From ef9778a392fb6c9f49a13da55f7c5dcca8d2b5ed Mon Sep 17 00:00:00 2001 From: Samuel Nicholas Date: Thu, 5 Dec 2024 09:35:32 +1030 Subject: [PATCH] CMake: Enable using clang-cl on windows detect clang with MSVC frontend using CMAKE_CXX_COMPILER_FRONTEND_VARIANT --- CMakeLists.txt | 1 + cmake/common_compiler_flags.cmake | 29 +++++++++++++++++++++++++---- 2 files changed, 26 insertions(+), 4 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index fb59a999..fa2f1cc9 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -50,6 +50,7 @@ project( godot-cpp HOMEPAGE_URL "https://github.com/godotengine/godot-cpp" LANGUAGES CXX) +compiler_detection() godotcpp_generate() # Test Example diff --git a/cmake/common_compiler_flags.cmake b/cmake/common_compiler_flags.cmake index 4d1bdb95..ac3f4490 100644 --- a/cmake/common_compiler_flags.cmake +++ b/cmake/common_compiler_flags.cmake @@ -2,9 +2,10 @@ Common Compiler Flags --------------------- -This file contains a single function to configure platform agnostic compiler -flags like optimization levels, warnings, and features. For platform specific -flags look to each of the ``cmake/.cmake`` files. +This file contains host platform toolchain and target platform agnostic +configuration. It includes flags like optimization levels, warnings, and +features. For target platform specific flags look to each of the +``cmake/.cmake`` files. ]=======================================================================] @@ -24,6 +25,25 @@ set( GNU_GT_V11 "$,11>" ) set( GNU_LT_V11 "$,11>" ) set( GNU_GE_V12 "$,12>" ) +#[[ Check for clang-cl with MSVC frontend +The compiler is tested and set when the project command is called. +The variable CXX_COMPILER_FRONTEND_VARIANT was introduced in 3.14 +The generator expression $ wasn't introduced +until CMake 3.30 so we can't use it yet. + +So to support clang downloaded from llvm.org which uses the MSVC frontend +by default, we need to test for it. ]] +function( compiler_detection ) + if( ${CMAKE_CXX_COMPILER_ID} STREQUAL Clang ) + if( ${CMAKE_CXX_COMPILER_FRONTEND_VARIANT} STREQUAL MSVC ) + message( "Using clang-cl" ) + set( IS_CLANG "0" PARENT_SCOPE ) + set( IS_MSVC "1" PARENT_SCOPE ) + set( NOT_MSVC "0" PARENT_SCOPE ) + endif () + endif () +endfunction( ) + function( common_compiler_flags TARGET_NAME ) target_compile_features(${TARGET_NAME} @@ -60,7 +80,8 @@ function( common_compiler_flags TARGET_NAME ) # MSVC only $<${IS_MSVC}: - "/MP ${PROC_N}" + # /MP isn't valid for clang-cl with msvc frontend + $<$:/MP${PROC_N}> /W4 # Disable warnings which we don't plan to fix.