From: Geoffrey Keating Date: Wed, 24 Jul 2002 23:01:07 +0000 (+0000) Subject: In cp/ChangeLog: X-Git-Tag: releases/gcc-3.3.0~3655 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3cfab7ec187a78d27d5625fa8472897dc923617b;p=thirdparty%2Fgcc.git In cp/ChangeLog: * tree.c (cp_build_qualified_type_real): When copying pointer-to-method types, unshare the record that holds the cached pointer-to-member-function type. In testsuite/ChangeLog: * g++.dg/other/ptrmem4.C: New testcase. From-SVN: r55725 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ba8093f13aab..659ecfa5f3b4 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2002-07-24 Geoffrey Keating + + * tree.c (cp_build_qualified_type_real): When copying + pointer-to-method types, unshare the record that holds + the cached pointer-to-member-function type. + 2002-07-23 Neil Booth * cp-tree.h (FILE_FUNCTION_PREFIX_LEN): Remove. diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index b6e70ceface8..ea456f00b5fd 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -644,13 +644,13 @@ cp_build_qualified_type_real (type, type_quals, complain) result = build_qualified_type (type, type_quals); /* If this was a pointer-to-method type, and we just made a copy, - then we need to clear the cached associated - pointer-to-member-function type; it is not valid for the new - type. */ + then we need to unshare the record that holds the cached + pointer-to-member-function type, because these will be distinct + between the unqualified and qualified types. */ if (result != type && TREE_CODE (type) == POINTER_TYPE && TREE_CODE (TREE_TYPE (type)) == METHOD_TYPE) - TYPE_SET_PTRMEMFUNC_TYPE (result, NULL_TREE); + TYPE_LANG_SPECIFIC (result) = NULL; return result; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 2ee83e8006ac..90da516a3e83 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2002-07-24 Geoffrey Keating + + * g++.dg/other/ptrmem4.C: New testcase. + 2002-07-24 Richard Henderson * gcc.c-torture/execute/loop-2e.c: Rewrite for 64 bit and no mmap. diff --git a/gcc/testsuite/g++.dg/other/ptrmem4.C b/gcc/testsuite/g++.dg/other/ptrmem4.C new file mode 100644 index 000000000000..4f3f541e5831 --- /dev/null +++ b/gcc/testsuite/g++.dg/other/ptrmem4.C @@ -0,0 +1,18 @@ +// Bug: This checks that the pointer-to-member-function type is not +// shared between differently-qualified pointer-to-method types. + +// { dg-do compile } +struct A +{ + void f () {} +}; + +void (A::*const cp)() = &A::f; + +int main () +{ + void (A::* p)(); + void (A::** ip)() = &p; + + *ip = &A::f; +}