From 802dbc34915da16c5fe637f54d1a18287eabb9d2 Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Mon, 12 Apr 1999 10:54:06 +0000 Subject: [PATCH] * pt.c (lookup_template_class): Look through implict typename. From-SVN: r26370 --- gcc/cp/ChangeLog | 4 ++++ gcc/cp/pt.c | 11 +++++++++-- 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index be8c8653ad9..992aaa9daf7 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,7 @@ +1999-04-12 Jason Merrill + + * pt.c (lookup_template_class): Look through implict typename. + 1999-04-11 Mark Mitchell * friend.c (add_friend): Deal gracefully with error_mark_node. diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 2988ed6fb6f..e8de7769980 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -3581,9 +3581,16 @@ lookup_template_class (d1, arglist, in_decl, context, entering_scope) } else if (TREE_CODE (d1) == TYPE_DECL && IS_AGGR_TYPE (TREE_TYPE (d1))) { - if (CLASSTYPE_TEMPLATE_INFO (TREE_TYPE (d1))) + tree type = TREE_TYPE (d1); + + /* If we are declaring a constructor, say A::A, we will get + an implicit typename for the second A. Deal with it. */ + if (TREE_CODE (type) == TYPENAME_TYPE && TREE_TYPE (type)) + type = TREE_TYPE (type); + + if (CLASSTYPE_TEMPLATE_INFO (type)) { - template = CLASSTYPE_TI_TEMPLATE (TREE_TYPE (d1)); + template = CLASSTYPE_TI_TEMPLATE (type); d1 = DECL_NAME (template); } } -- 2.30.2