Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / libcxx / test / std / utilities / meta / meta.unary / meta.unary.prop / is_nothrow_destructible.pass.cpp
blob60d55620f32a466d391fd3b69f374a3c07251bc6
1 //===----------------------------------------------------------------------===//
2 //
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
6 //
7 //===----------------------------------------------------------------------===//
9 // type_traits
11 // is_nothrow_destructible
13 #include <type_traits>
14 #include "test_macros.h"
16 template <class T>
17 void test_is_nothrow_destructible()
19 static_assert( std::is_nothrow_destructible<T>::value, "");
20 static_assert( std::is_nothrow_destructible<const T>::value, "");
21 static_assert( std::is_nothrow_destructible<volatile T>::value, "");
22 static_assert( std::is_nothrow_destructible<const volatile T>::value, "");
23 #if TEST_STD_VER > 14
24 static_assert( std::is_nothrow_destructible_v<T>, "");
25 static_assert( std::is_nothrow_destructible_v<const T>, "");
26 static_assert( std::is_nothrow_destructible_v<volatile T>, "");
27 static_assert( std::is_nothrow_destructible_v<const volatile T>, "");
28 #endif
31 template <class T>
32 void test_is_not_nothrow_destructible()
34 static_assert(!std::is_nothrow_destructible<T>::value, "");
35 static_assert(!std::is_nothrow_destructible<const T>::value, "");
36 static_assert(!std::is_nothrow_destructible<volatile T>::value, "");
37 static_assert(!std::is_nothrow_destructible<const volatile T>::value, "");
38 #if TEST_STD_VER > 14
39 static_assert(!std::is_nothrow_destructible_v<T>, "");
40 static_assert(!std::is_nothrow_destructible_v<const T>, "");
41 static_assert(!std::is_nothrow_destructible_v<volatile T>, "");
42 static_assert(!std::is_nothrow_destructible_v<const volatile T>, "");
43 #endif
47 struct PublicDestructor { public: ~PublicDestructor() {}};
48 struct ProtectedDestructor { protected: ~ProtectedDestructor() {}};
49 struct PrivateDestructor { private: ~PrivateDestructor() {}};
51 struct VirtualPublicDestructor { public: virtual ~VirtualPublicDestructor() {}};
52 struct VirtualProtectedDestructor { protected: virtual ~VirtualProtectedDestructor() {}};
53 struct VirtualPrivateDestructor { private: virtual ~VirtualPrivateDestructor() {}};
55 struct PurePublicDestructor { public: virtual ~PurePublicDestructor() = 0; };
56 struct PureProtectedDestructor { protected: virtual ~PureProtectedDestructor() = 0; };
57 struct PurePrivateDestructor { private: virtual ~PurePrivateDestructor() = 0; };
59 class Empty
64 union Union {};
66 struct bit_zero
68 int : 0;
71 class Abstract
73 virtual void foo() = 0;
77 int main(int, char**)
79 test_is_not_nothrow_destructible<void>();
80 test_is_not_nothrow_destructible<char[]>();
81 test_is_not_nothrow_destructible<char[][3]>();
83 test_is_nothrow_destructible<int&>();
84 test_is_nothrow_destructible<int>();
85 test_is_nothrow_destructible<double>();
86 test_is_nothrow_destructible<int*>();
87 test_is_nothrow_destructible<const int*>();
88 test_is_nothrow_destructible<char[3]>();
90 #if TEST_STD_VER >= 11
91 // requires noexcept. These are all destructible.
92 test_is_nothrow_destructible<PublicDestructor>();
93 test_is_nothrow_destructible<VirtualPublicDestructor>();
94 test_is_nothrow_destructible<PurePublicDestructor>();
95 test_is_nothrow_destructible<bit_zero>();
96 test_is_nothrow_destructible<Abstract>();
97 test_is_nothrow_destructible<Empty>();
98 test_is_nothrow_destructible<Union>();
99 #endif
100 // requires access control
101 test_is_not_nothrow_destructible<ProtectedDestructor>();
102 test_is_not_nothrow_destructible<PrivateDestructor>();
103 test_is_not_nothrow_destructible<VirtualProtectedDestructor>();
104 test_is_not_nothrow_destructible<VirtualPrivateDestructor>();
105 test_is_not_nothrow_destructible<PureProtectedDestructor>();
106 test_is_not_nothrow_destructible<PurePrivateDestructor>();
109 return 0;