//===------------------------- dynamic_cast.pass.cpp ----------------------===// // // The LLVM Compiler Infrastructure // // This file is dual licensed under the MIT and the University of Illinois Open // Source Licenses. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #include // This test explicitly tests dynamic cast with types that have inaccessible // bases. #if defined(__clang__) #pragma clang diagnostic ignored "-Winaccessible-base" #endif typedef char Pad1[43981]; typedef char Pad2[34981]; typedef char Pad3[93481]; typedef char Pad4[13489]; typedef char Pad5[81349]; typedef char Pad6[34819]; typedef char Pad7[3489]; namespace t1 { // PR33425 struct C3 { virtual ~C3() {} Pad1 _; }; struct C5 : protected virtual C3 { Pad2 _; }; struct C6 : virtual C5 { Pad3 _; }; struct C7 : virtual C3 { Pad4 _; }; struct C9 : C6, C7 { Pad5 _; }; C9 c9; C3 *c3 = &c9; void test() { assert(dynamic_cast(c3) == static_cast(&c9)); assert(dynamic_cast(c3) == static_cast(&c9)); assert(dynamic_cast(c3) == static_cast(&c9)); assert(dynamic_cast(c3) == static_cast(&c9)); assert(dynamic_cast(c3) == static_cast(&c9)); } } // t1 namespace t2 { // PR33425 struct Src { virtual ~Src() {} Pad1 _; }; struct Mask : protected virtual Src { Pad2 _; }; struct Dest : Mask { Pad3 _; }; struct Root : Dest, virtual Src { Pad4 _; }; Root root; Src *src = &root; void test() { assert(dynamic_cast(src) == static_cast(&root)); assert(dynamic_cast(src) == static_cast(&root)); assert(dynamic_cast(src) == static_cast(&root)); assert(dynamic_cast(src) == static_cast(&root)); } } // t2 namespace t3 { // PR33487 struct Class1 { virtual ~Class1() {} Pad1 _; }; struct Shared : virtual Class1 { Pad2 _; }; struct Class6 : virtual Shared { Pad3 _; }; struct Left : Class6 { Pad4 _; }; struct Right : Class6 { Pad5 _; }; struct Main : Left, Right { Pad6 _; }; Main m; Class1 *c1 = &m; void test() { assert(dynamic_cast(c1) == static_cast(&m)); assert(dynamic_cast(c1) == static_cast(&m)); assert(dynamic_cast(c1) == 0); assert(dynamic_cast(c1) == static_cast(&m)); assert(dynamic_cast(c1) == static_cast(&m)); assert(dynamic_cast(c1) == static_cast(&m)); } } // t3 namespace t4 { // PR33439 struct C2 { virtual ~C2() {} Pad1 _; }; struct C3 { virtual ~C3() {} Pad2 _; }; struct C4 : C3 { Pad3 _; }; struct C8 : C2, virtual C4 { Pad4 _; }; struct C9 : C4, C8 { Pad5 _; }; C9 c9; C2 *c2 = &c9; void test() { assert(dynamic_cast(c2) == static_cast(&c9)); assert(dynamic_cast(c2) == 0); assert(dynamic_cast(c2) == 0); assert(dynamic_cast(c2) == static_cast(&c9)); assert(dynamic_cast(c2) == static_cast(&c9)); } } // t4 namespace t5 { // PR33439 struct Dummy { virtual ~Dummy() {} Pad1 _; }; struct Src { virtual ~Src() {} Pad2 _; }; struct Dest : Dummy { Pad3 _; }; struct A1 : Dest { Pad4 _; }; struct A2 : Dest { Pad5 _; }; struct Root : Src, A1, A2 { Pad6 _; }; Root root; Src *src = &root; void test() { assert(dynamic_cast(src) == 0); assert(dynamic_cast(src) == static_cast(&root)); assert(dynamic_cast(src) == 0); assert(dynamic_cast(src) == static_cast(&root)); assert(dynamic_cast(src) == static_cast(&root)); } } // t5 int main() { t1::test(); t2::test(); t3::test(); t4::test(); t5::test(); }