From: Nathan Sidwell Date: Wed, 8 Mar 2000 17:17:50 +0000 (+0000) Subject: * g++.old-deja/g++.eh/vbase4.C: New test. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=45f984e4ba75b38331d050fd87fa97cb17194416;p=gcc.git * g++.old-deja/g++.eh/vbase4.C: New test. From-SVN: r32427 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a2ce4c594e1..146c2b63c8d 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2000-03-08 Nathan Sidwell + + * g++.old-deja/g++.eh/vbase4.C: New test. + 2000-03-08 Nathan Sidwell * g++.old-deja/g++.bugs/900215_01.C: Adjust. 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 00000000000..60360864b2b --- /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 + +// 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; +}