summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--cmake/opentrack-platform.cmake24
1 files changed, 17 insertions, 7 deletions
diff --git a/cmake/opentrack-platform.cmake b/cmake/opentrack-platform.cmake
index 7e627e64..b977c5d8 100644
--- a/cmake/opentrack-platform.cmake
+++ b/cmake/opentrack-platform.cmake
@@ -62,13 +62,23 @@ if(MSVC)
add_definitions(-DNOMINMAX -D_CRT_SECURE_NO_WARNINGS -D_SCL_SECURE_NO_WARNINGS -D_NO_DEBUG_HEAP)
add_definitions(-D_ITERATOR_DEBUG_LEVEL=0)
add_definitions(-D_HAS_EXCEPTIONS=0)
- if(MSVC_VERSION GREATER 1909) # visual studio 2017
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -permissive- -diagnostics:caret")
- set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} -permissive- -diagnostics:caret")
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Zi")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Zi")
+
+ if(NOT CMAKE_COMPILER_IS_CLANG)
+ if(MSVC_VERSION GREATER 1909) # visual studio 2017
+ set(__stuff "-permissive- -diagnostics:caret -Qvec-report:1")
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${__stuff}")
+ set(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} ${__stuff}")
+ endif()
+
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std:c++latest")
+ else()
+ set(__stuff "-fms-compatibility -fms-compatibility-version=1911 -fms-extensions")
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${__stuff} -std:c++latest -Xclang -std=c++17")
+ set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${__stuff}")
endif()
- set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Zi -std:c++14")
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Zi")
if(opentrack-64bit)
set(ent "-HIGHENTROPYVA")
else()
@@ -116,8 +126,8 @@ if(APPLE)
endif()
if(NOT MSVC)
- set(CMAKE_CXX_STANDARD 14)
- set(CMAKE_CXX_STANDARD_DEFAULT 14)
+ set(CMAKE_CXX_STANDARD 17)
+ set(CMAKE_CXX_STANDARD_DEFAULT 17)
set(CMAKE_CXX_STANDARD_REQUIRED TRUE)
set(CMAKE_CXX_EXTENSIONS FALSE)
endif()