CMakeDetermineCompilerId.cmake 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772
  1. # Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. # file Copyright.txt or https://cmake.org/licensing for details.
  3. # Function to compile a source file to identify the compiler. This is
  4. # used internally by CMake and should not be included by user code.
  5. # If successful, sets CMAKE_<lang>_COMPILER_ID and CMAKE_<lang>_PLATFORM_ID
  6. function(CMAKE_DETERMINE_COMPILER_ID lang flagvar src)
  7. # Make sure the compiler arguments are clean.
  8. string(STRIP "${CMAKE_${lang}_COMPILER_ARG1}" CMAKE_${lang}_COMPILER_ID_ARG1)
  9. string(REGEX REPLACE " +" ";" CMAKE_${lang}_COMPILER_ID_ARG1 "${CMAKE_${lang}_COMPILER_ID_ARG1}")
  10. # Make sure user-specified compiler flags are used.
  11. if(CMAKE_${lang}_FLAGS)
  12. set(CMAKE_${lang}_COMPILER_ID_FLAGS ${CMAKE_${lang}_FLAGS})
  13. else()
  14. set(CMAKE_${lang}_COMPILER_ID_FLAGS $ENV{${flagvar}})
  15. endif()
  16. string(REPLACE " " ";" CMAKE_${lang}_COMPILER_ID_FLAGS_LIST "${CMAKE_${lang}_COMPILER_ID_FLAGS}")
  17. # Compute the directory in which to run the test.
  18. set(CMAKE_${lang}_COMPILER_ID_DIR ${CMAKE_PLATFORM_INFO_DIR}/CompilerId${lang})
  19. # Try building with no extra flags and then try each set
  20. # of helper flags. Stop when the compiler is identified.
  21. foreach(userflags "${CMAKE_${lang}_COMPILER_ID_FLAGS_LIST}" "")
  22. foreach(testflags ${CMAKE_${lang}_COMPILER_ID_TEST_FLAGS_FIRST}
  23. ""
  24. ${CMAKE_${lang}_COMPILER_ID_TEST_FLAGS})
  25. CMAKE_DETERMINE_COMPILER_ID_BUILD("${lang}" "${testflags}" "${userflags}" "${src}")
  26. CMAKE_DETERMINE_COMPILER_ID_MATCH_VENDOR("${lang}" "${COMPILER_${lang}_PRODUCED_OUTPUT}")
  27. if(CMAKE_${lang}_COMPILER_ID)
  28. break()
  29. endif()
  30. foreach(file ${COMPILER_${lang}_PRODUCED_FILES})
  31. CMAKE_DETERMINE_COMPILER_ID_CHECK("${lang}" "${CMAKE_${lang}_COMPILER_ID_DIR}/${file}" "${src}")
  32. endforeach()
  33. if(CMAKE_${lang}_COMPILER_ID)
  34. break()
  35. endif()
  36. endforeach()
  37. if(CMAKE_${lang}_COMPILER_ID)
  38. break()
  39. endif()
  40. endforeach()
  41. # If the compiler is still unknown, try to query its vendor.
  42. if(CMAKE_${lang}_COMPILER AND NOT CMAKE_${lang}_COMPILER_ID)
  43. foreach(userflags "${CMAKE_${lang}_COMPILER_ID_FLAGS_LIST}" "")
  44. CMAKE_DETERMINE_COMPILER_ID_VENDOR(${lang} "${userflags}")
  45. endforeach()
  46. endif()
  47. if (COMPILER_QNXNTO AND CMAKE_${lang}_COMPILER_ID STREQUAL "GNU")
  48. execute_process(
  49. COMMAND "${CMAKE_${lang}_COMPILER}"
  50. -V
  51. OUTPUT_VARIABLE output ERROR_VARIABLE output
  52. RESULT_VARIABLE result
  53. TIMEOUT 10
  54. )
  55. if (output MATCHES "targets available")
  56. set(CMAKE_${lang}_COMPILER_ID QCC)
  57. # http://community.qnx.com/sf/discussion/do/listPosts/projects.community/discussion.qnx_momentics_community_support.topc3555?_pagenum=2
  58. # The qcc driver does not itself have a version.
  59. endif()
  60. endif()
  61. # if the format is unknown after all files have been checked, put "Unknown" in the cache
  62. if(NOT CMAKE_EXECUTABLE_FORMAT)
  63. set(CMAKE_EXECUTABLE_FORMAT "Unknown" CACHE INTERNAL "Executable file format")
  64. endif()
  65. if(CMAKE_GENERATOR STREQUAL "Ninja" AND MSVC_${lang}_ARCHITECTURE_ID)
  66. foreach(userflags "${CMAKE_${lang}_COMPILER_ID_FLAGS_LIST}" "")
  67. CMAKE_DETERMINE_MSVC_SHOWINCLUDES_PREFIX(${lang} "${userflags}")
  68. endforeach()
  69. else()
  70. set(CMAKE_${lang}_CL_SHOWINCLUDES_PREFIX "")
  71. endif()
  72. # Display the final identification result.
  73. if(CMAKE_${lang}_COMPILER_ID)
  74. if(CMAKE_${lang}_COMPILER_VERSION)
  75. set(_version " ${CMAKE_${lang}_COMPILER_VERSION}")
  76. else()
  77. set(_version "")
  78. endif()
  79. message(STATUS "The ${lang} compiler identification is "
  80. "${CMAKE_${lang}_COMPILER_ID}${_version}")
  81. else()
  82. message(STATUS "The ${lang} compiler identification is unknown")
  83. endif()
  84. # Check if compiler id detection gave us the compiler tool.
  85. if(CMAKE_${lang}_COMPILER_ID_TOOL)
  86. set(CMAKE_${lang}_COMPILER "${CMAKE_${lang}_COMPILER_ID_TOOL}" PARENT_SCOPE)
  87. elseif(NOT CMAKE_${lang}_COMPILER)
  88. set(CMAKE_${lang}_COMPILER "CMAKE_${lang}_COMPILER-NOTFOUND" PARENT_SCOPE)
  89. endif()
  90. set(CMAKE_${lang}_COMPILER_ID "${CMAKE_${lang}_COMPILER_ID}" PARENT_SCOPE)
  91. set(CMAKE_${lang}_PLATFORM_ID "${CMAKE_${lang}_PLATFORM_ID}" PARENT_SCOPE)
  92. set(CMAKE_${lang}_COMPILER_ARCHITECTURE_ID "${CMAKE_${lang}_COMPILER_ARCHITECTURE_ID}" PARENT_SCOPE)
  93. set(MSVC_${lang}_ARCHITECTURE_ID "${MSVC_${lang}_ARCHITECTURE_ID}"
  94. PARENT_SCOPE)
  95. set(CMAKE_${lang}_XCODE_CURRENT_ARCH "${CMAKE_${lang}_XCODE_CURRENT_ARCH}" PARENT_SCOPE)
  96. set(CMAKE_${lang}_CL_SHOWINCLUDES_PREFIX "${CMAKE_${lang}_CL_SHOWINCLUDES_PREFIX}" PARENT_SCOPE)
  97. set(CMAKE_${lang}_COMPILER_VERSION "${CMAKE_${lang}_COMPILER_VERSION}" PARENT_SCOPE)
  98. set(CMAKE_${lang}_COMPILER_VERSION_INTERNAL "${CMAKE_${lang}_COMPILER_VERSION_INTERNAL}" PARENT_SCOPE)
  99. set(CMAKE_${lang}_COMPILER_WRAPPER "${CMAKE_${lang}_COMPILER_WRAPPER}" PARENT_SCOPE)
  100. set(CMAKE_${lang}_SIMULATE_ID "${CMAKE_${lang}_SIMULATE_ID}" PARENT_SCOPE)
  101. set(CMAKE_${lang}_SIMULATE_VERSION "${CMAKE_${lang}_SIMULATE_VERSION}" PARENT_SCOPE)
  102. set(CMAKE_${lang}_STANDARD_COMPUTED_DEFAULT "${CMAKE_${lang}_STANDARD_COMPUTED_DEFAULT}" PARENT_SCOPE)
  103. set(CMAKE_${lang}_COMPILER_PRODUCED_OUTPUT "${COMPILER_${lang}_PRODUCED_OUTPUT}" PARENT_SCOPE)
  104. set(CMAKE_${lang}_COMPILER_PRODUCED_FILES "${COMPILER_${lang}_PRODUCED_FILES}" PARENT_SCOPE)
  105. endfunction()
  106. include(CMakeCompilerIdDetection)
  107. #-----------------------------------------------------------------------------
  108. # Function to write the compiler id source file.
  109. function(CMAKE_DETERMINE_COMPILER_ID_WRITE lang src)
  110. find_file(src_in ${src}.in PATHS ${CMAKE_ROOT}/Modules ${CMAKE_MODULE_PATH} NO_DEFAULT_PATH NO_CMAKE_FIND_ROOT_PATH)
  111. file(READ ${src_in} ID_CONTENT_IN)
  112. compiler_id_detection(CMAKE_${lang}_COMPILER_ID_CONTENT ${lang}
  113. ID_STRING
  114. VERSION_STRINGS
  115. PLATFORM_DEFAULT_COMPILER
  116. )
  117. unset(src_in CACHE)
  118. string(CONFIGURE "${ID_CONTENT_IN}" ID_CONTENT_OUT @ONLY)
  119. file(WRITE ${CMAKE_${lang}_COMPILER_ID_DIR}/${src} "${ID_CONTENT_OUT}")
  120. endfunction()
  121. #-----------------------------------------------------------------------------
  122. # Function to build the compiler id source file and look for output
  123. # files.
  124. function(CMAKE_DETERMINE_COMPILER_ID_BUILD lang testflags userflags src)
  125. # Create a clean working directory.
  126. file(REMOVE_RECURSE ${CMAKE_${lang}_COMPILER_ID_DIR})
  127. file(MAKE_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR})
  128. file(MAKE_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}/tmp)
  129. CMAKE_DETERMINE_COMPILER_ID_WRITE("${lang}" "${src}")
  130. # Construct a description of this test case.
  131. set(COMPILER_DESCRIPTION
  132. "Compiler: ${CMAKE_${lang}_COMPILER} ${CMAKE_${lang}_COMPILER_ID_ARG1}
  133. Build flags: ${userflags}
  134. Id flags: ${testflags} ${CMAKE_${lang}_COMPILER_ID_FLAGS_ALWAYS}
  135. ")
  136. # Compile the compiler identification source.
  137. if("${CMAKE_GENERATOR}" MATCHES "Visual Studio ([0-9]+)")
  138. set(vs_version ${CMAKE_MATCH_1})
  139. set(id_platform ${CMAKE_VS_PLATFORM_NAME})
  140. set(id_lang "${lang}")
  141. if(CMAKE_VS_PLATFORM_TOOLSET MATCHES "v[0-9]+_clang_.*")
  142. set(id_cl clang.exe)
  143. else()
  144. set(id_cl cl.exe)
  145. endif()
  146. if(CMAKE_VS_PLATFORM_NAME STREQUAL "Tegra-Android")
  147. set(v NsightTegra)
  148. set(ext vcxproj)
  149. if(lang STREQUAL CXX)
  150. set(id_gcc g++)
  151. set(id_clang clang++)
  152. else()
  153. set(id_gcc gcc)
  154. set(id_clang clang)
  155. endif()
  156. elseif(lang STREQUAL Fortran)
  157. set(v Intel)
  158. set(ext vfproj)
  159. set(id_cl ifort.exe)
  160. elseif(lang STREQUAL CSharp)
  161. set(v 10)
  162. set(ext csproj)
  163. set(id_cl csc.exe)
  164. elseif(NOT "${vs_version}" VERSION_LESS 10)
  165. set(v 10)
  166. set(ext vcxproj)
  167. else()
  168. set(id_version ${vs_version}.00)
  169. set(v 7)
  170. set(ext vcproj)
  171. endif()
  172. if(CMAKE_VS_PLATFORM_TOOLSET)
  173. if(CMAKE_VS_PLATFORM_NAME STREQUAL "Tegra-Android")
  174. set(id_toolset "<NdkToolchainVersion>${CMAKE_VS_PLATFORM_TOOLSET}</NdkToolchainVersion>")
  175. else()
  176. set(id_toolset "<PlatformToolset>${CMAKE_VS_PLATFORM_TOOLSET}</PlatformToolset>")
  177. if(CMAKE_VS_PLATFORM_TOOLSET MATCHES "Intel")
  178. set(id_cl icl.exe)
  179. endif()
  180. endif()
  181. else()
  182. set(id_toolset "")
  183. endif()
  184. if(CMAKE_VS_PLATFORM_TOOLSET_HOST_ARCHITECTURE)
  185. set(id_PreferredToolArchitecture "<PreferredToolArchitecture>${CMAKE_VS_PLATFORM_TOOLSET_HOST_ARCHITECTURE}</PreferredToolArchitecture>")
  186. else()
  187. set(id_PreferredToolArchitecture "")
  188. endif()
  189. if(CMAKE_SYSTEM_NAME STREQUAL "WindowsPhone")
  190. set(id_system "<ApplicationType>Windows Phone</ApplicationType>")
  191. elseif(CMAKE_SYSTEM_NAME STREQUAL "WindowsStore")
  192. set(id_system "<ApplicationType>Windows Store</ApplicationType>")
  193. else()
  194. set(id_system "")
  195. endif()
  196. if(id_system AND CMAKE_SYSTEM_VERSION)
  197. set(id_system_version "<ApplicationTypeRevision>${CMAKE_SYSTEM_VERSION}</ApplicationTypeRevision>")
  198. else()
  199. set(id_system_version "")
  200. endif()
  201. if(CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION)
  202. set(id_WindowsTargetPlatformVersion "<WindowsTargetPlatformVersion>${CMAKE_VS_WINDOWS_TARGET_PLATFORM_VERSION}</WindowsTargetPlatformVersion>")
  203. endif()
  204. if(id_platform STREQUAL ARM64)
  205. set(id_WindowsSDKDesktopARMSupport "<WindowsSDKDesktopARM64Support>true</WindowsSDKDesktopARM64Support>")
  206. elseif(id_platform STREQUAL ARM)
  207. set(id_WindowsSDKDesktopARMSupport "<WindowsSDKDesktopARMSupport>true</WindowsSDKDesktopARMSupport>")
  208. else()
  209. set(id_WindowsSDKDesktopARMSupport "")
  210. endif()
  211. if(CMAKE_VS_WINCE_VERSION)
  212. set(id_entrypoint "mainACRTStartup")
  213. if("${vs_version}" VERSION_LESS 9)
  214. set(id_subsystem 9)
  215. else()
  216. set(id_subsystem 8)
  217. endif()
  218. else()
  219. set(id_subsystem 1)
  220. endif()
  221. set(id_dir ${CMAKE_${lang}_COMPILER_ID_DIR})
  222. set(id_src "${src}")
  223. set(id_compile "ClCompile")
  224. set(id_PostBuildEvent_Command "for %%i in (${id_cl}) do %40echo CMAKE_${lang}_COMPILER=%%~$PATH:i")
  225. set(id_Import_props "")
  226. set(id_Import_targets "")
  227. set(id_ItemDefinitionGroup_entry "")
  228. set(id_Link_AdditionalDependencies "")
  229. if(lang STREQUAL CUDA)
  230. if(NOT CMAKE_VS_PLATFORM_TOOLSET_CUDA)
  231. message(FATAL_ERROR "No CUDA toolset found.")
  232. endif()
  233. set(cuda_tools "CUDA ${CMAKE_VS_PLATFORM_TOOLSET_CUDA}")
  234. set(id_compile "CudaCompile")
  235. set(id_PostBuildEvent_Command [[echo CMAKE_CUDA_COMPILER=$(CudaToolkitBinDir)\nvcc.exe]])
  236. string(CONCAT id_Import_props [[<Import Project="$(VCTargetsPath)\BuildCustomizations\]] "${cuda_tools}" [[.props" />]])
  237. string(CONCAT id_Import_targets [[<Import Project="$(VCTargetsPath)\BuildCustomizations\]] "${cuda_tools}" [[.targets" />]])
  238. if(CMAKE_VS_PLATFORM_NAME STREQUAL x64)
  239. set(id_ItemDefinitionGroup_entry "<CudaCompile><TargetMachinePlatform>64</TargetMachinePlatform></CudaCompile>")
  240. endif()
  241. set(id_Link_AdditionalDependencies "<AdditionalDependencies>cudart.lib</AdditionalDependencies>")
  242. endif()
  243. configure_file(${CMAKE_ROOT}/Modules/CompilerId/VS-${v}.${ext}.in
  244. ${id_dir}/CompilerId${lang}.${ext} @ONLY)
  245. if(CMAKE_VS_MSBUILD_COMMAND AND NOT lang STREQUAL "Fortran")
  246. set(command "${CMAKE_VS_MSBUILD_COMMAND}" "CompilerId${lang}.${ext}"
  247. "/p:Configuration=Debug" "/p:Platform=${id_platform}" "/p:VisualStudioVersion=${vs_version}.0"
  248. )
  249. elseif(CMAKE_VS_DEVENV_COMMAND)
  250. set(command "${CMAKE_VS_DEVENV_COMMAND}" "CompilerId${lang}.${ext}" "/build" "Debug")
  251. else()
  252. set(command "")
  253. endif()
  254. if(command)
  255. execute_process(
  256. COMMAND ${command}
  257. WORKING_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}
  258. OUTPUT_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  259. ERROR_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  260. RESULT_VARIABLE CMAKE_${lang}_COMPILER_ID_RESULT
  261. )
  262. else()
  263. set(CMAKE_${lang}_COMPILER_ID_RESULT 1)
  264. set(CMAKE_${lang}_COMPILER_ID_OUTPUT "VS environment not known to support ${lang}")
  265. endif()
  266. # Match the compiler location line printed out.
  267. if("${CMAKE_${lang}_COMPILER_ID_OUTPUT}" MATCHES "CMAKE_${lang}_COMPILER=([^%\r\n]+)[\r\n]")
  268. # Strip VS diagnostic output from the end of the line.
  269. string(REGEX REPLACE " \\(TaskId:[0-9]*\\)$" "" _comp "${CMAKE_MATCH_1}")
  270. if(EXISTS "${_comp}")
  271. file(TO_CMAKE_PATH "${_comp}" _comp)
  272. set(CMAKE_${lang}_COMPILER_ID_TOOL "${_comp}" PARENT_SCOPE)
  273. endif()
  274. endif()
  275. elseif("${CMAKE_GENERATOR}" MATCHES "Xcode")
  276. set(id_lang "${lang}")
  277. set(id_type ${CMAKE_${lang}_COMPILER_XCODE_TYPE})
  278. set(id_dir ${CMAKE_${lang}_COMPILER_ID_DIR})
  279. set(id_src "${src}")
  280. if(CMAKE_XCODE_PLATFORM_TOOLSET)
  281. set(id_toolset "GCC_VERSION = ${CMAKE_XCODE_PLATFORM_TOOLSET};")
  282. else()
  283. set(id_toolset "")
  284. endif()
  285. if("${lang}" STREQUAL "Swift")
  286. if(CMAKE_Swift_LANGUAGE_VERSION)
  287. set(id_lang_version "SWIFT_VERSION = ${CMAKE_Swift_LANGUAGE_VERSION};")
  288. elseif(XCODE_VERSION VERSION_GREATER_EQUAL 8.3)
  289. set(id_lang_version "SWIFT_VERSION = 3.0;")
  290. else()
  291. set(id_lang_version "SWIFT_VERSION = 2.3;")
  292. endif()
  293. else()
  294. set(id_lang_version "")
  295. endif()
  296. if(CMAKE_OSX_DEPLOYMENT_TARGET)
  297. set(id_deployment_target
  298. "MACOSX_DEPLOYMENT_TARGET = \"${CMAKE_OSX_DEPLOYMENT_TARGET}\";")
  299. else()
  300. set(id_deployment_target "")
  301. endif()
  302. set(id_product_type "com.apple.product-type.tool")
  303. if(CMAKE_OSX_SYSROOT)
  304. set(id_sdkroot "SDKROOT = \"${CMAKE_OSX_SYSROOT}\";")
  305. if(CMAKE_OSX_SYSROOT MATCHES "(^|/)[Ii][Pp][Hh][Oo][Nn][Ee]" OR
  306. CMAKE_OSX_SYSROOT MATCHES "(^|/)[Aa][Pp][Pp][Ll][Ee][Tt][Vv]")
  307. set(id_product_type "com.apple.product-type.bundle.unit-test")
  308. endif()
  309. else()
  310. set(id_sdkroot "")
  311. endif()
  312. if(CMAKE_XCODE_ATTRIBUTE_DEVELOPMENT_TEAM)
  313. set(id_development_team
  314. "DEVELOPMENT_TEAM = \"${CMAKE_XCODE_ATTRIBUTE_DEVELOPMENT_TEAM}\";")
  315. else()
  316. set(id_development_team "")
  317. endif()
  318. configure_file(${CMAKE_ROOT}/Modules/CompilerId/Xcode-3.pbxproj.in
  319. ${id_dir}/CompilerId${lang}.xcodeproj/project.pbxproj @ONLY)
  320. unset(_ENV_MACOSX_DEPLOYMENT_TARGET)
  321. if(DEFINED ENV{MACOSX_DEPLOYMENT_TARGET})
  322. set(_ENV_MACOSX_DEPLOYMENT_TARGET "$ENV{MACOSX_DEPLOYMENT_TARGET}")
  323. set(ENV{MACOSX_DEPLOYMENT_TARGET} "")
  324. endif()
  325. execute_process(COMMAND xcodebuild
  326. WORKING_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}
  327. OUTPUT_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  328. ERROR_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  329. RESULT_VARIABLE CMAKE_${lang}_COMPILER_ID_RESULT
  330. )
  331. if(DEFINED _ENV_MACOSX_DEPLOYMENT_TARGET)
  332. set(ENV{MACOSX_DEPLOYMENT_TARGET} "${_ENV_MACOSX_DEPLOYMENT_TARGET}")
  333. endif()
  334. if(DEFINED CMAKE_${lang}_COMPILER_ID_TOOL_MATCH_REGEX)
  335. if("${CMAKE_${lang}_COMPILER_ID_OUTPUT}" MATCHES "${CMAKE_${lang}_COMPILER_ID_TOOL_MATCH_REGEX}")
  336. set(_comp "${CMAKE_MATCH_${CMAKE_${lang}_COMPILER_ID_TOOL_MATCH_INDEX}}")
  337. if(EXISTS "${_comp}")
  338. set(CMAKE_${lang}_COMPILER_ID_TOOL "${_comp}" PARENT_SCOPE)
  339. endif()
  340. endif()
  341. endif()
  342. if("${CMAKE_${lang}_COMPILER_ID_OUTPUT}" MATCHES "CURRENT_ARCH=([^%\r\n]+)[\r\n]")
  343. set(CMAKE_${lang}_XCODE_CURRENT_ARCH "${CMAKE_MATCH_1}" PARENT_SCOPE)
  344. endif()
  345. else()
  346. execute_process(
  347. COMMAND "${CMAKE_${lang}_COMPILER}"
  348. ${CMAKE_${lang}_COMPILER_ID_ARG1}
  349. ${userflags}
  350. ${testflags}
  351. ${CMAKE_${lang}_COMPILER_ID_FLAGS_ALWAYS}
  352. "${src}"
  353. WORKING_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}
  354. OUTPUT_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  355. ERROR_VARIABLE CMAKE_${lang}_COMPILER_ID_OUTPUT
  356. RESULT_VARIABLE CMAKE_${lang}_COMPILER_ID_RESULT
  357. )
  358. endif()
  359. # Check the result of compilation.
  360. if(CMAKE_${lang}_COMPILER_ID_RESULT
  361. # Intel Fortran warns and ignores preprocessor lines without /fpp
  362. OR CMAKE_${lang}_COMPILER_ID_OUTPUT MATCHES "Bad # preprocessor line"
  363. )
  364. # Compilation failed.
  365. set(MSG
  366. "Compiling the ${lang} compiler identification source file \"${src}\" failed.
  367. ${COMPILER_DESCRIPTION}
  368. The output was:
  369. ${CMAKE_${lang}_COMPILER_ID_RESULT}
  370. ${CMAKE_${lang}_COMPILER_ID_OUTPUT}
  371. ")
  372. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log "${MSG}")
  373. #if(NOT CMAKE_${lang}_COMPILER_ID_ALLOW_FAIL)
  374. # message(FATAL_ERROR "${MSG}")
  375. #endif()
  376. # No output files should be inspected.
  377. set(COMPILER_${lang}_PRODUCED_FILES)
  378. set(COMPILER_${lang}_PRODUCED_OUTPUT)
  379. else()
  380. # Compilation succeeded.
  381. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  382. "Compiling the ${lang} compiler identification source file \"${src}\" succeeded.
  383. ${COMPILER_DESCRIPTION}
  384. The output was:
  385. ${CMAKE_${lang}_COMPILER_ID_RESULT}
  386. ${CMAKE_${lang}_COMPILER_ID_OUTPUT}
  387. ")
  388. # Find the executable produced by the compiler, try all files in the
  389. # binary dir.
  390. string(REGEX REPLACE "([][])" "[\\1]" _glob_id_dir "${CMAKE_${lang}_COMPILER_ID_DIR}")
  391. file(GLOB files
  392. RELATIVE ${CMAKE_${lang}_COMPILER_ID_DIR}
  393. # normal case
  394. ${_glob_id_dir}/*
  395. # com.apple.package-type.bundle.unit-test
  396. ${_glob_id_dir}/*.xctest/*
  397. )
  398. list(REMOVE_ITEM files "${src}")
  399. set(COMPILER_${lang}_PRODUCED_FILES "")
  400. foreach(file ${files})
  401. if(NOT IS_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}/${file})
  402. list(APPEND COMPILER_${lang}_PRODUCED_FILES ${file})
  403. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  404. "Compilation of the ${lang} compiler identification source \""
  405. "${src}\" produced \"${file}\"\n\n")
  406. endif()
  407. endforeach()
  408. if(NOT COMPILER_${lang}_PRODUCED_FILES)
  409. # No executable was found.
  410. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
  411. "Compilation of the ${lang} compiler identification source \""
  412. "${src}\" did not produce an executable in \""
  413. "${CMAKE_${lang}_COMPILER_ID_DIR}\".\n\n")
  414. endif()
  415. set(COMPILER_${lang}_PRODUCED_OUTPUT "${CMAKE_${lang}_COMPILER_ID_OUTPUT}")
  416. endif()
  417. # Return the files produced by the compilation.
  418. set(COMPILER_${lang}_PRODUCED_FILES "${COMPILER_${lang}_PRODUCED_FILES}" PARENT_SCOPE)
  419. set(COMPILER_${lang}_PRODUCED_OUTPUT "${COMPILER_${lang}_PRODUCED_OUTPUT}" PARENT_SCOPE)
  420. endfunction()
  421. #-----------------------------------------------------------------------------
  422. # Function to extract the compiler id from compiler output.
  423. function(CMAKE_DETERMINE_COMPILER_ID_MATCH_VENDOR lang output)
  424. foreach(vendor ${CMAKE_${lang}_COMPILER_ID_MATCH_VENDORS})
  425. if(output MATCHES "${CMAKE_${lang}_COMPILER_ID_MATCH_VENDOR_REGEX_${vendor}}")
  426. set(CMAKE_${lang}_COMPILER_ID "${vendor}")
  427. endif()
  428. endforeach()
  429. set(CMAKE_${lang}_COMPILER_ID "${CMAKE_${lang}_COMPILER_ID}" PARENT_SCOPE)
  430. endfunction()
  431. #-----------------------------------------------------------------------------
  432. # Function to extract the compiler id from an executable.
  433. function(CMAKE_DETERMINE_COMPILER_ID_CHECK lang file)
  434. # Look for a compiler id if not yet known.
  435. if(NOT CMAKE_${lang}_COMPILER_ID)
  436. # Read the compiler identification string from the executable file.
  437. set(COMPILER_ID)
  438. set(COMPILER_VERSION)
  439. set(COMPILER_VERSION_MAJOR 0)
  440. set(COMPILER_VERSION_MINOR 0)
  441. set(COMPILER_VERSION_PATCH 0)
  442. set(COMPILER_VERSION_TWEAK 0)
  443. set(COMPILER_VERSION_INTERNAL "")
  444. set(HAVE_COMPILER_VERSION_MAJOR 0)
  445. set(HAVE_COMPILER_VERSION_MINOR 0)
  446. set(HAVE_COMPILER_VERSION_PATCH 0)
  447. set(HAVE_COMPILER_VERSION_TWEAK 0)
  448. set(COMPILER_WRAPPER)
  449. set(DIGIT_VALUE_1 1)
  450. set(DIGIT_VALUE_2 10)
  451. set(DIGIT_VALUE_3 100)
  452. set(DIGIT_VALUE_4 1000)
  453. set(DIGIT_VALUE_5 10000)
  454. set(DIGIT_VALUE_6 100000)
  455. set(DIGIT_VALUE_7 1000000)
  456. set(DIGIT_VALUE_8 10000000)
  457. set(PLATFORM_ID)
  458. set(ARCHITECTURE_ID)
  459. set(SIMULATE_ID)
  460. set(SIMULATE_VERSION)
  461. file(STRINGS ${file}
  462. CMAKE_${lang}_COMPILER_ID_STRINGS LIMIT_COUNT 38
  463. ${CMAKE_${lang}_COMPILER_ID_STRINGS_PARAMETERS}
  464. REGEX "INFO:[A-Za-z0-9_]+\\[[^]]*\\]")
  465. set(COMPILER_ID_TWICE)
  466. # In C# binaries, some strings are found more than once.
  467. list(REMOVE_DUPLICATES CMAKE_${lang}_COMPILER_ID_STRINGS)
  468. foreach(info ${CMAKE_${lang}_COMPILER_ID_STRINGS})
  469. if("${info}" MATCHES "INFO:compiler\\[([^]\"]*)\\]")
  470. if(COMPILER_ID)
  471. set(COMPILER_ID_TWICE 1)
  472. endif()
  473. set(COMPILER_ID "${CMAKE_MATCH_1}")
  474. endif()
  475. if("${info}" MATCHES "INFO:platform\\[([^]\"]*)\\]")
  476. set(PLATFORM_ID "${CMAKE_MATCH_1}")
  477. endif()
  478. if("${info}" MATCHES "INFO:arch\\[([^]\"]*)\\]")
  479. set(ARCHITECTURE_ID "${CMAKE_MATCH_1}")
  480. endif()
  481. if("${info}" MATCHES "INFO:compiler_version\\[([^]\"]*)\\]")
  482. string(REGEX REPLACE "^0+([0-9])" "\\1" COMPILER_VERSION "${CMAKE_MATCH_1}")
  483. string(REGEX REPLACE "\\.0+([0-9])" ".\\1" COMPILER_VERSION "${COMPILER_VERSION}")
  484. endif()
  485. if("${info}" MATCHES "INFO:compiler_version_internal\\[([^]\"]*)\\]")
  486. string(REGEX REPLACE "^0+([0-9])" "\\1" COMPILER_VERSION_INTERNAL "${CMAKE_MATCH_1}")
  487. string(REGEX REPLACE "\\.0+([0-9])" ".\\1" COMPILER_VERSION_INTERNAL "${COMPILER_VERSION_INTERNAL}")
  488. endif()
  489. foreach(comp MAJOR MINOR PATCH TWEAK)
  490. foreach(digit 1 2 3 4 5 6 7 8 9)
  491. if("${info}" MATCHES "INFO:compiler_version_${comp}_digit_${digit}\\[([0-9])\\]")
  492. set(value ${CMAKE_MATCH_1})
  493. math(EXPR COMPILER_VERSION_${comp} "${COMPILER_VERSION_${comp}} + ${value} * ${DIGIT_VALUE_${digit}}")
  494. set(HAVE_COMPILER_VERSION_${comp} 1)
  495. endif()
  496. endforeach()
  497. endforeach()
  498. if("${info}" MATCHES "INFO:compiler_wrapper\\[([^]\"]*)\\]")
  499. set(COMPILER_WRAPPER "${CMAKE_MATCH_1}")
  500. endif()
  501. if("${info}" MATCHES "INFO:simulate\\[([^]\"]*)\\]")
  502. set(SIMULATE_ID "${CMAKE_MATCH_1}")
  503. endif()
  504. if("${info}" MATCHES "INFO:simulate_version\\[([^]\"]*)\\]")
  505. string(REGEX REPLACE "^0+([0-9])" "\\1" SIMULATE_VERSION "${CMAKE_MATCH_1}")
  506. string(REGEX REPLACE "\\.0+([0-9])" ".\\1" SIMULATE_VERSION "${SIMULATE_VERSION}")
  507. endif()
  508. if("${info}" MATCHES "INFO:qnxnto\\[\\]")
  509. set(COMPILER_QNXNTO 1)
  510. endif()
  511. if("${info}" MATCHES "INFO:dialect_default\\[([^]\"]*)\\]")
  512. set(CMAKE_${lang}_STANDARD_COMPUTED_DEFAULT "${CMAKE_MATCH_1}")
  513. endif()
  514. endforeach()
  515. # Construct compiler version from components if needed.
  516. if(NOT DEFINED COMPILER_VERSION AND HAVE_COMPILER_VERSION_MAJOR)
  517. set(COMPILER_VERSION "${COMPILER_VERSION_MAJOR}")
  518. if(HAVE_COMPILER_VERSION_MINOR)
  519. string(APPEND COMPILER_VERSION ".${COMPILER_VERSION_MINOR}")
  520. if(HAVE_COMPILER_VERSION_PATCH)
  521. string(APPEND COMPILER_VERSION ".${COMPILER_VERSION_PATCH}")
  522. if(HAVE_COMPILER_VERSION_TWEAK)
  523. string(APPEND COMPILER_VERSION ".${COMPILER_VERSION_TWEAK}")
  524. endif()
  525. endif()
  526. endif()
  527. endif()
  528. # Detect the exact architecture from the PE header.
  529. if(WIN32)
  530. # The offset to the PE signature is stored at 0x3c.
  531. file(READ ${file} peoffsethex LIMIT 1 OFFSET 60 HEX)
  532. string(SUBSTRING "${peoffsethex}" 0 1 peoffsethex1)
  533. string(SUBSTRING "${peoffsethex}" 1 1 peoffsethex2)
  534. set(peoffsetexpression "${peoffsethex1} * 16 + ${peoffsethex2}")
  535. string(REPLACE "a" "10" peoffsetexpression "${peoffsetexpression}")
  536. string(REPLACE "b" "11" peoffsetexpression "${peoffsetexpression}")
  537. string(REPLACE "c" "12" peoffsetexpression "${peoffsetexpression}")
  538. string(REPLACE "d" "13" peoffsetexpression "${peoffsetexpression}")
  539. string(REPLACE "e" "14" peoffsetexpression "${peoffsetexpression}")
  540. string(REPLACE "f" "15" peoffsetexpression "${peoffsetexpression}")
  541. math(EXPR peoffset "${peoffsetexpression}")
  542. file(READ ${file} peheader LIMIT 6 OFFSET ${peoffset} HEX)
  543. if(peheader STREQUAL "50450000a201")
  544. set(ARCHITECTURE_ID "SH3")
  545. elseif(peheader STREQUAL "50450000a301")
  546. set(ARCHITECTURE_ID "SH3DSP")
  547. elseif(peheader STREQUAL "50450000a601")
  548. set(ARCHITECTURE_ID "SH4")
  549. elseif(peheader STREQUAL "50450000a801")
  550. set(ARCHITECTURE_ID "SH5")
  551. endif()
  552. endif()
  553. # Check if a valid compiler and platform were found.
  554. if(COMPILER_ID AND NOT COMPILER_ID_TWICE)
  555. set(CMAKE_${lang}_COMPILER_ID "${COMPILER_ID}")
  556. set(CMAKE_${lang}_PLATFORM_ID "${PLATFORM_ID}")
  557. set(CMAKE_${lang}_COMPILER_ARCHITECTURE_ID "${ARCHITECTURE_ID}")
  558. set(MSVC_${lang}_ARCHITECTURE_ID "${ARCHITECTURE_ID}")
  559. set(CMAKE_${lang}_COMPILER_VERSION "${COMPILER_VERSION}")
  560. set(CMAKE_${lang}_COMPILER_VERSION_INTERNAL "${COMPILER_VERSION_INTERNAL}")
  561. set(CMAKE_${lang}_SIMULATE_ID "${SIMULATE_ID}")
  562. set(CMAKE_${lang}_SIMULATE_VERSION "${SIMULATE_VERSION}")
  563. endif()
  564. # Check the compiler identification string.
  565. if(CMAKE_${lang}_COMPILER_ID)
  566. # The compiler identification was found.
  567. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  568. "The ${lang} compiler identification is ${CMAKE_${lang}_COMPILER_ID}, found in \""
  569. "${file}\"\n\n")
  570. else()
  571. # The compiler identification could not be found.
  572. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
  573. "The ${lang} compiler identification could not be found in \""
  574. "${file}\"\n\n")
  575. endif()
  576. endif()
  577. # try to figure out the executable format: ELF, COFF, Mach-O
  578. if(NOT CMAKE_EXECUTABLE_FORMAT)
  579. file(READ ${file} CMAKE_EXECUTABLE_MAGIC LIMIT 4 HEX)
  580. # ELF files start with 0x7f"ELF"
  581. if("${CMAKE_EXECUTABLE_MAGIC}" STREQUAL "7f454c46")
  582. set(CMAKE_EXECUTABLE_FORMAT "ELF" CACHE INTERNAL "Executable file format")
  583. endif()
  584. # # COFF (.exe) files start with "MZ"
  585. # if("${CMAKE_EXECUTABLE_MAGIC}" MATCHES "4d5a....")
  586. # set(CMAKE_EXECUTABLE_FORMAT "COFF" CACHE STRING "Executable file format")
  587. # endif()
  588. #
  589. # # Mach-O files start with CAFEBABE or FEEDFACE, according to http://radio.weblogs.com/0100490/2003/01/28.html
  590. # if("${CMAKE_EXECUTABLE_MAGIC}" MATCHES "cafebabe")
  591. # set(CMAKE_EXECUTABLE_FORMAT "MACHO" CACHE STRING "Executable file format")
  592. # endif()
  593. # if("${CMAKE_EXECUTABLE_MAGIC}" MATCHES "feedface")
  594. # set(CMAKE_EXECUTABLE_FORMAT "MACHO" CACHE STRING "Executable file format")
  595. # endif()
  596. endif()
  597. if(NOT DEFINED CMAKE_EXECUTABLE_FORMAT)
  598. set(CMAKE_EXECUTABLE_FORMAT)
  599. endif()
  600. # Return the information extracted.
  601. set(CMAKE_${lang}_COMPILER_ID "${CMAKE_${lang}_COMPILER_ID}" PARENT_SCOPE)
  602. set(CMAKE_${lang}_PLATFORM_ID "${CMAKE_${lang}_PLATFORM_ID}" PARENT_SCOPE)
  603. set(CMAKE_${lang}_COMPILER_ARCHITECTURE_ID "${CMAKE_${lang}_COMPILER_ARCHITECTURE_ID}" PARENT_SCOPE)
  604. set(MSVC_${lang}_ARCHITECTURE_ID "${MSVC_${lang}_ARCHITECTURE_ID}"
  605. PARENT_SCOPE)
  606. set(CMAKE_${lang}_COMPILER_VERSION "${CMAKE_${lang}_COMPILER_VERSION}" PARENT_SCOPE)
  607. set(CMAKE_${lang}_COMPILER_VERSION_INTERNAL "${CMAKE_${lang}_COMPILER_VERSION_INTERNAL}" PARENT_SCOPE)
  608. set(CMAKE_${lang}_COMPILER_WRAPPER "${COMPILER_WRAPPER}" PARENT_SCOPE)
  609. set(CMAKE_${lang}_SIMULATE_ID "${CMAKE_${lang}_SIMULATE_ID}" PARENT_SCOPE)
  610. set(CMAKE_${lang}_SIMULATE_VERSION "${CMAKE_${lang}_SIMULATE_VERSION}" PARENT_SCOPE)
  611. set(CMAKE_EXECUTABLE_FORMAT "${CMAKE_EXECUTABLE_FORMAT}" PARENT_SCOPE)
  612. set(COMPILER_QNXNTO "${COMPILER_QNXNTO}" PARENT_SCOPE)
  613. set(CMAKE_${lang}_STANDARD_COMPUTED_DEFAULT "${CMAKE_${lang}_STANDARD_COMPUTED_DEFAULT}" PARENT_SCOPE)
  614. endfunction()
  615. #-----------------------------------------------------------------------------
  616. # Function to query the compiler vendor.
  617. # This uses a table with entries of the form
  618. # list(APPEND CMAKE_${lang}_COMPILER_ID_VENDORS ${vendor})
  619. # set(CMAKE_${lang}_COMPILER_ID_VENDOR_FLAGS_${vendor} -some-vendor-flag)
  620. # set(CMAKE_${lang}_COMPILER_ID_VENDOR_REGEX_${vendor} "Some Vendor Output")
  621. # We try running the compiler with the flag for each vendor and
  622. # matching its regular expression in the output.
  623. function(CMAKE_DETERMINE_COMPILER_ID_VENDOR lang userflags)
  624. if(NOT CMAKE_${lang}_COMPILER_ID_DIR)
  625. # We get here when this function is called not from within CMAKE_DETERMINE_COMPILER_ID()
  626. # This is done e.g. for detecting the compiler ID for assemblers.
  627. # Compute the directory in which to run the test and Create a clean working directory.
  628. set(CMAKE_${lang}_COMPILER_ID_DIR ${CMAKE_PLATFORM_INFO_DIR}/CompilerId${lang})
  629. file(REMOVE_RECURSE ${CMAKE_${lang}_COMPILER_ID_DIR})
  630. file(MAKE_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR})
  631. endif()
  632. foreach(vendor ${CMAKE_${lang}_COMPILER_ID_VENDORS})
  633. set(flags ${CMAKE_${lang}_COMPILER_ID_VENDOR_FLAGS_${vendor}})
  634. set(regex ${CMAKE_${lang}_COMPILER_ID_VENDOR_REGEX_${vendor}})
  635. execute_process(
  636. COMMAND "${CMAKE_${lang}_COMPILER}"
  637. ${CMAKE_${lang}_COMPILER_ID_ARG1}
  638. ${userflags}
  639. ${flags}
  640. WORKING_DIRECTORY ${CMAKE_${lang}_COMPILER_ID_DIR}
  641. OUTPUT_VARIABLE output ERROR_VARIABLE output
  642. RESULT_VARIABLE result
  643. TIMEOUT 10
  644. )
  645. if("${output}" MATCHES "${regex}")
  646. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
  647. "Checking whether the ${lang} compiler is ${vendor} using \"${flags}\" "
  648. "matched \"${regex}\":\n${output}")
  649. set(CMAKE_${lang}_COMPILER_ID "${vendor}" PARENT_SCOPE)
  650. set(CMAKE_${lang}_COMPILER_ID_OUTPUT "${output}" PARENT_SCOPE)
  651. break()
  652. else()
  653. if("${result}" MATCHES "timeout")
  654. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
  655. "Checking whether the ${lang} compiler is ${vendor} using \"${flags}\" "
  656. "terminated after 10 s due to timeout.")
  657. else()
  658. file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
  659. "Checking whether the ${lang} compiler is ${vendor} using \"${flags}\" "
  660. "did not match \"${regex}\":\n${output}")
  661. endif()
  662. endif()
  663. endforeach()
  664. endfunction()
  665. function(CMAKE_DETERMINE_MSVC_SHOWINCLUDES_PREFIX lang userflags)
  666. # Run this MSVC-compatible compiler to detect what the /showIncludes
  667. # option displays. We can use a C source even with the C++ compiler
  668. # because MSVC-compatible compilers handle both and show the same output.
  669. set(showdir ${CMAKE_BINARY_DIR}/CMakeFiles/ShowIncludes)
  670. file(WRITE ${showdir}/foo.h "\n")
  671. file(WRITE ${showdir}/main.c "#include \"foo.h\" \nint main(){}\n")
  672. execute_process(
  673. COMMAND "${CMAKE_${lang}_COMPILER}"
  674. ${CMAKE_${lang}_COMPILER_ID_ARG1}
  675. ${userflags}
  676. /nologo /showIncludes /c main.c
  677. WORKING_DIRECTORY ${showdir}
  678. OUTPUT_VARIABLE out
  679. ERROR_VARIABLE err
  680. RESULT_VARIABLE res
  681. ENCODING AUTO # cl prints in current code page
  682. )
  683. if(res EQUAL 0 AND "${out}" MATCHES "(^|\n)([^:\n]*:[^:\n]*:[ \t]*)")
  684. set(CMAKE_${lang}_CL_SHOWINCLUDES_PREFIX "${CMAKE_MATCH_2}" PARENT_SCOPE)
  685. else()
  686. set(CMAKE_${lang}_CL_SHOWINCLUDES_PREFIX "" PARENT_SCOPE)
  687. endif()
  688. endfunction()
  689. function(CMAKE_DIAGNOSE_UNSUPPORTED_CLANG lang envvar)
  690. if(NOT CMAKE_HOST_WIN32 OR CMAKE_GENERATOR MATCHES "Visual Studio" OR
  691. NOT "${CMAKE_${lang}_COMPILER_ID};${CMAKE_${lang}_SIMULATE_ID}" STREQUAL "Clang;MSVC")
  692. return()
  693. endif()
  694. # Test whether an MSVC-like command-line option works.
  695. execute_process(COMMAND "${CMAKE_${lang}_COMPILER}" /?
  696. RESULT_VARIABLE _clang_result
  697. OUTPUT_VARIABLE _clang_stdout
  698. ERROR_VARIABLE _clang_stderr)
  699. if(_clang_result EQUAL 0)
  700. return()
  701. endif()
  702. # Help the user configure the environment to use the MSVC-like Clang.
  703. string(CONCAT _msg
  704. "The Clang compiler tool\n"
  705. " \"${CMAKE_${lang}_COMPILER}\"\n"
  706. "targets the MSVC ABI but has a GNU-like command-line interface. "
  707. "This is not supported. "
  708. "Use 'clang-cl' instead, e.g. by setting '${envvar}=clang-cl' in the environment."
  709. )
  710. execute_process(COMMAND rc -help
  711. RESULT_VARIABLE _rc_result
  712. OUTPUT_VARIABLE _rc_stdout
  713. ERROR_VARIABLE _rc_stderr)
  714. if(NOT _rc_result EQUAL 0)
  715. string(APPEND _msg " "
  716. "Furthermore, use the MSVC command-line environment."
  717. )
  718. endif()
  719. message(FATAL_ERROR "${_msg}")
  720. endfunction()