aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Merrill <jason@gcc.gnu.org>2000-05-14 21:08:23 -0400
committerJason Merrill <jason@gcc.gnu.org>2000-05-14 21:08:23 -0400
commitc2b2bca6360e429bccc10d083edfb72618b3a658 (patch)
tree1c6a61d8bb471970ec35a97ab02d644782ef6191
parent40c954b902ffda31de2ae17b160aaf5a200eba04 (diff)
downloadgcc-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.C21
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
+}