diff options
author | Giovanni Bajo <giovannibajo@gcc.gnu.org> | 2004-02-14 02:15:20 +0000 |
---|---|---|
committer | Giovanni Bajo <giovannibajo@gcc.gnu.org> | 2004-02-14 02:15:20 +0000 |
commit | 32bb574bf52ca7e673a4eabf3ab37a50550316cb (patch) | |
tree | 68eb4407b0b83b7ae27a707a670abb5ee0340369 /gcc | |
parent | 7162281a3221c98be6c6c96b9cafe13feddcdad3 (diff) | |
download | gcc-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/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/other/error8.C | 26 |
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 } |