From 6eaa507473e175f7e5900e0fecb11279c444f7f2 Mon Sep 17 00:00:00 2001 From: Victor Zverovich Date: Wed, 18 Jul 2018 09:14:10 -0700 Subject: [PATCH] Fix global initialization issue (#807) --- include/fmt/core.h | 24 +++++++++++++++++------- 1 file changed, 17 insertions(+), 7 deletions(-) diff --git a/include/fmt/core.h b/include/fmt/core.h index b301b59e..f35bfc3a 100644 --- a/include/fmt/core.h +++ b/include/fmt/core.h @@ -54,7 +54,7 @@ # define FMT_MSC_VER 0 #endif -// Check if relaxed c++14 constexpr is supported. +// Check if relaxed C++14 constexpr is supported. // GCC doesn't allow throw in constexpr until version 6 (bug 67371). #ifndef FMT_USE_CONSTEXPR # define FMT_USE_CONSTEXPR \ @@ -69,6 +69,16 @@ # define FMT_CONSTEXPR_DECL #endif +#ifndef FMT_USE_CONSTEXPR11 +# define FMT_USE_CONSTEXPR11 \ + (FMT_MSC_VER >= 1900 || FMT_GCC_VERSION >= 406 || FMT_USE_CONSTEXPR) +#endif +#if FMT_USE_CONSTEXPR11 +# define FMT_CONSTEXPR11 constexpr +#else +# define FMT_CONSTEXPR11 +#endif + #ifndef FMT_OVERRIDE # if FMT_HAS_FEATURE(cxx_override) || \ (FMT_GCC_VERSION >= 408 && FMT_HAS_GXX_CXX11) || FMT_MSC_VER >= 1900 @@ -957,10 +967,10 @@ struct get_type { }; template -FMT_CONSTEXPR unsigned long long get_types() { return 0; } +FMT_CONSTEXPR11 unsigned long long get_types() { return 0; } template -FMT_CONSTEXPR unsigned long long get_types() { +FMT_CONSTEXPR11 unsigned long long get_types() { return get_type::value | (get_types() << 4); } @@ -1010,15 +1020,15 @@ class format_arg_store { friend class basic_format_args; - static FMT_CONSTEXPR long long get_types() { + static FMT_CONSTEXPR11 long long get_types() { return IS_PACKED ? static_cast(internal::get_types()) : -static_cast(NUM_ARGS); } public: -#if FMT_USE_CONSTEXPR - static constexpr long long TYPES = get_types(); +#if FMT_USE_CONSTEXPR11 + static FMT_CONSTEXPR11 long long TYPES = get_types(); #else static const long long TYPES; #endif @@ -1037,7 +1047,7 @@ class format_arg_store { #endif }; -#if !FMT_USE_CONSTEXPR +#if !FMT_USE_CONSTEXPR11 template const long long format_arg_store::TYPES = get_types(); #endif