//===----------------------------------------------------------------------===//
//
// 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
// <type_traits>
// constexpr bool is_constant_evaluated() noexcept; // C++20
#include <type_traits>
#include <cassert>
#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 <bool> 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<std::is_constant_evaluated()>, InTemplate<true>);
static int local_static = std::is_constant_evaluated() ? 42 : -1;
assert(local_static == 42);
}
return 0;
}