From: Giovanni Bajo Date: Fri, 18 Feb 2005 19:11:58 +0000 (+0000) Subject: re PR c++/19508 (dwarf2, ICE on __attribute__(aligned) in class template) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=aecc0cf071f98308306003f76458fe47ecebc3c9;p=gcc.git re PR c++/19508 (dwarf2, ICE on __attribute__(aligned) in class template) 2005-01-20 Giovanni Bajo PR c++/19508 * g++.dg/ext/attrib20.C: New test. 2005-01-20 Giovanni Bajo PR c++/19508 * decl2.c (grokfield): Do not apply attributes to template parameters as they are ignored by tsubst anyway. From-SVN: r95230 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 61cd6702c30..ab452e996db 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2005-01-20 Giovanni Bajo + + PR c++/19508 + * decl2.c (grokfield): Do not apply attributes to template parameters + as they are ignored by tsubst anyway. + 2005-02-18 Jakub Jelinek PR c++/19813 diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c index c7b04150e8f..113386a880f 100644 --- a/gcc/cp/decl2.c +++ b/gcc/cp/decl2.c @@ -878,7 +878,16 @@ grokfield (const cp_declarator *declarator, value = push_template_decl (value); if (attrlist) - cplus_decl_attributes (&value, attrlist, 0); + { + /* Avoid storing attributes in template parameters: + tsubst is not ready to handle them. */ + tree type = TREE_TYPE (value); + if (TREE_CODE (type) == TEMPLATE_TYPE_PARM + || TREE_CODE (type) == BOUND_TEMPLATE_TEMPLATE_PARM) + sorry ("applying attributes to template parameters is not implemented"); + else + cplus_decl_attributes (&value, attrlist, 0); + } return value; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 581e21a9028..5eb642ece86 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-01-20 Giovanni Bajo + + PR c++/19508 + * g++.dg/ext/attrib20.C: New test. + 2004-02-18 Andrew Pinski PR middle-end/20030 diff --git a/gcc/testsuite/g++.dg/ext/attrib20.C b/gcc/testsuite/g++.dg/ext/attrib20.C new file mode 100644 index 00000000000..e46e8ae2077 --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/attrib20.C @@ -0,0 +1,23 @@ +// { dg-do compile } +// { dg-options "-g" } +// Origin: +// PR c++/19508: avoid attributes for template parameters + +template +struct BVector +{ + typedef T T2; + typedef T value_type __attribute__ ((aligned(8))); // { dg-bogus "attribute" "attribute" { xfail *-*-* } } + typedef T2 value_type2 __attribute__ ((aligned(8))); // { dg-bogus "attribute" "attribute" { xfail *-*-* } } + value_type v; +}; +BVector m; + +template