From eb5c3f052a57f3b14c24848d6a195d96f0a6bbef Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Sat, 4 Jul 2009 22:09:15 -0400 Subject: [PATCH] pt.c (retrieve_specialization): Don't get confused by a using-declaration that brings in another instance of... * pt.c (retrieve_specialization): Don't get confused by a using-declaration that brings in another instance of this template from a base class. * ptree.c (cxx_print_type): Fix logic. From-SVN: r149247 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/pt.c | 5 ++++- gcc/cp/ptree.c | 4 ++++ gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/g++.dg/template/using15.C | 25 +++++++++++++++++++++++++ 5 files changed, 43 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/template/using15.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 9953b2094e1..e3fe9c25b81 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,11 @@ 2009-07-04 Jason Merrill + * pt.c (retrieve_specialization): Don't get confused by a + using-declaration that brings in another instance of this template + from a base class. + + * ptree.c (cxx_print_type): Fix logic. + * cp-tree.h (LANG_DECL_FN_CHECK): Fix non-checking version. PR c++/40619 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 527fe04f5a8..4143bb121d9 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -974,7 +974,10 @@ retrieve_specialization (tree tmpl, tree args, hashval_t hash) for (fns = VEC_index (tree, methods, idx); fns; fns = OVL_NEXT (fns)) { tree fn = OVL_CURRENT (fns); - if (DECL_TEMPLATE_INFO (fn) && DECL_TI_TEMPLATE (fn) == tmpl) + if (DECL_TEMPLATE_INFO (fn) && DECL_TI_TEMPLATE (fn) == tmpl + /* using-declarations can add base methods to the method vec, + and we don't want those here. */ + && DECL_CONTEXT (fn) == class_specialization) return fn; } return NULL_TREE; diff --git a/gcc/cp/ptree.c b/gcc/cp/ptree.c index ec7a4712ba1..69279cd4883 100644 --- a/gcc/cp/ptree.c +++ b/gcc/cp/ptree.c @@ -91,6 +91,10 @@ cxx_print_type (FILE *file, tree node, int indent) print_node (file, "throws", TYPE_RAISES_EXCEPTIONS (node), indent + 4); return; + case RECORD_TYPE: + case UNION_TYPE: + break; + default: return; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 1582c882dac..da27711cf66 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2009-07-04 Jason Merrill + + * g++.dg/template/using15.C: New. + 2009-07-04 Jakub Jelinek * gfortran.dg/maxloc_1.f90: New test. diff --git a/gcc/testsuite/g++.dg/template/using15.C b/gcc/testsuite/g++.dg/template/using15.C new file mode 100644 index 00000000000..b158ac09cf6 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/using15.C @@ -0,0 +1,25 @@ +// Reduced from the testcase for c++/29433 + +template +struct A: T +{ + void f(typename T::type); + using T::f; + void g() { f(1); } +}; + +template +struct B: T +{ typedef int type; }; + +struct C +{ + typedef double type; + void f(); +}; + +int main() +{ + A > > a; + a.g(); +}