From 22ddd4b9898cc5786e133eacbf824afa0d48b334 Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Wed, 19 Jun 2019 07:46:09 -0700 Subject: [PATCH] Simplify feature checks --- include/fmt/format.h | 32 +++++++------------------------- include/fmt/prepare.h | 10 ++++------ 2 files changed, 11 insertions(+), 31 deletions(-) diff --git a/include/fmt/format.h b/include/fmt/format.h index 0f4f59d3..41f0112f 100644 --- a/include/fmt/format.h +++ b/include/fmt/format.h @@ -60,20 +60,6 @@ # define FMT_CUDA_VERSION 0 #endif -#ifdef __GNUC_LIBSTD__ -# define FMT_GNUC_LIBSTD_VERSION \ - (__GNUC_LIBSTD__ * 100 + __GNUC_LIBSTD_MINOR__) -#endif - -// Check whether we can use unrestricted unions and use struct if not. -#ifndef FMT_UNRESTRICTED_UNION -# if FMT_MSC_VER >= 1900 || FMT_GCC_VERSION >= 406 || FMT_CLANG_VERSION >= 303 -# define FMT_UNRESTRICTED_UNION union -# else -# define FMT_UNRESTRICTED_UNION struct -# endif -#endif - #ifdef __has_builtin # define FMT_HAS_BUILTIN(x) __has_builtin(x) #else @@ -142,14 +128,11 @@ FMT_END_NAMESPACE // __builtin_clz is broken in clang with Microsoft CodeGen: // https://github.com/fmtlib/fmt/issues/519 -#ifndef _MSC_VER -# if FMT_GCC_VERSION || FMT_HAS_BUILTIN(__builtin_clz) -# define FMT_BUILTIN_CLZ(n) __builtin_clz(n) -# endif - -# if FMT_GCC_VERSION || FMT_HAS_BUILTIN(__builtin_clzll) -# define FMT_BUILTIN_CLZLL(n) __builtin_clzll(n) -# endif +#if (FMT_GCC_VERSION || FMT_HAS_BUILTIN(__builtin_clz)) && !FMT_MSC_VER +# define FMT_BUILTIN_CLZ(n) __builtin_clz(n) +#endif +#if (FMT_GCC_VERSION || FMT_HAS_BUILTIN(__builtin_clzll)) && !FMT_MSC_VER +# define FMT_BUILTIN_CLZLL(n) __builtin_clzll(n) #endif // Some compilers masquerade as both MSVC and GCC-likes or otherwise support @@ -1727,15 +1710,14 @@ template struct arg_ref { } Kind kind; - FMT_UNRESTRICTED_UNION value { + union value { FMT_CONSTEXPR value() : index(0u) {} FMT_CONSTEXPR value(unsigned id) : index(id) {} FMT_CONSTEXPR value(string_view_metadata n) : name(n) {} unsigned index; string_view_metadata name; - } - val; + } val; }; // Format specifiers with width and precision resolved at formatting rather diff --git a/include/fmt/prepare.h b/include/fmt/prepare.h index 791858af..5a83ee13 100644 --- a/include/fmt/prepare.h +++ b/include/fmt/prepare.h @@ -40,7 +40,7 @@ template struct format_part { which_arg_id which; - FMT_UNRESTRICTED_UNION value { + union value { FMT_CONSTEXPR value() : index(0u) {} FMT_CONSTEXPR value(unsigned id) : index(id) {} FMT_CONSTEXPR value(internal::string_view_metadata id) @@ -48,8 +48,7 @@ template struct format_part { unsigned index; internal::string_view_metadata named_index; - } - val; + } val; }; struct specification { @@ -89,7 +88,7 @@ template struct format_part { which_value which; std::size_t end_of_argument_id; - FMT_UNRESTRICTED_UNION value { + union value { FMT_CONSTEXPR value() : arg_id(0u) {} FMT_CONSTEXPR value(unsigned id) : arg_id(id) {} FMT_CONSTEXPR value(named_argument_id named_id) @@ -100,8 +99,7 @@ template struct format_part { internal::string_view_metadata named_arg_id; internal::string_view_metadata text; specification spec; - } - val; + } val; }; namespace internal {