summaryrefslogtreecommitdiffstats
path: root/Modules
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2022-10-25 14:29:20 (GMT)
committerKitware Robot <kwrobot@kitware.com>2022-10-25 14:29:36 (GMT)
commit765d8eda88ca123299c62758ba3d7cf0c815e55e (patch)
treec15c9a735da3c18775904e3149493b8ab462ecfa /Modules
parent30e0358d84679f3192d7f5db1f1f583841cf406b (diff)
parent3fc971c38b3aba4d2b216d31a1e6ced9cda2bf4a (diff)
downloadCMake-765d8eda88ca123299c62758ba3d7cf0c815e55e.zip
CMake-765d8eda88ca123299c62758ba3d7cf0c815e55e.tar.gz
CMake-765d8eda88ca123299c62758ba3d7cf0c815e55e.tar.bz2
Merge topic 'CheckSourceCompiles-Swift'
3fc971c38b CheckSourceCompiles: For Swift executable, name source 'main.swift' 2345139ab5 CheckSourceCompiles: Add support for Swift 4451a1f54f Tests: Factor out a CMake_TEST_Swift variable for Swift test conditions f78ad6223a Tests: Provide Apple inspection results to CMakeOnly and RunCMake tests Acked-by: Kitware Robot <kwrobot@kitware.com> Acked-by: Saleem Abdulrasool <compnerd@compnerd.org> Merge-request: !7783
Diffstat (limited to 'Modules')
-rw-r--r--Modules/Internal/CheckSourceCompiles.cmake11
1 files changed, 9 insertions, 2 deletions
diff --git a/Modules/Internal/CheckSourceCompiles.cmake b/Modules/Internal/CheckSourceCompiles.cmake
index eadf3da..bf5a82d 100644
--- a/Modules/Internal/CheckSourceCompiles.cmake
+++ b/Modules/Internal/CheckSourceCompiles.cmake
@@ -9,7 +9,7 @@ cmake_policy(SET CMP0057 NEW) # if() supports IN_LIST
function(CMAKE_CHECK_SOURCE_COMPILES _lang _source _var)
if(NOT DEFINED "${_var}")
-
+ set(_lang_filename "src")
if(_lang STREQUAL "C")
set(_lang_textual "C")
set(_lang_ext "c")
@@ -34,6 +34,13 @@ function(CMAKE_CHECK_SOURCE_COMPILES _lang _source _var)
elseif(_lang STREQUAL "OBJCXX")
set(_lang_textual "Objective-C++")
set(_lang_ext "mm")
+ elseif(_lang STREQUAL "Swift")
+ set(_lang_textual "Swift")
+ set(_lang_ext "swift")
+ if (NOT DEFINED CMAKE_TRY_COMPILE_TARGET_TYPE
+ OR CMAKE_TRY_COMPILE_TARGET_TYPE STREQUAL "EXECUTABLE")
+ set(_lang_filename "main")
+ endif()
else()
message (SEND_ERROR "check_source_compiles: ${_lang}: unknown language.")
return()
@@ -92,7 +99,7 @@ function(CMAKE_CHECK_SOURCE_COMPILES _lang _source _var)
endif()
string(APPEND _source "\n")
try_compile(${_var}
- SOURCE_FROM_VAR "src.${_SRC_EXT}" _source
+ SOURCE_FROM_VAR "${_lang_filename}.${_SRC_EXT}" _source
COMPILE_DEFINITIONS -D${_var} ${CMAKE_REQUIRED_DEFINITIONS}
${CHECK_${LANG}_SOURCE_COMPILES_ADD_LINK_OPTIONS}
${CHECK_${LANG}_SOURCE_COMPILES_ADD_LIBRARIES}