Skip to content

Commit

Permalink
Fix build when using clang-cl on Windows (#129)
Browse files Browse the repository at this point in the history
The Clang front-end provided with Visual Studio, `clang-cl.exe`, does
not support the `/Qspectre` or `/MP` compiler flags. This patch adds
logic to check that the `CMAKE_C_COMPILER_ID`/`CMAKE_CXX_COMPILER_ID`
variables are not `Clang` before appending the unsupported flags to
`CMAKE_C_FLAGS`/`CMAKE_CXX_FLAGS`.

Signed-off-by: Kenneth Benzie (Benie) <[email protected]>
  • Loading branch information
kbenzie authored Nov 30, 2023
1 parent ea5be99 commit b115569
Showing 1 changed file with 11 additions and 5 deletions.
16 changes: 11 additions & 5 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -81,9 +81,13 @@ if(MSVC)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /DYNAMICBASE")
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /DYNAMICBASE")
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} /guard:cf")
# enable Spectre Mitigation
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /Qspectre")
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /Qspectre")
# enable Spectre Mitigation, not supported by clang-cl
if(NOT CMAKE_CXX_COMPILER_ID STREQUAL Clang)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /Qspectre")
endif()
if(NOT CMAKE_C_COMPILER_ID STREQUAL Clang)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /Qspectre")
endif()
endif()

#CXX compiler support
Expand Down Expand Up @@ -111,8 +115,10 @@ if(MSVC)
# treat warnings as errors
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /WX /W3")

# enable multi-process compilation
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /MP")
# enable multi-process compilation, not supported by clang-cl
if(NOT CMAKE_CXX_COMPILER_ID STREQUAL Clang)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /MP")
endif()

# enable exceptions handling
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /EHsc")
Expand Down

0 comments on commit b115569

Please sign in to comment.