aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C')
-rw-r--r--gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C74
1 files changed, 0 insertions, 74 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C b/gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C
deleted file mode 100644
index 511ab7f231c..00000000000
--- a/gcc/testsuite/g++.old-deja/g++.brendan/dtors2.C
+++ /dev/null
@@ -1,74 +0,0 @@
-// GROUPS passed destructors
-// Check that virtual destructors work correctly. Specifically,
-// check that when you destruct an object of a derived class for
-// which the base class had an explicitly declared virtual destructor
-// no infinite recursion occurs.
-//
-// Bug description:
-// The generated g++ code apparently calls the base class destructor via
-// the virtual table, rather than directly. This, of course, results in the
-// infinite recursion.
-
-extern "C" void printf (char *, ...);
-
-int errors = 0;
-
-struct base {
- int member;
- base();
- virtual ~base();
-};
-
-base::base()
-{
-}
-
-base::~base()
-{
-}
-
-struct derived : public base
-{
- int member;
- derived();
- ~derived();
-};
-
-derived::derived() : base()
-{
-}
-
-int derived_destructor_calls = 0;
-
-extern void exit (int);
-
-derived::~derived()
-{
- if (++derived_destructor_calls > 2)
- errors++;
-}
-
-void test ();
-
-int main ()
-{
- test ();
-
- if (errors)
- printf ("FAIL\n");
- else
- printf ("PASS\n");
-
- return 0;
-}
-
-base* bp;
-
-void test()
-{
- derived a;
-
- a.member = 99;
- bp = new derived;
- delete bp;
-}