2017-09-28 08:46:47 -07:00
|
|
|
# C++14 feature support detection
|
2016-03-18 08:10:06 -07:00
|
|
|
|
2018-06-06 16:57:59 +03:00
|
|
|
include(CheckCXXSourceCompiles)
|
2016-01-29 13:03:47 +01:00
|
|
|
include(CheckCXXCompilerFlag)
|
|
|
|
|
2018-06-06 16:57:59 +03:00
|
|
|
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)
|
2016-01-29 13:03:47 +01:00
|
|
|
endif ()
|
2018-06-06 16:57:59 +03:00
|
|
|
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)
|
2016-01-29 13:03:47 +01:00
|
|
|
|
2018-06-06 16:57:59 +03:00
|
|
|
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 ()
|
2016-08-05 08:22:45 -07:00
|
|
|
endif ()
|
|
|
|
|
2018-06-06 16:57:59 +03:00
|
|
|
set(CMAKE_REQUIRED_FLAGS ${CXX_STANDARD_FLAG})
|
2016-01-29 13:03:47 +01:00
|
|
|
|
|
|
|
# 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)
|
2018-06-06 16:57:59 +03:00
|
|
|
if (NOT SUPPORTS_VARIADIC_TEMPLATES)
|
|
|
|
set (SUPPORTS_VARIADIC_TEMPLATES OFF)
|
|
|
|
endif ()
|
2016-01-29 13:03:47 +01:00
|
|
|
|
|
|
|
# Check if initializer lists are supported.
|
|
|
|
check_cxx_source_compiles("
|
|
|
|
#include <initializer_list>
|
|
|
|
int main() {}" SUPPORTS_INITIALIZER_LIST)
|
2018-06-06 16:57:59 +03:00
|
|
|
if (NOT SUPPORTS_INITIALIZER_LIST)
|
|
|
|
set (SUPPORTS_INITIALIZER_LIST OFF)
|
|
|
|
endif ()
|
2016-01-29 13:03:47 +01:00
|
|
|
|
|
|
|
# Check if enum bases are available
|
|
|
|
check_cxx_source_compiles("
|
|
|
|
enum C : char {A};
|
|
|
|
int main() {}"
|
|
|
|
SUPPORTS_ENUM_BASE)
|
2018-06-06 16:57:59 +03:00
|
|
|
if (NOT SUPPORTS_ENUM_BASE)
|
|
|
|
set (SUPPORTS_ENUM_BASE OFF)
|
|
|
|
endif ()
|
2016-01-29 13:03:47 +01:00
|
|
|
|
|
|
|
# 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)
|
2018-06-06 16:57:59 +03:00
|
|
|
if (NOT SUPPORTS_TYPE_TRAITS)
|
|
|
|
set (SUPPORTS_TYPE_TRAITS OFF)
|
|
|
|
endif ()
|
2016-05-02 23:51:37 +02:00
|
|
|
|
|
|
|
# Check if user-defined literals are available
|
|
|
|
check_cxx_source_compiles("
|
|
|
|
void operator\"\" _udl(long double);
|
|
|
|
int main() {}"
|
|
|
|
SUPPORTS_USER_DEFINED_LITERALS)
|
2018-06-06 16:57:59 +03:00
|
|
|
if (NOT SUPPORTS_USER_DEFINED_LITERALS)
|
|
|
|
set (SUPPORTS_USER_DEFINED_LITERALS OFF)
|
|
|
|
endif ()
|
2016-05-02 23:51:37 +02:00
|
|
|
|
2016-01-29 13:03:47 +01:00
|
|
|
set(CMAKE_REQUIRED_FLAGS )
|