Commit bb85aa74 by Marek Polacek Committed by Marek Polacek

re PR c/81795 (Stray "originally defined here" when using -Wc++-compat with…

re PR c/81795 (Stray "originally defined here" when using -Wc++-compat with #pragma GCC diagnostic push/pop)

	PR c/81795
	* c-decl.c (pushtag): Only print inform if the warning was printed.
	(grokdeclarator): Likewise.

	* gcc.dg/pr81795.c: New test.

From-SVN: r251056
parent 27c33b8f
2017-08-11 Marek Polacek <polacek@redhat.com>
PR c/81795
* c-decl.c (pushtag): Only print inform if the warning was printed.
(grokdeclarator): Likewise.
2017-08-10 David Malcolm <dmalcolm@redhat.com>
* c-parser.c (c_parser_error): Rename to...
......
......@@ -1557,11 +1557,10 @@ pushtag (location_t loc, tree name, tree type)
&& (TYPE_MAIN_VARIANT (TREE_TYPE (b->decl))
!= TYPE_MAIN_VARIANT (type)))
{
warning_at (loc, OPT_Wc___compat,
("using %qD as both a typedef and a tag is "
"invalid in C++"),
b->decl);
if (b->locus != UNKNOWN_LOCATION)
if (warning_at (loc, OPT_Wc___compat,
("using %qD as both a typedef and a tag is "
"invalid in C++"), b->decl)
&& b->locus != UNKNOWN_LOCATION)
inform (b->locus, "originally defined here");
}
}
......@@ -6596,11 +6595,10 @@ grokdeclarator (const struct c_declarator *declarator,
|| (current_scope == file_scope && B_IN_EXTERNAL_SCOPE (b)))
&& TYPE_MAIN_VARIANT (b->decl) != TYPE_MAIN_VARIANT (type))
{
warning_at (declarator->id_loc, OPT_Wc___compat,
("using %qD as both a typedef and a tag is "
"invalid in C++"),
decl);
if (b->locus != UNKNOWN_LOCATION)
if (warning_at (declarator->id_loc, OPT_Wc___compat,
("using %qD as both a typedef and a tag is "
"invalid in C++"), decl)
&& b->locus != UNKNOWN_LOCATION)
inform (b->locus, "originally defined here");
}
}
......
2017-08-11 Marek Polacek <polacek@redhat.com>
PR c/81795
* gcc.dg/pr81795.c: New test.
2017-08-11 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/60355
......
/* PR c/81795 */
/* { dg-do compile } */
/* { dg-options "-Wc++-compat" } */
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wc++-compat"
struct S { int f; }; /* { dg-bogus "note: originally defined here" } */
typedef int S; /* { dg-bogus "invalid in C\[+\]\[+\]" } */
typedef int T; /* { dg-bogus "note: originally defined here" } */
struct T { int f; }; /* { dg-bogus "invalid in C\[+\]\[+\]" } */
#pragma GCC diagnostic pop
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment