annotate gcc/testsuite/g++.old-deja/g++.mike/p4246.C @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run }
kono
parents:
diff changeset
2 // prms-id: 4246
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 extern "C" void abort ();
kono
parents:
diff changeset
5 int num_d;
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 class A
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 public:
kono
parents:
diff changeset
10 A() { }
kono
parents:
diff changeset
11 virtual ~A() { }
kono
parents:
diff changeset
12 virtual void id() { }
kono
parents:
diff changeset
13 };
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 class B
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 public:
kono
parents:
diff changeset
18 B() { }
kono
parents:
diff changeset
19 virtual ~B() { }
kono
parents:
diff changeset
20 virtual void id() { }
kono
parents:
diff changeset
21 };
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 class C : public A, public B
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 public:
kono
parents:
diff changeset
26 C() { }
kono
parents:
diff changeset
27 virtual ~C() { }
kono
parents:
diff changeset
28 void id() { abort(); }
kono
parents:
diff changeset
29 };
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 class D : public C
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 public:
kono
parents:
diff changeset
34 D() { ++num_d; }
kono
parents:
diff changeset
35 virtual ~D() { -- num_d; }
kono
parents:
diff changeset
36 void id() { }
kono
parents:
diff changeset
37 };
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 int main()
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 D* dp2 = new D;
kono
parents:
diff changeset
42 ((B*)dp2)->id();
kono
parents:
diff changeset
43 delete (B*) dp2;
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 B* bp1 = new D;
kono
parents:
diff changeset
46 bp1->id();
kono
parents:
diff changeset
47 delete bp1;
kono
parents:
diff changeset
48 return num_d != 0;
kono
parents:
diff changeset
49 }