aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/g++.old-deja/g++.eh/vbase4.C39
2 files changed, 43 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index a2ce4c5..146c2b6 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,9 @@
2000-03-08 Nathan Sidwell <nathan@codesourcery.com>
+ * g++.old-deja/g++.eh/vbase4.C: New test.
+
+2000-03-08 Nathan Sidwell <nathan@codesourcery.com>
+
* g++.old-deja/g++.bugs/900215_01.C: Adjust.
2000-03-08 Nathan Sidwell <nathan@codesourcery.com>
diff --git a/gcc/testsuite/g++.old-deja/g++.eh/vbase4.C b/gcc/testsuite/g++.old-deja/g++.eh/vbase4.C
new file mode 100644
index 0000000..6036086
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.eh/vbase4.C
@@ -0,0 +1,39 @@
+
+// Copyright (C) 2000 Free Software Foundation, Inc.
+// Contributed by Nathan Sidwell 8 Mar 2000 <nathan@codesourcery.com>
+
+// Derived from PR#7
+
+// We need to destroy the thrown object when exiting the catch
+// clause. That needs to destroy the original thrown object, not
+// the caught one (which might be a base).
+
+static int ok = 0;
+
+struct A
+{
+ A (){};
+ virtual ~A () {};
+};
+
+struct B : virtual A
+{
+ int value;
+ B ()
+ :value(10)
+ {}
+ ~B()
+ {
+ if (value == 10)
+ ok = 1;
+ }
+};
+
+int main()
+{
+ try {
+ throw B ();
+ } catch (A & e) {
+ }
+ return !ok;
+}