diff options
author | Jason Merrill <jason@redhat.com> | 2009-07-04 22:09:15 -0400 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2009-07-04 22:09:15 -0400 |
commit | eb5c3f052a57f3b14c24848d6a195d96f0a6bbef (patch) | |
tree | f4ac00f6323e57653d33af03809113217cdd5479 /gcc/cp/pt.c | |
parent | bf15d4697d6d4605699730e286f822ed27ff180d (diff) | |
download | gcc-eb5c3f052a57f3b14c24848d6a195d96f0a6bbef.tar.gz |
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
Diffstat (limited to 'gcc/cp/pt.c')
-rw-r--r-- | gcc/cp/pt.c | 5 |
1 files changed, 4 insertions, 1 deletions
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; |