|
|
|
include(RunCMake)
|
|
|
|
|
|
|
|
# Early bailouts.
|
|
|
|
if(RunCMake_GENERATOR STREQUAL "Xcode" AND XCODE_VERSION VERSION_LESS 6.1)
|
|
|
|
run_cmake(XcodeTooOld)
|
|
|
|
return()
|
|
|
|
elseif(NOT CMake_TEST_Swift)
|
|
|
|
return()
|
|
|
|
elseif(NOT RunCMake_GENERATOR MATCHES "^Ninja|^Xcode$")
|
|
|
|
run_cmake(NotSupported)
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(RunCMake_GENERATOR_IS_MULTI_CONFIG)
|
|
|
|
set(RunCMake_TEST_OPTIONS "-DCMAKE_CONFIGURATION_TYPES=Debug\\;Release")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
block()
|
|
|
|
run_cmake(CMP0157-NEW)
|
|
|
|
run_cmake(CMP0157-WARN)
|
|
|
|
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/CMP0157-OLD-build)
|
|
|
|
|
|
|
|
run_cmake(CMP0157-OLD)
|
|
|
|
|
|
|
|
if(RunCMake_GENERATOR MATCHES "Ninja.*")
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
# -n: dry-run to avoid actually compiling, -v: verbose to capture executed command
|
|
|
|
run_cmake_command(CMP0157-OLD-build ${CMAKE_COMMAND} --build . -- -n -v)
|
|
|
|
endif()
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/SwiftSimple-build)
|
|
|
|
run_cmake(SwiftSimple)
|
|
|
|
if(RunCMake_GENERATOR_IS_MULTI_CONFIG AND
|
|
|
|
# Older Xcode versions didn't support Swift static libraries.
|
|
|
|
NOT (RunCMake_GENERATOR STREQUAL "Xcode" AND XCODE_VERSION VERSION_LESS 9.0))
|
|
|
|
# Check that .swiftmodule files get their own directories
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
run_cmake_command(SwiftSimple-build-Debug ${CMAKE_COMMAND} --build . --config Debug)
|
|
|
|
run_cmake_command(SwiftSimple-build-Release ${CMAKE_COMMAND} --build . --config Release)
|
|
|
|
|
|
|
|
# Will fail if either path doesn't exist. Passing -r because Xcode
|
|
|
|
# generates .swiftmodule directories.
|
|
|
|
run_cmake_command(SwiftSimple-verify ${CMAKE_COMMAND} -E
|
|
|
|
rm -r Debug/L.swiftmodule Release/L.swiftmodule)
|
|
|
|
endif()
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
if(RunCMake_GENERATOR MATCHES "Ninja")
|
|
|
|
block()
|
|
|
|
if (CMAKE_SYSTEM_NAME MATCHES "Windows")
|
|
|
|
run_cmake_with_options(Win32ExecutableDisallowed)
|
|
|
|
else()
|
|
|
|
run_cmake_with_options(Win32ExecutableIgnored)
|
|
|
|
list(APPEND RunCMake_TEST_OPTIONS -DCMAKE_SYSTEM_NAME=Darwin)
|
|
|
|
run_cmake(SwiftMultiArch)
|
|
|
|
endif()
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
# Test that a second build with no changes does nothing.
|
|
|
|
block()
|
|
|
|
run_cmake(NoWorkToDo)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/NoWorkToDo-build)
|
|
|
|
set(RunCMake_TEST_OUTPUT_MERGE 1)
|
|
|
|
run_cmake_command(NoWorkToDo-build ${CMAKE_COMMAND} --build .)
|
|
|
|
run_cmake_command(NoWorkToDo-nowork ${CMAKE_COMMAND} --build . -- -d explain)
|
|
|
|
file(WRITE ${RunCMake_TEST_BINARY_DIR}/hello.swift "//No-op change\n")
|
|
|
|
run_cmake_command(NoWorkToDo-norelink ${CMAKE_COMMAND} --build . -- -d explain)
|
|
|
|
run_cmake_command(NoWorkToDo-nowork ${CMAKE_COMMAND} --build . -- -d explain)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
# Test that intermediate static libraries are rebuilt when the public
|
|
|
|
# interface of their dependency changes
|
|
|
|
block()
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/IncrementalSwift-build)
|
|
|
|
# Since files are modified during test, the files are created in the cmake
|
|
|
|
# file into the build directory
|
|
|
|
run_cmake(IncrementalSwift)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
run_cmake_command(IncrementalSwift-first ${CMAKE_COMMAND} --build .)
|
|
|
|
|
|
|
|
# Modify public interface of libA requiring rebuild of libB
|
|
|
|
file(WRITE ${RunCMake_TEST_BINARY_DIR}/a.swift
|
|
|
|
"public func callA() -> Float { return 32.0 }\n")
|
|
|
|
|
|
|
|
# Note: We still expect this to fail, but instead of failure at link time,
|
|
|
|
# it should fail while re-compiling libB because the function changed
|
|
|
|
run_cmake_command(IncrementalSwift-second ${CMAKE_COMMAND} --build . -- -d explain)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/CompileCommands-build)
|
|
|
|
run_cmake(CompileCommands)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
run_cmake_command(CompileCommands-check ${CMAKE_COMMAND} --build .)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
# Try enabling Swift with a static-library try-compile
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/StaticLibTryCompile-build)
|
|
|
|
list(APPEND RunCMake_TEST_OPTIONS -DCMAKE_TRY_COMPILE_TARGET_TYPE=STATIC_LIBRARY)
|
|
|
|
run_cmake(EnableSwift)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
# Try enabling Swift with an executable try-compile
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/ExecutableTryCompile-build)
|
|
|
|
list(APPEND RunCMake_TEST_OPTIONS -DCMAKE_TRY_COMPILE_TARGET_TYPE=EXECUTABLE)
|
|
|
|
run_cmake(EnableSwift)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/ForceResponseFile-build)
|
|
|
|
run_cmake(ForceResponseFile)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
# -v: verbose to capture executed commands -n: dry-run to avoid actually compiling
|
|
|
|
run_cmake_command(ForceResponseFile-check ${CMAKE_COMMAND} --build . -- -vn)
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
if(CMAKE_SYSTEM_NAME MATCHES Windows)
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/ImportLibraryFlags-build)
|
|
|
|
run_cmake(ImportLibraryFlags)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
run_cmake_command(ImportLibraryFlags-check ${CMAKE_COMMAND} --build . -- -n -v)
|
|
|
|
endif()
|
|
|
|
endblock()
|
|
|
|
|
|
|
|
block()
|
|
|
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/SwiftLibraryModuleCommand-build)
|
|
|
|
run_cmake(SwiftLibraryModuleCommand)
|
|
|
|
set(RunCMake_TEST_NO_CLEAN 1)
|
|
|
|
run_cmake_command(SwiftLibraryModuleCommand-check ${CMAKE_COMMAND} --build . -- -n -v)
|
|
|
|
endblock()
|
|
|
|
endif()
|