mirror of
https://github.com/fmtlib/fmt.git
synced 2025-01-12 06:37:28 +00:00
691a7a91a1
* Add a _lot_ more warnings to FMT_PEDANTIC Fix these warnings * Add more compilers to CI Fix (some) of the compiler errors with them * Enable -Werror on CI Increase warning level on MSVC when compiling with FMT_PEDANTIC * Add VS 2013 and 2015 to Appveyor * Fix Appveyor tests Formatting * Implement requested changes Fix some of the MSVC warnings Implement C++11 integer_sequence * Reintroduce appveyor-build.py * Remove ranges-test from tests * Remove (some) explicit warning suppressions Fix C++ standard setting in CI * Remove (some) explicit warning suppressions Fix C++ standard setting in CI * Fix test builds with C++11 * Enable pedantic warnings on tests * Fix warnings from edits to master * Cleanups * Add C++11 support to ranges.h Re-enable ranges-test Fix a Visual Studio error about function not returning a value in printf.h Fix a bug in .travis.yml
98 lines
2.7 KiB
CMake
98 lines
2.7 KiB
CMake
# C++14 feature support detection
|
|
|
|
include(CheckCXXSourceCompiles)
|
|
include(CheckCXXCompilerFlag)
|
|
|
|
if (NOT CMAKE_CXX_STANDARD)
|
|
set(CMAKE_CXX_STANDARD 11)
|
|
endif()
|
|
message(STATUS "CXX_STANDARD: ${CMAKE_CXX_STANDARD}")
|
|
|
|
if (CMAKE_CXX_STANDARD EQUAL 20)
|
|
check_cxx_compiler_flag(-std=c++20 has_std_20_flag)
|
|
check_cxx_compiler_flag(-std=c++2a has_std_2a_flag)
|
|
|
|
if (has_std_20_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++20)
|
|
elseif (has_std_2a_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++2a)
|
|
endif ()
|
|
elseif (CMAKE_CXX_STANDARD EQUAL 17)
|
|
check_cxx_compiler_flag(-std=c++17 has_std_17_flag)
|
|
check_cxx_compiler_flag(-std=c++1z has_std_1z_flag)
|
|
|
|
if (has_std_17_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++17)
|
|
elseif (has_std_1z_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++1z)
|
|
endif ()
|
|
elseif (CMAKE_CXX_STANDARD EQUAL 14)
|
|
check_cxx_compiler_flag(-std=c++14 has_std_14_flag)
|
|
check_cxx_compiler_flag(-std=c++1y has_std_1y_flag)
|
|
|
|
if (has_std_14_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++14)
|
|
elseif (has_std_1y_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++1y)
|
|
endif ()
|
|
elseif (CMAKE_CXX_STANDARD EQUAL 11)
|
|
check_cxx_compiler_flag(-std=c++11 has_std_11_flag)
|
|
check_cxx_compiler_flag(-std=c++0x has_std_0x_flag)
|
|
|
|
if (has_std_11_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++11)
|
|
elseif (has_std_0x_flag)
|
|
set(CXX_STANDARD_FLAG -std=c++0x)
|
|
endif ()
|
|
endif ()
|
|
|
|
set(CMAKE_REQUIRED_FLAGS ${CXX_STANDARD_FLAG})
|
|
|
|
# Check if variadic templates are working and not affected by GCC bug 39653:
|
|
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=39653
|
|
check_cxx_source_compiles("
|
|
template <class T, class ...Types>
|
|
struct S { typedef typename S<Types...>::type type; };
|
|
int main() {}" SUPPORTS_VARIADIC_TEMPLATES)
|
|
if (NOT SUPPORTS_VARIADIC_TEMPLATES)
|
|
set (SUPPORTS_VARIADIC_TEMPLATES OFF)
|
|
endif ()
|
|
|
|
# Check if initializer lists are supported.
|
|
check_cxx_source_compiles("
|
|
#include <initializer_list>
|
|
int main() {}" SUPPORTS_INITIALIZER_LIST)
|
|
if (NOT SUPPORTS_INITIALIZER_LIST)
|
|
set (SUPPORTS_INITIALIZER_LIST OFF)
|
|
endif ()
|
|
|
|
# Check if enum bases are available
|
|
check_cxx_source_compiles("
|
|
enum C : char {A};
|
|
int main() {}"
|
|
SUPPORTS_ENUM_BASE)
|
|
if (NOT SUPPORTS_ENUM_BASE)
|
|
set (SUPPORTS_ENUM_BASE OFF)
|
|
endif ()
|
|
|
|
# Check if type traits are available
|
|
check_cxx_source_compiles("
|
|
#include <type_traits>
|
|
class C { void operator=(const C&); };
|
|
int main() { static_assert(!std::is_copy_assignable<C>::value, \"\"); }"
|
|
SUPPORTS_TYPE_TRAITS)
|
|
if (NOT SUPPORTS_TYPE_TRAITS)
|
|
set (SUPPORTS_TYPE_TRAITS OFF)
|
|
endif ()
|
|
|
|
# Check if user-defined literals are available
|
|
check_cxx_source_compiles("
|
|
void operator\"\" _udl(long double);
|
|
int main() {}"
|
|
SUPPORTS_USER_DEFINED_LITERALS)
|
|
if (NOT SUPPORTS_USER_DEFINED_LITERALS)
|
|
set (SUPPORTS_USER_DEFINED_LITERALS OFF)
|
|
endif ()
|
|
|
|
set(CMAKE_REQUIRED_FLAGS )
|