From: Jason Merrill Date: Mon, 12 Apr 1999 10:54:06 +0000 (+0000) Subject: * pt.c (lookup_template_class): Look through implict typename. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=802dbc34915da16c5fe637f54d1a18287eabb9d2;p=gcc.git * pt.c (lookup_template_class): Look through implict typename. From-SVN: r26370 --- 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); } }