PR c++/51427 - Better diagnostic when union/struct tags conflicts
authordodji <dodji@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 6 Dec 2011 10:06:49 +0000 (10:06 +0000)
committerdodji <dodji@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 6 Dec 2011 10:06:49 +0000 (10:06 +0000)
gcc/cp/

PR c++/51427
* parser.c (cp_parser_check_class_key): Add note about earlier
declaration.

gcc/testsuite/

PR c++/51427
* g++.dg/diagnostic/wrong-tag-1.C

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@182043 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/diagnostic/wrong-tag-1.C [new file with mode: 0644]

index 25e381a..4391a47 100644 (file)
@@ -1,3 +1,9 @@
+2011-12-06  Dodji Seketeli  <dodji@redhat.com>
+
+       PR c++/51427
+       * parser.c (cp_parser_check_class_key): Add note about earlier
+       declaration.
+
 2011-12-05  Fabien ChĂȘne  <fabien@gcc.gnu.org>
 
        PR c++/51319
index 9e7a398..daf2ded 100644 (file)
@@ -22544,10 +22544,14 @@ static void
 cp_parser_check_class_key (enum tag_types class_key, tree type)
 {
   if ((TREE_CODE (type) == UNION_TYPE) != (class_key == union_type))
-    permerror (input_location, "%qs tag used in naming %q#T",
-           class_key == union_type ? "union"
-            : class_key == record_type ? "struct" : "class",
-            type);
+    {
+      permerror (input_location, "%qs tag used in naming %q#T",
+                class_key == union_type ? "union"
+                : class_key == record_type ? "struct" : "class",
+                type);
+      inform (DECL_SOURCE_LOCATION (TYPE_NAME (type)),
+             "%q#T was previously declared here", type);
+    }
 }
 
 /* Issue an error message if DECL is redeclared with different
index 12709b7..e920bf7 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-06  Dodji Seketeli  <dodji@redhat.com>
+
+       PR c++/51427
+       * g++.dg/diagnostic/wrong-tag-1.C
+
 2011-12-05  Fabien ChĂȘne  <fabien@gcc.gnu.org>
 
        PR c++/51319
diff --git a/gcc/testsuite/g++.dg/diagnostic/wrong-tag-1.C b/gcc/testsuite/g++.dg/diagnostic/wrong-tag-1.C
new file mode 100644 (file)
index 0000000..2cf75f8
--- /dev/null
@@ -0,0 +1,4 @@
+// Origin PR c++/51427
+
+typedef struct _GMutex GMutex; // { dg-message "previously declared here"}
+typedef union _GMutex GMutex; // { dg-error "tag used in naming" }