1 //===---------------------- catch_class_04.cpp ----------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
10 This test checks that adjustedPtr is correct as there exist offsets in this
11 object for the various subobjects, all of which have a unique id_ to
12 check against. It also checks that virtual bases work properly
15 // UNSUPPORTED: libcxxabi-no-exceptions
21 // Clang emits warnings about exceptions of type 'Child' being caught by
22 // an earlier handler of type 'Base'. Congrats clang, you've just
23 // diagnosed the behavior under test.
24 #if defined(__clang__)
25 #pragma clang diagnostic ignored "-Wexceptions"
32 explicit B(int id
) : id_(id
) {count
++;}
33 B(const B
& a
) : id_(a
.id_
) {count
++;}
44 explicit C1(int id
) : B(id
-2), id_(id
) {count
++;}
45 C1(const C1
& a
) : B(a
.id_
-2), id_(a
.id_
) {count
++;}
56 explicit C2(int id
) : B(id
-2), id_(id
) {count
++;}
57 C2(const C2
& a
) : B(a
.id_
-2), id_(a
.id_
) {count
++;}
68 explicit A(int id
) : B(id
+3), C1(id
-1), C2(id
-2), id_(id
) {count
++;}
69 A(const A
& a
) : B(a
.id_
+3), C1(a
.id_
-1), C2(a
.id_
-2), id_(a
.id_
) {count
++;}
77 assert(A::count
== 0);
78 assert(C1::count
== 0);
79 assert(C2::count
== 0);
80 assert(B::count
== 0);
82 assert(A::count
== 1);
83 assert(C1::count
== 1);
84 assert(C2::count
== 1);
85 assert(B::count
== 1);
88 assert(static_cast<C1
&>(a
).id_
== 4);
89 assert(static_cast<C2
&>(a
).id_
== 3);
90 assert(static_cast<B
&>(a
).id_
== 8);
99 assert(A::count
== 0);
100 assert(C1::count
== 0);
101 assert(C2::count
== 0);
102 assert(B::count
== 0);
106 catch (const A
& a
) // can catch A
109 assert(static_cast<const C1
&>(a
).id_
== 4);
110 assert(static_cast<const C2
&>(a
).id_
== 3);
111 assert(static_cast<const B
&>(a
).id_
== 8);
132 assert(A::count
== 0);
133 assert(C1::count
== 0);
134 assert(C2::count
== 0);
135 assert(B::count
== 0);
139 catch (const B
& a
) // can catch B
141 assert(static_cast<const B
&>(a
).id_
== 8);
158 assert(A::count
== 0);
159 assert(C1::count
== 0);
160 assert(C2::count
== 0);
161 assert(B::count
== 0);
165 catch (const C2
& c2
) // can catch C2
170 catch (const B
& a
) // can not catch B (ambiguous base)
184 assert(A::count
== 0);
185 assert(C1::count
== 0);
186 assert(C2::count
== 0);
187 assert(B::count
== 0);
191 catch (const C1
& c1
) // can catch C1
194 assert(static_cast<const B
&>(c1
).id_
== 8);
217 assert(A::count
== 0);
218 assert(C1::count
== 0);
219 assert(C2::count
== 0);
220 assert(B::count
== 0);