diff options
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.eh/catch11.C')
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.eh/catch11.C | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.eh/catch11.C b/gcc/testsuite/g++.old-deja/g++.eh/catch11.C new file mode 100644 index 000000000..275a96ac7 --- /dev/null +++ b/gcc/testsuite/g++.old-deja/g++.eh/catch11.C @@ -0,0 +1,64 @@ +// { dg-do run } +// Copyright (C) 2000 Free Software Foundation, Inc. +// Contributed by Nathan Sidwell 24 May 2000 <nathan@codesourcery.com> + +// we should be able to catch a base a virtual, provided it is accessible by at +// least one public path +// -- public, << private, == virtual +// E<<B==A +// +--C==A +// +<<D==A + +struct A {}; +struct B : virtual A {}; +struct C : virtual A {}; +struct D : virtual A {}; +struct E : private B, public C, private D {}; + +extern "C" void abort (); + +void fne (E *e) +{ + throw e; +} + +void check(E *e) +{ + int caught; + + caught = 0; + try { fne(e); } + catch(A *p) { caught = 1; if (p != e) abort();} + catch(...) { abort(); } + if (!caught) abort(); + + caught = 0; + try { fne(e); } + catch(B *p) { abort ();} + catch(...) { caught = 1; } + if (!caught) abort(); + + caught = 0; + try { fne(e); } + catch(C *p) { caught = 1; if (p != e) abort();} + catch(...) { abort(); } + if (!caught) abort(); + + caught = 0; + try { fne(e); } + catch(D *p) { abort ();} + catch(...) { caught = 1; } + if (!caught) abort(); + + return; +} + +int main () +{ + E e; + + check (&e); + check ((E *)0); + + return 0; +} |