From a95142be97ea824be284e395b41b4acdf0358c83 Mon Sep 17 00:00:00 2001 From: Vladislav Shchapov Date: Sat, 21 Jan 2023 18:25:34 +0500 Subject: [PATCH] Workaround for incompatibility between libstdc++ consteval-based std::is_constant_evaluated() implementation and clang-14 Signed-off-by: Vladislav Shchapov --- include/fmt/core.h | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/include/fmt/core.h b/include/fmt/core.h index 59ba21d1bd1d..f7656da00f3d 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -329,7 +329,15 @@ template FMT_CONSTEXPR void ignore_unused(const T&...) {} constexpr FMT_INLINE auto is_constant_evaluated( bool default_value = false) noexcept -> bool { -#ifdef __cpp_lib_is_constant_evaluated +// Workaround for incompatibility between libstdc++ consteval-based +// std::is_constant_evaluated() implementation and clang-14. +// https://github.com/fmtlib/fmt/issues/3247 +#if FMT_CPLUSPLUS >= 202002L && defined(_GLIBCXX_RELEASE) && \ + _GLIBCXX_RELEASE >= 12 && \ + (FMT_CLANG_VERSION >= 1400 && FMT_CLANG_VERSION < 1500) + ignore_unused(default_value); + return __builtin_is_constant_evaluated(); +#elif defined(__cpp_lib_is_constant_evaluated) ignore_unused(default_value); return std::is_constant_evaluated(); #else