diff options
author | Jason Merrill <jason@redhat.com> | 2000-08-11 20:02:49 -0400 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2000-08-11 20:02:49 -0400 |
commit | e69c807271479a7c4e9efcc0340d24c8832936ee (patch) | |
tree | 6b29c92973d922ef6f392a6d9ec4a4ce8fbc02e4 /gcc | |
parent | 058557c4d1b036386daf2f124ab829e5371e0dfa (diff) | |
download | gcc-e69c807271479a7c4e9efcc0340d24c8832936ee.zip gcc-e69c807271479a7c4e9efcc0340d24c8832936ee.tar.gz gcc-e69c807271479a7c4e9efcc0340d24c8832936ee.tar.bz2 |
decl.c (lookup_name_real): Don't forget the TYPENAME_TYPE we're looking inside.
* decl.c (lookup_name_real): Don't forget the TYPENAME_TYPE we're
looking inside.
From-SVN: r35650
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/cp/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/cp/decl.c | 7 | ||||
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.ext/typename1.C | 32 |
3 files changed, 45 insertions, 1 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 2ce3f44..27126a5 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2000-08-11 Jason Merrill <jason@redhat.com> + + * decl.c (lookup_name_real): Don't forget the TYPENAME_TYPE we're + looking inside. + 2000-08-11 Nathan Sidwell <nathan@codesourcery.com> * cp-tree.h (resolve_scope_to_name): Remove unused prototype. @@ -882,7 +887,7 @@ Wed Jul 26 15:05:51 CEST 2000 Marc Espie <espie@cvs.openbsd.org> * semantics.c (emit_associated_thunks): New function. (expand_body): Use it. * ir.texi: Adjust decriptions of thunks. - + 2000-06-22 Jason Merrill <jason@redhat.com> * pt.c (tsubst_decl, case FUNCTION_DECL): Clear DECL_SAVED_TREE. diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index d3a0e52..e84264d 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -5898,6 +5898,13 @@ lookup_name_real (name, prefer_type, nonclass, namespaces_only) { val = lookup_member (type, name, 0, prefer_type); type_access_control (type, val); + + /* Restore the containing TYPENAME_TYPE if we looked + through it before. */ + if (got_scope && got_scope != type + && val && TREE_CODE (val) == TYPE_DECL + && TREE_CODE (TREE_TYPE (val)) == TYPENAME_TYPE) + TYPE_CONTEXT (TREE_TYPE (val)) = got_scope; } } else diff --git a/gcc/testsuite/g++.old-deja/g++.ext/typename1.C b/gcc/testsuite/g++.old-deja/g++.ext/typename1.C new file mode 100644 index 0000000..31de28f --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.ext/typename1.C @@ -0,0 +1,32 @@ +// Bug: g++ forgets about the instantiation of class1 when looking up +// class11_value, and tries to look things up in class1<class2>. + +// Special g++ Options: + +template<class ItIsInt> +struct class1 { + struct class11 { + typedef ItIsInt class11_value; + }; +}; + +template<class ItIsClass2> +struct class3 { + int f(); +}; + +template<class ItIsClass2> +int class3<ItIsClass2>::f() +{ + return class1<typename ItIsClass2::class2_value>::class11::class11_value(10); +} + +struct class2 { + typedef int class2_value; +}; + +int main() +{ + class3<class2> the_class3; + the_class3.f(); +} |