X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/417ed3b671abe3a71fa4106d23d0a432084cc207..3973bb7a4ee47daf6a4a682f18d18b409c5d6de8:/FindSimGrid.cmake diff --git a/FindSimGrid.cmake b/FindSimGrid.cmake index 209d709941..6f9d9e19cf 100644 --- a/FindSimGrid.cmake +++ b/FindSimGrid.cmake @@ -37,7 +37,7 @@ # (code to use with SimGrid v3.19+) # #endif # -# Since SimGrid header files require C++14, so we set CMAKE_CXX_STANDARD to 14. +# Since SimGrid header files require C++17, so we set CMAKE_CXX_STANDARD to 17. # Change this variable in your own file if you need a later standard. # @@ -50,7 +50,7 @@ cmake_minimum_required(VERSION 2.8.12) -set(CMAKE_CXX_STANDARD 14) +set(CMAKE_CXX_STANDARD 17) set(CMAKE_CXX_STANDARD_REQUIRED ON) find_path(SimGrid_INCLUDE_DIR @@ -109,26 +109,23 @@ if (SimGrid_FOUND) INTERFACE_COMPILE_FEATURES cxx_alias_templates IMPORTED_LOCATION ${SimGrid_LIBRARY} ) - # We need C++14, so check for it just in case the user removed it since compiling SimGrid + # We need C++17, so check for it just in case the user removed it since compiling SimGrid if (NOT CMAKE_VERSION VERSION_LESS 3.8) - # 3.8+ allows us to simply require C++14 (or higher) - set_property(TARGET SimGrid::SimGrid PROPERTY INTERFACE_COMPILE_FEATURES cxx_std_14) - elseif (NOT CMAKE_VERSION VERSION_LESS 3.1) - # 3.1+ is similar but for certain features. We pick just one - set_property(TARGET SimGrid::SimGrid PROPERTY INTERFACE_COMPILE_FEATURES cxx_attribute_deprecated) + # 3.8+ allows us to simply require C++17 (or higher) + set_property(TARGET SimGrid::SimGrid PROPERTY INTERFACE_COMPILE_FEATURES cxx_std_17) else () - # Old CMake can't do much. Just check the CXX_FLAGS and inform the user when a C++14 feature does not work + # Old CMake can't do much. Just check the CXX_FLAGS and inform the user when a C++17 feature does not work include(CheckCXXSourceCompiles) set(CMAKE_REQUIRED_FLAGS "${CMAKE_CXX_FLAGS}") check_cxx_source_compiles(" -#if __cplusplus < 201402L +#if __cplusplus < 201703L #error #else int main(){} #endif -" _SIMGRID_CXX14_ENABLED) - if (NOT _SIMGRID_CXX14_ENABLED) - message(WARNING "C++14 is required to use SimGrid. Enable it with e.g. -std=c++14") +" _SIMGRID_CXX17_ENABLED) + if (NOT _SIMGRID_CXX17_ENABLED) + message(WARNING "C++17 is required to use SimGrid. Enable it with e.g. -std=c++17") endif () unset(_SIMGRID_CXX14_ENABLED CACHE) endif ()