diff options
author | simartin <simartin@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-01-23 22:33:51 +0000 |
---|---|---|
committer | simartin <simartin@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-01-23 22:33:51 +0000 |
commit | 324392c5e680b566fe3766f3075b5ca0ecdc52c2 (patch) | |
tree | b320b1b486f928f965fef64e2fc15b2fe268e454 | |
parent | b5af670241b1f4a1884d24df93843bc651715bf2 (diff) | |
download | ppe42-gcc-324392c5e680b566fe3766f3075b5ca0ecdc52c2.tar.gz ppe42-gcc-324392c5e680b566fe3766f3075b5ca0ecdc52c2.zip |
2007-01-23 Simon Martin <simartin@users.sourceforge.net>
PR c++/27492
* decl.c (duplicate_decls): Don't reset DECL_INVALID_OVERRIDER_P for
function decls.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@121089 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/decl.c | 1 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/inherit/covariant15.C | 18 |
4 files changed, 30 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 65366bb4025..afc66a88d31 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2007-01-23 Simon Martin <simartin@users.sourceforge.net> + + PR c++/27492 + * decl.c (duplicate_decls): Don't reset DECL_INVALID_OVERRIDER_P for + function decls. + 2007-01-23 Ian Lance Taylor <iant@google.com> * typeck.c (convert_for_assignment): Only warn about a = b = c diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index a100c9dc9ce..dfd199b1a7e 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -1576,6 +1576,7 @@ duplicate_decls (tree newdecl, tree olddecl, bool newdecl_is_friend) DECL_STATIC_DESTRUCTOR (newdecl) |= DECL_STATIC_DESTRUCTOR (olddecl); DECL_PURE_VIRTUAL_P (newdecl) |= DECL_PURE_VIRTUAL_P (olddecl); DECL_VIRTUAL_P (newdecl) |= DECL_VIRTUAL_P (olddecl); + DECL_INVALID_OVERRIDER_P (newdecl) |= DECL_INVALID_OVERRIDER_P (olddecl); DECL_THIS_STATIC (newdecl) |= DECL_THIS_STATIC (olddecl); if (DECL_OVERLOADED_OPERATOR_P (olddecl) != ERROR_MARK) SET_OVERLOADED_OPERATOR_CODE diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 81f1370986c..b46cf793da6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2007-01-23 Simon Martin <simartin@users.sourceforge.net> + + PR c++/27492 + * g++.dg/inherit/covariant15.C: New test. + 2007-01-23 Ian Lance Taylor <iant@google.com> * g++.dg/warn/Wparentheses-24.C: New test. diff --git a/gcc/testsuite/g++.dg/inherit/covariant15.C b/gcc/testsuite/g++.dg/inherit/covariant15.C new file mode 100644 index 00000000000..4696cc6334a --- /dev/null +++ b/gcc/testsuite/g++.dg/inherit/covariant15.C @@ -0,0 +1,18 @@ +/* This used to ICE (PR c++/27492) */ +/* { dg-do "compile" } */ + +struct A {}; + +class B : A +{ + virtual A* foo(); /* { dg-error "overriding" } */ +}; + +struct C : virtual B +{ + virtual C* foo(); /* { dg-error "invalid covariant return type" } */ +}; + +C* C::foo() { return 0; } + +struct D : C {}; |