1 //===---------------------- catch_class_03.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
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
) : C1(id
-1), C2(id
-2), id_(id
) {count
++;}
69 A(const A
& a
) : 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
== 2);
88 assert(static_cast<C1
&>(a
).id_
== 4);
89 assert(static_cast<C2
&>(a
).id_
== 3);
90 assert(static_cast<B
&>(static_cast<C1
&>(a
)).id_
== 2);
91 assert(static_cast<B
&>(static_cast<C2
&>(a
)).id_
== 1);
100 assert(A::count
== 0);
101 assert(C1::count
== 0);
102 assert(C2::count
== 0);
103 assert(B::count
== 0);
107 catch (const A
& a
) // can catch A
110 assert(static_cast<const C1
&>(a
).id_
== 4);
111 assert(static_cast<const C2
&>(a
).id_
== 3);
112 assert(static_cast<const B
&>(static_cast<const C1
&>(a
)).id_
== 2);
113 assert(static_cast<const B
&>(static_cast<const C2
&>(a
)).id_
== 1);
134 assert(A::count
== 0);
135 assert(C1::count
== 0);
136 assert(C2::count
== 0);
137 assert(B::count
== 0);
141 catch (const B
& a
) // can not catch B (ambiguous base)
145 catch (const C1
& c1
) // can catch C1
148 assert(static_cast<const B
&>(c1
).id_
== 2);
161 assert(A::count
== 0);
162 assert(C1::count
== 0);
163 assert(C2::count
== 0);
164 assert(B::count
== 0);
168 catch (const B
& a
) // can not catch B (ambiguous base)
172 catch (const C2
& c2
) // can catch C2
175 assert(static_cast<const B
&>(c2
).id_
== 1);
194 assert(A::count
== 0);
195 assert(C1::count
== 0);
196 assert(C2::count
== 0);
197 assert(B::count
== 0);