From: Giovanni Bajo Date: Thu, 23 Dec 2004 01:49:39 +0000 (+0000) Subject: re PR c++/18733 (friend rejected) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f65b7de376c7284b60167d8400ddbcfddff58db6;p=gcc.git re PR c++/18733 (friend rejected) PR c++/18733 * pt.c (check_explicit_specialization): Use special logic to validate befriended specializations. PR c++/18733 * g++.dg/template/friend33.C: New testcase. From-SVN: r92527 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ee0f56e3a36..2d6e1af0133 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2004-12-23 Giovanni Bajo + + PR c++/18733 + * pt.c (check_explicit_specialization): Use special logic to validate + befriended specializations. + 2004-12-22 Mark Mitchell * rtti.c (emit_support_tinfos): Avoid using C99 semantics. diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index a73f6916f02..07cdd5d7356 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -1738,7 +1738,15 @@ check_explicit_specialization (tree declarator, tree dname = DECL_NAME (decl); tmpl_spec_kind tsk; - tsk = current_tmpl_spec_kind (template_count); + if (is_friend) + { + if (!processing_specialization) + tsk = tsk_none; + else + tsk = tsk_excessive_parms; + } + else + tsk = current_tmpl_spec_kind (template_count); switch (tsk) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 555353a2d56..b966939c2ac 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2004-12-23 Giovanni Bajo + + PR c++/18733 + * g++.dg/template/friend33.C: New testcase. + 2004-12-22 Mark Mitchell PR c++/18464 diff --git a/gcc/testsuite/g++.dg/template/friend33.C b/gcc/testsuite/g++.dg/template/friend33.C new file mode 100644 index 00000000000..f1b5cb26aa3 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/friend33.C @@ -0,0 +1,12 @@ +// { dg-do compile } +// PR c++/18733: Validation of template headers in friends + +template struct A +{ + void foo(); +}; + +struct B +{ + friend void A<0>::foo(); +};