From: Steven Bosscher Date: Wed, 19 Oct 2005 14:48:29 +0000 (+0000) Subject: re PR c/23228 (Silly "unused variable" warning after redeclaration of a local variable) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f95f80d1a762998d6b8731d506f6667ccbdaf996;p=gcc.git re PR c/23228 (Silly "unused variable" warning after redeclaration of a local variable) PR c/23228 * c-decl.c (pop_scope): Don't warn about an unused variable if it is marked with TREE_NO_WARNING. (duplicate_decls): Set TREE_NO_WARNING if olddecl and newdecl somenow mismatch and olddecl is to be replaced. From-SVN: r105621 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 45d936ae273..886d1f8f431 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2005-10-19 Steven Bosscher + + PR c/23228 + * c-decl.c (pop_scope): Don't warn about an unused variable + if it is marked with TREE_NO_WARNING. + (duplicate_decls): Set TREE_NO_WARNING if olddecl and newdecl + somenow mismatch and olddecl is to be replaced. + 2005-10-19 Eric Botcazou PR middle-end/23199 diff --git a/gcc/c-decl.c b/gcc/c-decl.c index c274df47ac4..f7cad3b7105 100644 --- a/gcc/c-decl.c +++ b/gcc/c-decl.c @@ -803,6 +803,7 @@ pop_scope (void) case VAR_DECL: /* Warnings for unused variables. */ if (!TREE_USED (p) + && !TREE_NO_WARNING (p) && !DECL_IN_SYSTEM_HEADER (p) && DECL_NAME (p) && !DECL_ARTIFICIAL (p) @@ -1876,7 +1877,11 @@ duplicate_decls (tree newdecl, tree olddecl) tree newtype = NULL, oldtype = NULL; if (!diagnose_mismatched_decls (newdecl, olddecl, &newtype, &oldtype)) - return false; + { + /* Avoid `unused variable' and other warnings warnings for OLDDECL. */ + TREE_NO_WARNING (olddecl) = 1; + return false; + } merge_decls (newdecl, olddecl, newtype, oldtype); return true;