//===----------------------------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // UNSUPPORTED: c++03, c++11, c++14, c++17 // // constexpr bool is_constant_evaluated() noexcept; // C++20 #include #include #include "test_macros.h" #ifndef __cpp_lib_is_constant_evaluated #if TEST_HAS_BUILTIN(__builtin_is_constant_evaluated) # error __cpp_lib_is_constant_evaluated should be defined #endif #endif // Disable the tautological constant evaluation warnings for this test, // because it's explicitly testing those cases. TEST_CLANG_DIAGNOSTIC_IGNORED("-Wconstant-evaluated") TEST_MSVC_DIAGNOSTIC_IGNORED(5063) template struct InTemplate {}; int main(int, char**) { // Test the signature { ASSERT_SAME_TYPE(decltype(std::is_constant_evaluated()), bool); ASSERT_NOEXCEPT(std::is_constant_evaluated()); constexpr bool p = std::is_constant_evaluated(); assert(p); } // Test the return value of the builtin for basic sanity only. It's the // compiler's job to test the builtin for correctness. { static_assert(std::is_constant_evaluated(), ""); bool p = std::is_constant_evaluated(); assert(!p); ASSERT_SAME_TYPE(InTemplate, InTemplate); static int local_static = std::is_constant_evaluated() ? 42 : -1; assert(local_static == 42); } return 0; }