Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 1 | // -*- C++ -*- |
| 2 | //===---------------------------- test_macros.h ---------------------------===// |
| 3 | // |
| 4 | // The LLVM Compiler Infrastructure |
| 5 | // |
| 6 | // This file is dual licensed under the MIT and the University of Illinois Open |
| 7 | // Source Licenses. See LICENSE.TXT for details. |
| 8 | // |
| 9 | //===----------------------------------------------------------------------===// |
| 10 | |
| 11 | #ifndef SUPPORT_TEST_MACROS_HPP |
| 12 | #define SUPPORT_TEST_MACROS_HPP |
| 13 | |
Eric Fiselier | 1f4231f | 2016-04-28 22:28:23 +0000 | [diff] [blame] | 14 | #include <ciso646> // Get STL specific macros like _LIBCPP_VERSION |
| 15 | |
Eric Fiselier | 1e33f12 | 2017-01-14 04:27:58 +0000 | [diff] [blame] | 16 | #if defined(__GNUC__) |
| 17 | #pragma GCC diagnostic push |
| 18 | #pragma GCC diagnostic ignored "-Wvariadic-macros" |
| 19 | #endif |
| 20 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 21 | #define TEST_CONCAT1(X, Y) X##Y |
| 22 | #define TEST_CONCAT(X, Y) TEST_CONCAT1(X, Y) |
| 23 | |
Eric Fiselier | 3461dbc | 2015-07-31 02:24:58 +0000 | [diff] [blame] | 24 | #ifdef __has_feature |
| 25 | #define TEST_HAS_FEATURE(X) __has_feature(X) |
| 26 | #else |
| 27 | #define TEST_HAS_FEATURE(X) 0 |
| 28 | #endif |
| 29 | |
Eric Fiselier | 015839a | 2016-10-04 21:25:51 +0000 | [diff] [blame] | 30 | #ifdef __has_include |
| 31 | #define TEST_HAS_INCLUDE(X) __has_include(X) |
| 32 | #else |
| 33 | #define TEST_HAS_INCLUDE(X) 0 |
| 34 | #endif |
| 35 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 36 | #ifdef __has_extension |
| 37 | #define TEST_HAS_EXTENSION(X) __has_extension(X) |
| 38 | #else |
| 39 | #define TEST_HAS_EXTENSION(X) 0 |
| 40 | #endif |
| 41 | |
Eric Fiselier | fff5ec0 | 2015-12-09 22:03:06 +0000 | [diff] [blame] | 42 | #ifdef __has_builtin |
| 43 | #define TEST_HAS_BUILTIN(X) __has_builtin(X) |
| 44 | #else |
| 45 | #define TEST_HAS_BUILTIN(X) 0 |
| 46 | #endif |
Eric Fiselier | 324506b | 2016-08-11 03:13:11 +0000 | [diff] [blame] | 47 | #ifdef __is_identifier |
| 48 | // '__is_identifier' returns '0' if '__x' is a reserved identifier provided by |
| 49 | // the compiler and '1' otherwise. |
| 50 | #define TEST_HAS_BUILTIN_IDENTIFIER(X) !__is_identifier(X) |
| 51 | #else |
| 52 | #define TEST_HAS_BUILTIN_IDENTIFIER(X) 0 |
| 53 | #endif |
Eric Fiselier | fff5ec0 | 2015-12-09 22:03:06 +0000 | [diff] [blame] | 54 | |
Casey Carter | 768a93f | 2017-05-10 19:10:49 +0000 | [diff] [blame] | 55 | #if defined(__EDG__) |
| 56 | # define TEST_COMPILER_EDG |
| 57 | #elif defined(__clang__) |
| 58 | # define TEST_COMPILER_CLANG |
Eric Fiselier | 9506f14 | 2017-03-22 22:41:41 +0000 | [diff] [blame] | 59 | # if defined(__apple_build_version__) |
Casey Carter | 768a93f | 2017-05-10 19:10:49 +0000 | [diff] [blame] | 60 | # define TEST_COMPILER_APPLE_CLANG |
Eric Fiselier | 9506f14 | 2017-03-22 22:41:41 +0000 | [diff] [blame] | 61 | # endif |
| 62 | #elif defined(_MSC_VER) |
| 63 | # define TEST_COMPILER_C1XX |
| 64 | #elif defined(__GNUC__) |
| 65 | # define TEST_COMPILER_GCC |
| 66 | #endif |
| 67 | |
Eric Fiselier | 7f1b098 | 2016-07-20 22:53:21 +0000 | [diff] [blame] | 68 | #if defined(__apple_build_version__) |
| 69 | #define TEST_APPLE_CLANG_VER (__clang_major__ * 100) + __clang_minor__ |
| 70 | #elif defined(__clang_major__) |
| 71 | #define TEST_CLANG_VER (__clang_major__ * 100) + __clang_minor__ |
| 72 | #elif defined(__GNUC__) |
| 73 | #define TEST_GCC_VER (__GNUC__ * 100 + __GNUC_MINOR__) |
| 74 | #endif |
| 75 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 76 | /* Make a nice name for the standard version */ |
Eric Fiselier | f2f2a63 | 2016-06-14 21:31:42 +0000 | [diff] [blame] | 77 | #ifndef TEST_STD_VER |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 78 | #if __cplusplus <= 199711L |
| 79 | # define TEST_STD_VER 3 |
| 80 | #elif __cplusplus <= 201103L |
| 81 | # define TEST_STD_VER 11 |
| 82 | #elif __cplusplus <= 201402L |
| 83 | # define TEST_STD_VER 14 |
| 84 | #else |
Eric Fiselier | 68436a9 | 2016-06-27 01:02:43 +0000 | [diff] [blame] | 85 | # define TEST_STD_VER 16 // current year; greater than current standard |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 86 | #endif |
Eric Fiselier | f2f2a63 | 2016-06-14 21:31:42 +0000 | [diff] [blame] | 87 | #endif |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 88 | |
Eric Fiselier | f49fe8f | 2016-09-04 00:48:54 +0000 | [diff] [blame] | 89 | // Attempt to deduce GCC version |
Eric Fiselier | 015839a | 2016-10-04 21:25:51 +0000 | [diff] [blame] | 90 | #if defined(_LIBCPP_VERSION) && TEST_HAS_INCLUDE(<features.h>) |
Eric Fiselier | f49fe8f | 2016-09-04 00:48:54 +0000 | [diff] [blame] | 91 | #include <features.h> |
| 92 | #define TEST_HAS_GLIBC |
| 93 | #define TEST_GLIBC_PREREQ(major, minor) __GLIBC_PREREQ(major, minor) |
| 94 | #endif |
| 95 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 96 | /* Features that were introduced in C++14 */ |
| 97 | #if TEST_STD_VER >= 14 |
| 98 | #define TEST_HAS_EXTENDED_CONSTEXPR |
| 99 | #define TEST_HAS_VARIABLE_TEMPLATES |
| 100 | #endif |
| 101 | |
| 102 | /* Features that were introduced after C++14 */ |
| 103 | #if TEST_STD_VER > 14 |
| 104 | #endif |
| 105 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 106 | #if TEST_STD_VER >= 11 |
Eric Fiselier | 3ca4566 | 2016-12-11 02:47:36 +0000 | [diff] [blame] | 107 | #define TEST_ALIGNOF(...) alignof(__VA_ARGS__) |
| 108 | #define TEST_ALIGNAS(...) alignas(__VA_ARGS__) |
Eric Fiselier | 749adeb | 2015-08-19 17:21:46 +0000 | [diff] [blame] | 109 | #define TEST_CONSTEXPR constexpr |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 110 | #define TEST_NOEXCEPT noexcept |
Eric Fiselier | 859f80b | 2017-04-13 10:17:23 +0000 | [diff] [blame] | 111 | #define TEST_NOEXCEPT_FALSE noexcept(false) |
Eric Fiselier | 883cc25d | 2016-10-12 09:31:26 +0000 | [diff] [blame] | 112 | #define TEST_NOEXCEPT_COND(...) noexcept(__VA_ARGS__) |
Eric Fiselier | b530a25 | 2016-04-22 10:33:56 +0000 | [diff] [blame] | 113 | # if TEST_STD_VER >= 14 |
| 114 | # define TEST_CONSTEXPR_CXX14 constexpr |
| 115 | # else |
| 116 | # define TEST_CONSTEXPR_CXX14 |
| 117 | # endif |
Eric Fiselier | 3ca4566 | 2016-12-11 02:47:36 +0000 | [diff] [blame] | 118 | # if TEST_STD_VER > 14 |
| 119 | # define TEST_THROW_SPEC(...) |
| 120 | # else |
| 121 | # define TEST_THROW_SPEC(...) throw(__VA_ARGS__) |
| 122 | # endif |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 123 | #else |
Eric Fiselier | 3ca4566 | 2016-12-11 02:47:36 +0000 | [diff] [blame] | 124 | #define TEST_ALIGNOF(...) __alignof(__VA_ARGS__) |
| 125 | #define TEST_ALIGNAS(...) __attribute__((__aligned__(__VA_ARGS__))) |
Eric Fiselier | 749adeb | 2015-08-19 17:21:46 +0000 | [diff] [blame] | 126 | #define TEST_CONSTEXPR |
Eric Fiselier | b530a25 | 2016-04-22 10:33:56 +0000 | [diff] [blame] | 127 | #define TEST_CONSTEXPR_CXX14 |
Eric Fiselier | d2c71a9 | 2016-10-12 11:20:27 +0000 | [diff] [blame] | 128 | #define TEST_NOEXCEPT throw() |
Eric Fiselier | 859f80b | 2017-04-13 10:17:23 +0000 | [diff] [blame] | 129 | #define TEST_NOEXCEPT_FALSE |
Eric Fiselier | 883cc25d | 2016-10-12 09:31:26 +0000 | [diff] [blame] | 130 | #define TEST_NOEXCEPT_COND(...) |
Eric Fiselier | 3ca4566 | 2016-12-11 02:47:36 +0000 | [diff] [blame] | 131 | #define TEST_THROW_SPEC(...) throw(__VA_ARGS__) |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 132 | #endif |
| 133 | |
Eric Fiselier | 6ce45e0 | 2016-10-12 10:19:48 +0000 | [diff] [blame] | 134 | #define TEST_ALIGNAS_TYPE(...) TEST_ALIGNAS(TEST_ALIGNOF(__VA_ARGS__)) |
| 135 | |
Eric Fiselier | 19d4483 | 2016-06-22 05:40:17 +0000 | [diff] [blame] | 136 | #if !TEST_HAS_FEATURE(cxx_rtti) && !defined(__cpp_rtti) \ |
Eric Fiselier | 94713d1 | 2016-06-22 05:33:52 +0000 | [diff] [blame] | 137 | && !defined(__GXX_RTTI) |
Eric Fiselier | 3461dbc | 2015-07-31 02:24:58 +0000 | [diff] [blame] | 138 | #define TEST_HAS_NO_RTTI |
| 139 | #endif |
| 140 | |
Eric Fiselier | 19d4483 | 2016-06-22 05:40:17 +0000 | [diff] [blame] | 141 | #if !TEST_HAS_FEATURE(cxx_exceptions) && !defined(__cpp_exceptions) \ |
Eric Fiselier | 94713d1 | 2016-06-22 05:33:52 +0000 | [diff] [blame] | 142 | && !defined(__EXCEPTIONS) |
Eric Fiselier | 3461dbc | 2015-07-31 02:24:58 +0000 | [diff] [blame] | 143 | #define TEST_HAS_NO_EXCEPTIONS |
| 144 | #endif |
| 145 | |
Eric Fiselier | 7362982 | 2015-10-01 08:34:37 +0000 | [diff] [blame] | 146 | #if TEST_HAS_FEATURE(address_sanitizer) || TEST_HAS_FEATURE(memory_sanitizer) || \ |
| 147 | TEST_HAS_FEATURE(thread_sanitizer) |
| 148 | #define TEST_HAS_SANITIZERS |
| 149 | #endif |
| 150 | |
Eric Fiselier | 3740071 | 2016-06-26 19:42:59 +0000 | [diff] [blame] | 151 | #if defined(_LIBCPP_NORETURN) |
| 152 | #define TEST_NORETURN _LIBCPP_NORETURN |
| 153 | #else |
| 154 | #define TEST_NORETURN [[noreturn]] |
| 155 | #endif |
| 156 | |
Eric Fiselier | 3ca9185 | 2017-05-25 04:36:24 +0000 | [diff] [blame^] | 157 | #if defined(_LIBCPP_SAFE_STATIC) |
| 158 | #define TEST_SAFE_STATIC _LIBCPP_SAFE_STATIC |
| 159 | #else |
| 160 | #define TEST_SAFE_STATIC |
| 161 | #endif |
| 162 | |
Marshall Clow | d832316 | 2017-03-23 06:20:18 +0000 | [diff] [blame] | 163 | #if TEST_STD_VER < 11 |
| 164 | #define ASSERT_NOEXCEPT(...) |
| 165 | #define ASSERT_NOT_NOEXCEPT(...) |
| 166 | #else |
Eric Fiselier | c797958 | 2016-06-17 19:46:40 +0000 | [diff] [blame] | 167 | #define ASSERT_NOEXCEPT(...) \ |
| 168 | static_assert(noexcept(__VA_ARGS__), "Operation must be noexcept") |
| 169 | |
| 170 | #define ASSERT_NOT_NOEXCEPT(...) \ |
| 171 | static_assert(!noexcept(__VA_ARGS__), "Operation must NOT be noexcept") |
Marshall Clow | d832316 | 2017-03-23 06:20:18 +0000 | [diff] [blame] | 172 | #endif |
Eric Fiselier | c797958 | 2016-06-17 19:46:40 +0000 | [diff] [blame] | 173 | |
Stephan T. Lavavej | 8a597d6 | 2016-12-09 19:53:08 +0000 | [diff] [blame] | 174 | /* Macros for testing libc++ specific behavior and extensions */ |
| 175 | #if defined(_LIBCPP_VERSION) |
| 176 | #define LIBCPP_ASSERT(...) assert(__VA_ARGS__) |
| 177 | #define LIBCPP_STATIC_ASSERT(...) static_assert(__VA_ARGS__) |
| 178 | #define LIBCPP_ASSERT_NOEXCEPT(...) ASSERT_NOEXCEPT(__VA_ARGS__) |
| 179 | #define LIBCPP_ASSERT_NOT_NOEXCEPT(...) ASSERT_NOT_NOEXCEPT(__VA_ARGS__) |
| 180 | #define LIBCPP_ONLY(...) __VA_ARGS__ |
| 181 | #else |
| 182 | #define LIBCPP_ASSERT(...) ((void)0) |
| 183 | #define LIBCPP_STATIC_ASSERT(...) ((void)0) |
| 184 | #define LIBCPP_ASSERT_NOEXCEPT(...) ((void)0) |
| 185 | #define LIBCPP_ASSERT_NOT_NOEXCEPT(...) ((void)0) |
| 186 | #define LIBCPP_ONLY(...) ((void)0) |
| 187 | #endif |
| 188 | |
Eric Fiselier | c797958 | 2016-06-17 19:46:40 +0000 | [diff] [blame] | 189 | namespace test_macros_detail { |
| 190 | template <class T, class U> |
| 191 | struct is_same { enum { value = 0};} ; |
| 192 | template <class T> |
| 193 | struct is_same<T, T> { enum {value = 1}; }; |
| 194 | } // namespace test_macros_detail |
| 195 | |
| 196 | #define ASSERT_SAME_TYPE(...) \ |
Eric Fiselier | 34e38ca | 2017-04-12 22:43:49 +0000 | [diff] [blame] | 197 | static_assert((test_macros_detail::is_same<__VA_ARGS__>::value), \ |
Eric Fiselier | c797958 | 2016-06-17 19:46:40 +0000 | [diff] [blame] | 198 | "Types differ uexpectedly") |
| 199 | |
Eric Fiselier | f188910 | 2016-10-01 10:34:13 +0000 | [diff] [blame] | 200 | #ifndef TEST_HAS_NO_EXCEPTIONS |
| 201 | #define TEST_THROW(...) throw __VA_ARGS__ |
| 202 | #else |
| 203 | #if defined(__GNUC__) |
| 204 | #define TEST_THROW(...) __builtin_abort() |
| 205 | #else |
| 206 | #include <stdlib.h> |
| 207 | #define TEST_THROW(...) ::abort() |
| 208 | #endif |
| 209 | #endif |
| 210 | |
Eric Fiselier | 4cdd915 | 2017-02-08 00:10:10 +0000 | [diff] [blame] | 211 | #if defined(__GNUC__) || defined(__clang__) |
| 212 | template <class Tp> |
| 213 | inline void DoNotOptimize(Tp const& value) { |
| 214 | asm volatile("" : : "g"(value) : "memory"); |
| 215 | } |
| 216 | #else |
Eric Fiselier | d2001da | 2017-03-11 00:07:08 +0000 | [diff] [blame] | 217 | #include <intrin.h> |
Eric Fiselier | 4cdd915 | 2017-02-08 00:10:10 +0000 | [diff] [blame] | 218 | template <class Tp> |
Eric Fiselier | d2001da | 2017-03-11 00:07:08 +0000 | [diff] [blame] | 219 | inline void DoNotOptimize(Tp const& value) { |
Casey Carter | d50571b | 2017-05-04 15:54:09 +0000 | [diff] [blame] | 220 | const volatile void* volatile unused = __builtin_addressof(value); |
| 221 | static_cast<void>(unused); |
Eric Fiselier | d2001da | 2017-03-11 00:07:08 +0000 | [diff] [blame] | 222 | _ReadWriteBarrier(); |
Eric Fiselier | 4cdd915 | 2017-02-08 00:10:10 +0000 | [diff] [blame] | 223 | } |
| 224 | #endif |
| 225 | |
Eric Fiselier | 1e33f12 | 2017-01-14 04:27:58 +0000 | [diff] [blame] | 226 | #if defined(__GNUC__) |
| 227 | #pragma GCC diagnostic pop |
| 228 | #endif |
| 229 | |
Eric Fiselier | 6871bcb | 2015-05-27 00:28:30 +0000 | [diff] [blame] | 230 | #endif // SUPPORT_TEST_MACROS_HPP |