diff options
author | Jason Merrill <jason@gcc.gnu.org> | 2000-05-14 21:08:23 -0400 |
---|---|---|
committer | Jason Merrill <jason@gcc.gnu.org> | 2000-05-14 21:08:23 -0400 |
commit | c2b2bca6360e429bccc10d083edfb72618b3a658 (patch) | |
tree | 1c6a61d8bb471970ec35a97ab02d644782ef6191 | |
parent | 40c954b902ffda31de2ae17b160aaf5a200eba04 (diff) | |
download | gcc-c2b2bca6360e429bccc10d083edfb72618b3a658.zip gcc-c2b2bca6360e429bccc10d083edfb72618b3a658.tar.gz gcc-c2b2bca6360e429bccc10d083edfb72618b3a658.tar.bz2 |
new
From-SVN: r33903
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.eh/catch10.C | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.eh/catch10.C b/gcc/testsuite/g++.old-deja/g++.eh/catch10.C new file mode 100644 index 0000000..639f166 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.eh/catch10.C @@ -0,0 +1,21 @@ +// Test that we notice unfortunate handler ordering. + +struct A { }; +struct B: public A { }; +struct C: private A { }; + +void f(); +void g() +{ + try { f(); } + catch (...) { } // ERROR - ... followed by others + catch (A*) { } + + try { f(); } + catch (A*) { } // WARNING - A* before B* + catch (B*) { } // WARNING - A* before B* + + try { f(); } + catch (A*) { } + catch (C*) { } // no warning; A is private base +} |