From: jason Date: Wed, 23 Jan 2008 05:11:58 +0000 (+0000) Subject: PR c++/28560 X-Git-Tag: upstream/4.9.2~44024 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b63863e03023abc709802829be55ca5680fb054d;p=platform%2Fupstream%2Flinaro-gcc.git PR c++/28560 * decl.c (groktypename): Also ignore attributes on dependent possibly-class types. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@131755 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index f9971d4..667f813 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -9,6 +9,10 @@ 2008-01-22 Jason Merrill + PR c++/28560 + * decl.c (groktypename): Also ignore attributes on dependent + possibly-class types. + PR c++/34912 * friend.c (do_friend): Check for prior declaration of a friend function of a local class. diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 338e1ed..4640adf 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -3908,8 +3908,12 @@ groktypename (cp_decl_specifier_seq *type_specifiers, if (attrs) { if (CLASS_TYPE_P (type)) - warning (OPT_Wattributes, "ignoring attributes applied to class type " - "outside of definition"); + warning (OPT_Wattributes, "ignoring attributes applied to class type %qT " + "outside of definition", type); + else if (IS_AGGR_TYPE (type)) + /* A template type parameter or other dependent type. */ + warning (OPT_Wattributes, "ignoring attributes applied to dependent " + "type %qT without an associated declaration", type); else cplus_decl_attributes (&type, attrs, 0); } diff --git a/gcc/testsuite/g++.dg/ext/tmplattr8.C b/gcc/testsuite/g++.dg/ext/tmplattr8.C new file mode 100644 index 0000000..4b8707a --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/tmplattr8.C @@ -0,0 +1,8 @@ +// PR c++/28560 + +template struct A {}; + +template struct B; + +template struct C : + A::X __attribute__((unused))> {}; // { dg-warning "attribute" }