annotate gcc/testsuite/g++.dg/cpp0x/union3.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 // Runtime test for C++11 unrestricted unions
kono
parents:
diff changeset
2 // { dg-do run { target c++11 } }
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 int c, d;
kono
parents:
diff changeset
5 struct A
kono
parents:
diff changeset
6 {
kono
parents:
diff changeset
7 int i;
kono
parents:
diff changeset
8 A(): i(1) { ++c; }
kono
parents:
diff changeset
9 A(const A&): i(2) { ++c; }
kono
parents:
diff changeset
10 ~A() { ++d; }
kono
parents:
diff changeset
11 };
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 union B
kono
parents:
diff changeset
14 {
kono
parents:
diff changeset
15 A a;
kono
parents:
diff changeset
16 B() { }
kono
parents:
diff changeset
17 B(const B& b) { }
kono
parents:
diff changeset
18 ~B() { }
kono
parents:
diff changeset
19 };
kono
parents:
diff changeset
20
kono
parents:
diff changeset
21 struct C
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 union { A a; };
kono
parents:
diff changeset
24 C() { }
kono
parents:
diff changeset
25 C(const C&) { }
kono
parents:
diff changeset
26 ~C() { }
kono
parents:
diff changeset
27 };
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 union D
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 A a;
kono
parents:
diff changeset
32 D(): a() { }
kono
parents:
diff changeset
33 D(const D& d): a(d.a) { }
kono
parents:
diff changeset
34 ~D() { a.~A(); }
kono
parents:
diff changeset
35 };
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 struct E
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 union { A a; };
kono
parents:
diff changeset
40 E(): a() { }
kono
parents:
diff changeset
41 E(const E& e): a (e.a) { }
kono
parents:
diff changeset
42 ~E() { a.~A(); }
kono
parents:
diff changeset
43 };
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 int main()
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 B b1;
kono
parents:
diff changeset
49 B b2(b1);
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 C c1;
kono
parents:
diff changeset
52 C c2(c1);
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 if (c != 0 || d != 0)
kono
parents:
diff changeset
56 return c+d*10;
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 {
kono
parents:
diff changeset
59 D d1;
kono
parents:
diff changeset
60 D d2(d1);
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 E e1;
kono
parents:
diff changeset
63 E e2(e1);
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 if (c != 4 || d != 4)
kono
parents:
diff changeset
67 return c*100+d*1000;
kono
parents:
diff changeset
68 }