X-Git-Url: https://git.reactos.org/?p=reactos.git;a=blobdiff_plain;f=toolchain-msvc.cmake;h=d1699c38d4a7afa838eb995068d47106ac8ea827;hp=cf675a5a975e6a342c359d4259d0e78b0d5f21c5;hb=e57f103d53d35b0093112f73102ca106a51830e7;hpb=eae27787e5ab44c69661672bc501ce6bba6ec4e5 diff --git a/toolchain-msvc.cmake b/toolchain-msvc.cmake index cf675a5a975..d1699c38d4a 100644 --- a/toolchain-msvc.cmake +++ b/toolchain-msvc.cmake @@ -3,18 +3,40 @@ if(NOT ARCH) set(ARCH i386) endif() +# Default to Debug for the build type +if(NOT DEFINED CMAKE_BUILD_TYPE) + set(CMAKE_BUILD_TYPE "Debug" CACHE STRING + "Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel.") +endif() + # the name of the target operating system set(CMAKE_SYSTEM_NAME Windows) set(CMAKE_SYSTEM_PROCESSOR i686) # which compilers to use for C and C++ -set(CMAKE_C_COMPILER cl) +# clang-cl gets detected as "Clang" instead of "MSVC" so we force it here +if(USE_CLANG_CL) + include(CMakeForceCompiler) + CMAKE_FORCE_C_COMPILER(clang-cl MSVC) + set(CMAKE_C_COMPILER_VERSION "16.00.40219.01") + if(ARCH STREQUAL "i386") + set(MSVC_C_ARCHITECTURE_ID "X86") + endif() + include(${CMAKE_ROOT}/Modules/CMakeClDeps.cmake) +else() + set(CMAKE_C_COMPILER cl) +endif() if(ARCH STREQUAL "arm") include(CMakeForceCompiler) CMAKE_FORCE_CXX_COMPILER(cl MSVC) else() -set(CMAKE_CXX_COMPILER cl) + if(USE_CLANG_CL) + include(CMakeForceCompiler) + CMAKE_FORCE_CXX_COMPILER(clang-cl MSVC) + else() + set(CMAKE_CXX_COMPILER cl) + endif() endif() set(CMAKE_MC_COMPILER mc) @@ -23,6 +45,8 @@ if(ARCH STREQUAL "amd64") set(CMAKE_ASM_COMPILER ml64) elseif(ARCH STREQUAL "arm") set(CMAKE_ASM_COMPILER armasm) +elseif(ARCH STREQUAL "arm64") + set(CMAKE_ASM_COMPILER armasm64) else() set(CMAKE_ASM_COMPILER ml) endif() @@ -33,3 +57,5 @@ set(CMAKE_C_STANDARD_LIBRARIES "" CACHE INTERNAL "") if(CMAKE_SYSTEM_PROCESSOR STREQUAL "x86") add_definitions(-D__i386__) endif() + +set(CMAKE_USER_MAKE_RULES_OVERRIDE "${CMAKE_CURRENT_LIST_DIR}/overrides-msvc.cmake")