aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorGiovanni Bajo <giovannibajo@gcc.gnu.org>2004-02-14 02:15:20 +0000
committerGiovanni Bajo <giovannibajo@gcc.gnu.org>2004-02-14 02:15:20 +0000
commit32bb574bf52ca7e673a4eabf3ab37a50550316cb (patch)
tree68eb4407b0b83b7ae27a707a670abb5ee0340369 /gcc
parent7162281a3221c98be6c6c96b9cafe13feddcdad3 (diff)
downloadgcc-32bb574bf52ca7e673a4eabf3ab37a50550316cb.zip
gcc-32bb574bf52ca7e673a4eabf3ab37a50550316cb.tar.gz
gcc-32bb574bf52ca7e673a4eabf3ab37a50550316cb.tar.bz2
re PR c++/13927 (duplicated error message on bad redeclaration of anon union)
PR c++/13927 * g++.dg/other/error8.C: New test. From-SVN: r77788
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/other/error8.C26
2 files changed, 31 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 0b1289d..4b29491 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2004-02-13 Giovanni Bajo <giovannibajo@gcc.gnu.org>
+
+ PR c++/13927
+ * g++.dg/other/error8.C: New test.
+
2004-02-13 Mark Mitchell <mark@codesourcery.com>
PR c++/14122
diff --git a/gcc/testsuite/g++.dg/other/error8.C b/gcc/testsuite/g++.dg/other/error8.C
new file mode 100644
index 0000000..d427e3c
--- /dev/null
+++ b/gcc/testsuite/g++.dg/other/error8.C
@@ -0,0 +1,26 @@
+// { dg-do compile }
+// Contributed by: Michael Elizabeth Chastain
+// <mec dot gnu at mindspring dot com>
+// PR c++/13927: Wrong error message for redeclartion of type from union
+
+void foo(void)
+{
+ union { int alpha; int beta; }; // { dg-error "previous declaration `int alpha'" }
+ double alpha; // { dg-error "declaration of" }
+}
+
+// This checks both the templated version, and the position of the diagnostic
+// (which is currently wrong).
+template <int>
+void tfoo(void)
+{
+ union {
+ int alpha; // { dg-error "" "" { xfail *-*-* } }
+ int beta;
+ }; // { dg-bogus "" "misplaced position of the declaration" { xfail *-*-* } }
+ double alpha; // { dg-error "" "" }
+}
+
+// The duplicated error messages are xfailed for now (tracked in the PR)
+// { dg-bogus "" "duplicate error messages" { xfail *-*-* } 8 }
+// { dg-bogus "" "duplicate error messages" { xfail *-*-* } 9 }