-
Notifications
You must be signed in to change notification settings - Fork 2.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Workaround for incompatibility between libstdc++ consteval-based std::is_constant_evaluated() implementation and clang-14 #3281
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the PR.
include/fmt/core.h
Outdated
@@ -329,7 +329,14 @@ template <typename... T> 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 incompatible between libstdc++ consteval based |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
incompatible -> incompatibility
consteval based -> consteval-based
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fixed
include/fmt/core.h
Outdated
// 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 >= 14 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should this be FMT_CLANG_VERSION == 14
per #3247 (comment)?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should be
(FMT_CLANG_VERSION >= 1400 && FMT_CLANG_VERSION < 1500)
This is my mistake, I forgot about the minor version part (00):
Line 23 in f89cd27
# define FMT_CLANG_VERSION (__clang_major__ * 100 + __clang_minor__) |
Since bug is fixed in clang-15, I added a second condition.
…:is_constant_evaluated() implementation and clang-14 Signed-off-by: Vladislav Shchapov <vladislav@shchapov.ru>
Thank you! |
Fix for issue #3247
cc @m5k8