From: Jason Merrill Date: Sun, 18 Jun 2017 04:55:02 +0000 (-0400) Subject: PR c++/60063 - -Wunused-local-typedefs and templates. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=20ef9df1cffcae042e02d596724e69c24047c557;p=gcc.git PR c++/60063 - -Wunused-local-typedefs and templates. * decl2.c (is_late_template_attribute): Return false for "used". From-SVN: r249347 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index d0825743e45..465e7d9ffe6 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,8 @@ 2017-06-17 Jason Merrill + PR c++/60063 - -Wunused-local-typedefs and templates. + * decl2.c (is_late_template_attribute): Return false for "used". + PR c++/70844 - -Wuseless-cast and inheriting constructor. * method.c (forward_parm): Suppress warn_useless_cast. diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c index 69cb40f2998..72239ec6208 100644 --- a/gcc/cp/decl2.c +++ b/gcc/cp/decl2.c @@ -1091,9 +1091,10 @@ is_late_template_attribute (tree attr, tree decl) if (is_attribute_p ("weak", name)) return true; - /* Attribute unused is applied directly, as it appertains to + /* Attributes used and unused are applied directly, as they appertain to decls. */ - if (is_attribute_p ("unused", name)) + if (is_attribute_p ("unused", name) + || is_attribute_p ("used", name)) return false; /* Attribute tls_model wants to modify the symtab. */ diff --git a/gcc/testsuite/g++.dg/warn/Wunused-local-typedefs-4.C b/gcc/testsuite/g++.dg/warn/Wunused-local-typedefs-4.C new file mode 100644 index 00000000000..7efe1125477 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wunused-local-typedefs-4.C @@ -0,0 +1,13 @@ +// PR c++/60063 +// { dg-options -Wunused-local-typedefs } + +template struct S; + +void foo (int i) { + typedef __attribute__ ((used)) S X; +} + +template +void bar (T i) { + typedef __attribute__ ((used)) S Y; +}