New upstream version 3.18.4
This commit is contained in:
parent
0b396e2089
commit
e0ffb2c2a7
@ -178,17 +178,15 @@ Modules
|
|||||||
Autogen
|
Autogen
|
||||||
-------
|
-------
|
||||||
|
|
||||||
* When using :prop_tgt:`AUTOMOC`, CMake now generates the ``-p`` path prefix
|
* When using :prop_tgt:`AUTOMOC`, the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX`
|
||||||
|
variable or :prop_tgt:`AUTOMOC_PATH_PREFIX` target property may be enabled
|
||||||
|
to generate the ``-p`` path prefix
|
||||||
option for ``moc``. This ensures that ``moc`` output files are identical
|
option for ``moc``. This ensures that ``moc`` output files are identical
|
||||||
on different build setups (given, that the headers compiled by ``moc`` are
|
on different build setups (given, that the headers compiled by ``moc`` are
|
||||||
in an :command:`include directory <target_include_directories>`).
|
in an :command:`include directory <target_include_directories>`).
|
||||||
Also it ensures that ``moc`` output files will compile correctly when the
|
Also it ensures that ``moc`` output files will compile correctly when the
|
||||||
source and/or build directory is a symbolic link.
|
source and/or build directory is a symbolic link.
|
||||||
|
|
||||||
The ``moc`` path prefix generation behavior can be configured by setting
|
|
||||||
the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX` variable and/or
|
|
||||||
:prop_tgt:`AUTOMOC_PATH_PREFIX` target property.
|
|
||||||
|
|
||||||
CTest
|
CTest
|
||||||
-----
|
-----
|
||||||
|
|
||||||
@ -316,3 +314,11 @@ Changes made since CMake 3.16.0 include the following.
|
|||||||
:prop_tgt:`INTERFACE_INCLUDE_DIRECTORIES` target properties.
|
:prop_tgt:`INTERFACE_INCLUDE_DIRECTORIES` target properties.
|
||||||
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
||||||
:prop_tgt:`INTERFACE_COMPILE_OPTIONS` target properties.
|
:prop_tgt:`INTERFACE_COMPILE_OPTIONS` target properties.
|
||||||
|
|
||||||
|
3.16.9
|
||||||
|
------
|
||||||
|
|
||||||
|
* The default value of :variable:`CMAKE_AUTOMOC_PATH_PREFIX` was changed to
|
||||||
|
``OFF`` because this feature can break existing projects that have
|
||||||
|
identically named header files in different include directories.
|
||||||
|
This restores compatibility with behavior of CMake 3.15 and below.
|
||||||
|
@ -346,3 +346,12 @@ Changes made since CMake 3.17.0 include the following.
|
|||||||
:prop_tgt:`INTERFACE_INCLUDE_DIRECTORIES` target properties.
|
:prop_tgt:`INTERFACE_INCLUDE_DIRECTORIES` target properties.
|
||||||
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
||||||
:prop_tgt:`INTERFACE_COMPILE_OPTIONS` target properties.
|
:prop_tgt:`INTERFACE_COMPILE_OPTIONS` target properties.
|
||||||
|
|
||||||
|
3.17.5
|
||||||
|
------
|
||||||
|
|
||||||
|
* The default value of :variable:`CMAKE_AUTOMOC_PATH_PREFIX` was changed to
|
||||||
|
``OFF`` because this feature can break existing projects that have
|
||||||
|
identically named header files in different include directories.
|
||||||
|
This restores compatibility with behavior of CMake 3.15 and below.
|
||||||
|
The default was also changed to ``OFF`` in 3.16.9.
|
||||||
|
@ -265,8 +265,9 @@ Other
|
|||||||
environment variable to customize colors.
|
environment variable to customize colors.
|
||||||
|
|
||||||
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
||||||
is now aware of the availability of C11 features in MSVC 19.27 and above,
|
is now aware of the availability of C11 features in MSVC 19.27 and 19.28,
|
||||||
including support for the ``c_restrict`` feature and the ``-std:c11`` flag.
|
including support for the ``c_restrict``, ``c_static_assert`` features and
|
||||||
|
the ``-std:c11`` flag.
|
||||||
|
|
||||||
Deprecated and Removed Features
|
Deprecated and Removed Features
|
||||||
===============================
|
===============================
|
||||||
@ -351,6 +352,13 @@ Changes made since CMake 3.18.0 include the following.
|
|||||||
``OFF`` because this feature can break existing projects that have
|
``OFF`` because this feature can break existing projects that have
|
||||||
identically named header files in different include directories.
|
identically named header files in different include directories.
|
||||||
This restores compatibility with behavior of CMake 3.15 and below.
|
This restores compatibility with behavior of CMake 3.15 and below.
|
||||||
|
The default was also changed to ``OFF`` in 3.16.9 and 3.17.5.
|
||||||
|
|
||||||
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
||||||
was updated for MSVC 19.27 as mentioned above.
|
was updated for MSVC 19.27 as mentioned above (``c_restrict``).
|
||||||
|
|
||||||
|
3.18.3
|
||||||
|
------
|
||||||
|
|
||||||
|
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
||||||
|
was updated for MSVC 19.28 as mentioned above (``c_static_assert``).
|
||||||
|
@ -72,10 +72,11 @@ if(("x${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_SIMULATE_ID}" STREQUAL "xMSVC" AND
|
|||||||
if("x${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ID}" STREQUAL "xClang")
|
if("x${CMAKE_${_CMAKE_PROCESSING_LANGUAGE}_COMPILER_ID}" STREQUAL "xClang")
|
||||||
find_program(CMAKE_NM NAMES ${_CMAKE_TOOLCHAIN_PREFIX}nm llvm-nm HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
find_program(CMAKE_NM NAMES ${_CMAKE_TOOLCHAIN_PREFIX}nm llvm-nm HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
||||||
set(_CMAKE_ADDITIONAL_LINKER_NAMES "lld-link")
|
set(_CMAKE_ADDITIONAL_LINKER_NAMES "lld-link")
|
||||||
|
set(_CMAKE_ADDITIONAL_AR_NAMES "llvm-lib")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
find_program(CMAKE_LINKER NAMES ${_CMAKE_ADDITIONAL_LINKER_NAMES} link HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
find_program(CMAKE_LINKER NAMES ${_CMAKE_ADDITIONAL_LINKER_NAMES} link HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
||||||
find_program(CMAKE_AR NAMES lib HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
find_program(CMAKE_AR NAMES ${_CMAKE_ADDITIONAL_AR_NAMES} lib HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
||||||
find_program(CMAKE_MT NAMES mt HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
find_program(CMAKE_MT NAMES mt HINTS ${_CMAKE_TOOLCHAIN_LOCATION})
|
||||||
|
|
||||||
list(APPEND _CMAKE_TOOL_VARS LINKER MT)
|
list(APPEND _CMAKE_TOOL_VARS LINKER MT)
|
||||||
|
@ -170,7 +170,7 @@ endif()
|
|||||||
# compile an Objective-C file into an object file
|
# compile an Objective-C file into an object file
|
||||||
if(NOT CMAKE_OBJC_COMPILE_OBJECT)
|
if(NOT CMAKE_OBJC_COMPILE_OBJECT)
|
||||||
set(CMAKE_OBJC_COMPILE_OBJECT
|
set(CMAKE_OBJC_COMPILE_OBJECT
|
||||||
"<CMAKE_OBJC_COMPILER> <DEFINES> <INCLUDES> <FLAGS> -x objective-c -o <OBJECT> -c <SOURCE>")
|
"<CMAKE_OBJC_COMPILER> <DEFINES> <INCLUDES> -x objective-c <FLAGS> -o <OBJECT> -c <SOURCE>")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT CMAKE_OBJC_LINK_EXECUTABLE)
|
if(NOT CMAKE_OBJC_LINK_EXECUTABLE)
|
||||||
|
@ -263,7 +263,7 @@ endif()
|
|||||||
# compile an Objective-C++ file into an object file
|
# compile an Objective-C++ file into an object file
|
||||||
if(NOT CMAKE_OBJCXX_COMPILE_OBJECT)
|
if(NOT CMAKE_OBJCXX_COMPILE_OBJECT)
|
||||||
set(CMAKE_OBJCXX_COMPILE_OBJECT
|
set(CMAKE_OBJCXX_COMPILE_OBJECT
|
||||||
"<CMAKE_OBJCXX_COMPILER> <DEFINES> <INCLUDES> <FLAGS> -x objective-c++ -o <OBJECT> -c <SOURCE>")
|
"<CMAKE_OBJCXX_COMPILER> <DEFINES> <INCLUDES> -x objective-c++ <FLAGS> -o <OBJECT> -c <SOURCE>")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT CMAKE_OBJCXX_LINK_EXECUTABLE)
|
if(NOT CMAKE_OBJCXX_LINK_EXECUTABLE)
|
||||||
|
@ -54,5 +54,4 @@ function(check_c_compiler_flag _flag _var)
|
|||||||
foreach(v IN LISTS _locale_vars)
|
foreach(v IN LISTS _locale_vars)
|
||||||
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
||||||
endforeach()
|
endforeach()
|
||||||
set(${_var} "${${_var}}" PARENT_SCOPE)
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
@ -54,5 +54,4 @@ function(check_cxx_compiler_flag _flag _var)
|
|||||||
foreach(v IN LISTS _locale_vars)
|
foreach(v IN LISTS _locale_vars)
|
||||||
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
||||||
endforeach()
|
endforeach()
|
||||||
set(${_var} "${${_var}}" PARENT_SCOPE)
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
@ -115,11 +115,12 @@ macro(__compiler_armclang lang)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(__CMAKE_ARMClang_USING_armlink)
|
if(__CMAKE_ARMClang_USING_armlink)
|
||||||
|
unset(CMAKE_${lang}_LINKER_WRAPPER_FLAG)
|
||||||
set(__CMAKE_ARMClang_USING_armlink_WRAPPER "")
|
set(__CMAKE_ARMClang_USING_armlink_WRAPPER "")
|
||||||
else()
|
else()
|
||||||
set(__CMAKE_ARMClang_USING_armlink_WRAPPER ${CMAKE_${lang}_LINKER_WRAPPER_FLAG})
|
set(__CMAKE_ARMClang_USING_armlink_WRAPPER "-Xlinker")
|
||||||
endif()
|
endif()
|
||||||
set(CMAKE_${lang}_LINK_EXECUTABLE "<CMAKE_LINKER> <CMAKE_${lang}_LINK_FLAGS> <LINK_FLAGS> <LINK_LIBRARIES> <OBJECTS> -o <TARGET> ${__CMAKE_ARMClang_USING_armlink_WRAPPER} --list <TARGET_BASE>.map")
|
set(CMAKE_${lang}_LINK_EXECUTABLE "<CMAKE_LINKER> <CMAKE_${lang}_LINK_FLAGS> <LINK_FLAGS> <LINK_LIBRARIES> <OBJECTS> -o <TARGET> ${__CMAKE_ARMClang_USING_armlink_WRAPPER} --list=<TARGET_BASE>.map")
|
||||||
set(CMAKE_${lang}_CREATE_STATIC_LIBRARY "<CMAKE_AR> --create -cr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
set(CMAKE_${lang}_CREATE_STATIC_LIBRARY "<CMAKE_AR> --create -cr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
||||||
set(CMAKE_${lang}_ARCHIVE_CREATE "<CMAKE_AR> --create -cr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
set(CMAKE_${lang}_ARCHIVE_CREATE "<CMAKE_AR> --create -cr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
||||||
set(CMAKE_${lang}_RESPONSE_FILE_LINK_FLAG "${__CMAKE_ARMClang_USING_armlink_WRAPPER} --via=")
|
set(CMAKE_${lang}_RESPONSE_FILE_LINK_FLAG "${__CMAKE_ARMClang_USING_armlink_WRAPPER} --via=")
|
||||||
|
@ -10,6 +10,11 @@ set(__COMPILER_CLANG 1)
|
|||||||
|
|
||||||
include(Compiler/CMakeCommonCompilerMacros)
|
include(Compiler/CMakeCommonCompilerMacros)
|
||||||
|
|
||||||
|
set(__pch_header_C "c-header")
|
||||||
|
set(__pch_header_CXX "c++-header")
|
||||||
|
set(__pch_header_OBJC "objective-c-header")
|
||||||
|
set(__pch_header_OBJCXX "objective-c++-header")
|
||||||
|
|
||||||
if("x${CMAKE_C_SIMULATE_ID}" STREQUAL "xMSVC"
|
if("x${CMAKE_C_SIMULATE_ID}" STREQUAL "xMSVC"
|
||||||
OR "x${CMAKE_CXX_SIMULATE_ID}" STREQUAL "xMSVC"
|
OR "x${CMAKE_CXX_SIMULATE_ID}" STREQUAL "xMSVC"
|
||||||
OR "x${CMAKE_Fortran_SIMULATE_ID}" STREQUAL "xMSVC")
|
OR "x${CMAKE_Fortran_SIMULATE_ID}" STREQUAL "xMSVC")
|
||||||
@ -102,7 +107,7 @@ else()
|
|||||||
set(CMAKE_PCH_PROLOGUE "#pragma clang system_header")
|
set(CMAKE_PCH_PROLOGUE "#pragma clang system_header")
|
||||||
endif()
|
endif()
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER> -x ${__pch_header_${lang}})
|
||||||
endmacro()
|
endmacro()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
set(_cmake_oldestSupported "_MSC_VER >= 1600")
|
set(_cmake_oldestSupported "_MSC_VER >= 1600")
|
||||||
|
|
||||||
# Not yet supported:
|
|
||||||
#set(_cmake_feature_test_c_static_assert "")
|
|
||||||
|
|
||||||
set(_cmake_feature_test_c_restrict "_MSC_VER >= 1927")
|
set(_cmake_feature_test_c_restrict "_MSC_VER >= 1927")
|
||||||
|
set(_cmake_feature_test_c_static_assert "_MSC_VER >= 1928")
|
||||||
|
|
||||||
set(_cmake_feature_test_c_variadic_macros "${_cmake_oldestSupported}")
|
set(_cmake_feature_test_c_variadic_macros "${_cmake_oldestSupported}")
|
||||||
set(_cmake_feature_test_c_function_prototypes "${_cmake_oldestSupported}")
|
set(_cmake_feature_test_c_function_prototypes "${_cmake_oldestSupported}")
|
||||||
|
@ -51,6 +51,10 @@ macro(cmake_record_c_compile_features)
|
|||||||
list(APPEND CMAKE_C_COMPILE_FEATURES c_restrict)
|
list(APPEND CMAKE_C_COMPILE_FEATURES c_restrict)
|
||||||
list(APPEND CMAKE_C99_COMPILE_FEATURES c_restrict)
|
list(APPEND CMAKE_C99_COMPILE_FEATURES c_restrict)
|
||||||
endif()
|
endif()
|
||||||
|
if(CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 19.28)
|
||||||
|
list(APPEND CMAKE_C_COMPILE_FEATURES c_static_assert)
|
||||||
|
list(APPEND CMAKE_C11_COMPILE_FEATURES c_static_assert)
|
||||||
|
endif()
|
||||||
set(_result 0) # expected by cmake_determine_compile_features
|
set(_result 0) # expected by cmake_determine_compile_features
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
|
@ -68,20 +68,22 @@ if(UNIX)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
if("x${CMAKE_CUDA_SIMULATE_ID}" STREQUAL "xMSVC")
|
if("x${CMAKE_CUDA_SIMULATE_ID}" STREQUAL "xMSVC")
|
||||||
|
# MSVC requires c++14 as the minimum level
|
||||||
set(CMAKE_CUDA03_STANDARD_COMPILE_OPTION "")
|
set(CMAKE_CUDA03_STANDARD_COMPILE_OPTION "")
|
||||||
set(CMAKE_CUDA03_EXTENSION_COMPILE_OPTION "")
|
set(CMAKE_CUDA03_EXTENSION_COMPILE_OPTION "")
|
||||||
|
|
||||||
|
# MSVC requires c++14 as the minimum level
|
||||||
set(CMAKE_CUDA11_STANDARD_COMPILE_OPTION "")
|
set(CMAKE_CUDA11_STANDARD_COMPILE_OPTION "")
|
||||||
set(CMAKE_CUDA11_EXTENSION_COMPILE_OPTION "")
|
set(CMAKE_CUDA11_EXTENSION_COMPILE_OPTION "")
|
||||||
|
|
||||||
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 9.0)
|
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 9.0)
|
||||||
set(CMAKE_CUDA14_STANDARD_COMPILE_OPTION "")
|
set(CMAKE_CUDA14_STANDARD_COMPILE_OPTION "-std=c++14")
|
||||||
set(CMAKE_CUDA14_EXTENSION_COMPILE_OPTION "")
|
set(CMAKE_CUDA14_EXTENSION_COMPILE_OPTION "-std=c++14")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 11.0)
|
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 11.0)
|
||||||
set(CMAKE_CUDA17_STANDARD_COMPILE_OPTION "")
|
set(CMAKE_CUDA17_STANDARD_COMPILE_OPTION "-std=c++17")
|
||||||
set(CMAKE_CUDA17_EXTENSION_COMPILE_OPTION "")
|
set(CMAKE_CUDA17_EXTENSION_COMPILE_OPTION "-std=c++17")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
else()
|
else()
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
# ARCH_AND_PTX : NAME | NUM.NUM | NUM.NUM(NUM.NUM) | NUM.NUM+PTX
|
# ARCH_AND_PTX : NAME | NUM.NUM | NUM.NUM(NUM.NUM) | NUM.NUM+PTX
|
||||||
# NAME: Fermi Kepler Maxwell Kepler+Tegra Kepler+Tesla Maxwell+Tegra Pascal Volta Turing Ampere
|
# NAME: Fermi Kepler Maxwell Kepler+Tegra Kepler+Tesla Maxwell+Tegra Pascal Volta Turing Ampere
|
||||||
# NUM: Any number. Only those pairs are currently accepted by NVCC though:
|
# NUM: Any number. Only those pairs are currently accepted by NVCC though:
|
||||||
# 2.0 2.1 3.0 3.2 3.5 3.7 5.0 5.2 5.3 6.0 6.2 7.0 7.2 7.5 8.0
|
# 2.0 2.1 3.0 3.2 3.5 3.7 5.0 5.2 5.3 6.0 6.2 7.0 7.2 7.5 8.0 8.6
|
||||||
# Returns LIST of flags to be added to CUDA_NVCC_FLAGS in ${out_variable}
|
# Returns LIST of flags to be added to CUDA_NVCC_FLAGS in ${out_variable}
|
||||||
# Additionally, sets ${out_variable}_readable to the resulting numeric list
|
# Additionally, sets ${out_variable}_readable to the resulting numeric list
|
||||||
# Example:
|
# Example:
|
||||||
@ -82,16 +82,26 @@ if(CUDA_VERSION VERSION_GREATER_EQUAL "10.0")
|
|||||||
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "7.5")
|
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "7.5")
|
||||||
|
|
||||||
if(CUDA_VERSION VERSION_LESS "11.0")
|
if(CUDA_VERSION VERSION_LESS "11.0")
|
||||||
set(CUDA_LIMIT_GPU_ARCHITECTURE "8.0")
|
|
||||||
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "7.5+PTX")
|
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "7.5+PTX")
|
||||||
|
set(CUDA_LIMIT_GPU_ARCHITECTURE "8.0")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(CUDA_VERSION VERSION_GREATER_EQUAL "11.0")
|
if(CUDA_VERSION VERSION_GREATER_EQUAL "11.0")
|
||||||
list(APPEND CUDA_KNOWN_GPU_ARCHITECTURES "Ampere")
|
list(APPEND CUDA_KNOWN_GPU_ARCHITECTURES "Ampere")
|
||||||
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "8.0" "8.0+PTX")
|
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "8.0")
|
||||||
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "8.0")
|
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "8.0")
|
||||||
|
|
||||||
|
if(CUDA_VERSION VERSION_LESS "11.1")
|
||||||
|
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "8.0+PTX")
|
||||||
|
set(CUDA_LIMIT_GPU_ARCHITECTURE "8.6")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(CUDA_VERSION VERSION_GREATER_EQUAL "11.1")
|
||||||
|
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "8.6" "8.6+PTX")
|
||||||
|
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "8.6")
|
||||||
|
|
||||||
if(CUDA_VERSION VERSION_LESS "12.0")
|
if(CUDA_VERSION VERSION_LESS "12.0")
|
||||||
set(CUDA_LIMIT_GPU_ARCHITECTURE "9.0")
|
set(CUDA_LIMIT_GPU_ARCHITECTURE "9.0")
|
||||||
endif()
|
endif()
|
||||||
|
@ -59,6 +59,8 @@ macro(java_append_library_directories _var)
|
|||||||
endif()
|
endif()
|
||||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^i.86$")
|
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^i.86$")
|
||||||
set(_java_libarch "i386")
|
set(_java_libarch "i386")
|
||||||
|
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^aarch64")
|
||||||
|
set(_java_libarch "arm64" "aarch64")
|
||||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^alpha")
|
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^alpha")
|
||||||
set(_java_libarch "alpha")
|
set(_java_libarch "alpha")
|
||||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^arm")
|
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^arm")
|
||||||
|
@ -241,6 +241,7 @@ if(NOT MATLAB_ADDITIONAL_VERSIONS)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(MATLAB_VERSIONS_MAPPING
|
set(MATLAB_VERSIONS_MAPPING
|
||||||
|
"R2020b=9.9"
|
||||||
"R2020a=9.8"
|
"R2020a=9.8"
|
||||||
"R2019b=9.7"
|
"R2019b=9.7"
|
||||||
"R2019a=9.6"
|
"R2019a=9.6"
|
||||||
|
@ -9,6 +9,9 @@
|
|||||||
# Initial configuration
|
# Initial configuration
|
||||||
#
|
#
|
||||||
|
|
||||||
|
cmake_policy(PUSH)
|
||||||
|
# numbers and boolean constants
|
||||||
|
cmake_policy (SET CMP0012 NEW)
|
||||||
# IN_LIST operator
|
# IN_LIST operator
|
||||||
cmake_policy (SET CMP0057 NEW)
|
cmake_policy (SET CMP0057 NEW)
|
||||||
|
|
||||||
@ -44,7 +47,6 @@ macro (_PYTHON_DISPLAY_FAILURE _PYTHON_MSG)
|
|||||||
set (${_PYTHON_PREFIX}_FOUND FALSE)
|
set (${_PYTHON_PREFIX}_FOUND FALSE)
|
||||||
string (TOUPPER "${_PYTHON_PREFIX}" _${_PYTHON_PREFIX}_UPPER_PREFIX)
|
string (TOUPPER "${_PYTHON_PREFIX}" _${_PYTHON_PREFIX}_UPPER_PREFIX)
|
||||||
set (${_PYTHON_UPPER_PREFIX}_FOUND FALSE)
|
set (${_PYTHON_UPPER_PREFIX}_FOUND FALSE)
|
||||||
return()
|
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
|
|
||||||
@ -607,14 +609,24 @@ function (_PYTHON_GET_VERSION)
|
|||||||
# ABI not used on Windows
|
# ABI not used on Windows
|
||||||
set (abi "")
|
set (abi "")
|
||||||
else()
|
else()
|
||||||
if (config MATCHES "#[ ]*define[ ]+Py_DEBUG[ ]+1")
|
if (NOT config)
|
||||||
string (APPEND abi "d")
|
# pyconfig.h can be a wrapper to a platform specific pyconfig.h
|
||||||
endif()
|
# In this case, try to identify ABI from include directory
|
||||||
if (config MATCHES "#[ ]*define[ ]+WITH_PYMALLOC[ ]+1")
|
if (_${_PYTHON_PREFIX}_INCLUDE_DIR MATCHES "python${version_major}\\.${version_minor}+([dmu]*)")
|
||||||
string (APPEND abi "m")
|
set (abi "${CMAKE_MATCH_1}")
|
||||||
endif()
|
else()
|
||||||
if (config MATCHES "#[ ]*define[ ]+Py_UNICODE_SIZE[ ]+4")
|
set (abi "")
|
||||||
string (APPEND abi "u")
|
endif()
|
||||||
|
else()
|
||||||
|
if (config MATCHES "#[ ]*define[ ]+Py_DEBUG[ ]+1")
|
||||||
|
string (APPEND abi "d")
|
||||||
|
endif()
|
||||||
|
if (config MATCHES "#[ ]*define[ ]+WITH_PYMALLOC[ ]+1")
|
||||||
|
string (APPEND abi "m")
|
||||||
|
endif()
|
||||||
|
if (config MATCHES "#[ ]*define[ ]+Py_UNICODE_SIZE[ ]+4")
|
||||||
|
string (APPEND abi "u")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
set (${_PGV_PREFIX}ABI "${abi}" PARENT_SCOPE)
|
set (${_PGV_PREFIX}ABI "${abi}" PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
@ -1012,6 +1024,9 @@ endfunction()
|
|||||||
if (DEFINED ${_PYTHON_PREFIX}_FIND_VERSION_MAJOR
|
if (DEFINED ${_PYTHON_PREFIX}_FIND_VERSION_MAJOR
|
||||||
AND NOT ${_PYTHON_PREFIX}_FIND_VERSION_MAJOR VERSION_EQUAL _${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR)
|
AND NOT ${_PYTHON_PREFIX}_FIND_VERSION_MAJOR VERSION_EQUAL _${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR)
|
||||||
_python_display_failure ("Could NOT find ${_PYTHON_PREFIX}: Wrong major version specified is \"${${_PYTHON_PREFIX}_FIND_VERSION_MAJOR}\", but expected major version is \"${_${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR}\"")
|
_python_display_failure ("Could NOT find ${_PYTHON_PREFIX}: Wrong major version specified is \"${${_PYTHON_PREFIX}_FIND_VERSION_MAJOR}\", but expected major version is \"${_${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR}\"")
|
||||||
|
|
||||||
|
cmake_policy(POP)
|
||||||
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
@ -2952,6 +2967,9 @@ endif()
|
|||||||
if (${_PYTHON_PREFIX}_VERSION_MAJOR AND
|
if (${_PYTHON_PREFIX}_VERSION_MAJOR AND
|
||||||
NOT ${_PYTHON_PREFIX}_VERSION_MAJOR VERSION_EQUAL _${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR)
|
NOT ${_PYTHON_PREFIX}_VERSION_MAJOR VERSION_EQUAL _${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR)
|
||||||
_python_display_failure ("Could NOT find ${_PYTHON_PREFIX}: Found unsuitable major version \"${${_PYTHON_PREFIX}_VERSION_MAJOR}\", but required major version is exact version \"${_${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR}\"")
|
_python_display_failure ("Could NOT find ${_PYTHON_PREFIX}: Found unsuitable major version \"${${_PYTHON_PREFIX}_VERSION_MAJOR}\", but required major version is exact version \"${_${_PYTHON_PREFIX}_REQUIRED_VERSION_MAJOR}\"")
|
||||||
|
|
||||||
|
cmake_policy(POP)
|
||||||
|
return()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
unset (_${_PYTHON_PREFIX}_REASON_FAILURE)
|
unset (_${_PYTHON_PREFIX}_REASON_FAILURE)
|
||||||
@ -3160,3 +3178,5 @@ if (DEFINED _${_PYTHON_PREFIX}_CMAKE_FIND_FRAMEWORK)
|
|||||||
else()
|
else()
|
||||||
unset (CMAKE_FIND_FRAMEWORK)
|
unset (CMAKE_FIND_FRAMEWORK)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
cmake_policy(POP)
|
||||||
|
@ -8,6 +8,11 @@ if(__WINDOWS_CLANG)
|
|||||||
endif()
|
endif()
|
||||||
set(__WINDOWS_CLANG 1)
|
set(__WINDOWS_CLANG 1)
|
||||||
|
|
||||||
|
set(__pch_header_C "c-header")
|
||||||
|
set(__pch_header_CXX "c++-header")
|
||||||
|
set(__pch_header_OBJC "objective-c-header")
|
||||||
|
set(__pch_header_OBJCXX "objective-c++-header")
|
||||||
|
|
||||||
macro(__windows_compiler_clang_gnu lang)
|
macro(__windows_compiler_clang_gnu lang)
|
||||||
set(CMAKE_LIBRARY_PATH_FLAG "-L")
|
set(CMAKE_LIBRARY_PATH_FLAG "-L")
|
||||||
set(CMAKE_LINK_LIBRARY_FLAG "-l")
|
set(CMAKE_LINK_LIBRARY_FLAG "-l")
|
||||||
@ -87,7 +92,7 @@ macro(__windows_compiler_clang_gnu lang)
|
|||||||
set(CMAKE_PCH_EXTENSION .pch)
|
set(CMAKE_PCH_EXTENSION .pch)
|
||||||
set(CMAKE_PCH_PROLOGUE "#pragma clang system_header")
|
set(CMAKE_PCH_PROLOGUE "#pragma clang system_header")
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER> -x ${__pch_header_${lang}})
|
||||||
|
|
||||||
unset(__ADDED_FLAGS)
|
unset(__ADDED_FLAGS)
|
||||||
unset(__ADDED_FLAGS_DEBUG)
|
unset(__ADDED_FLAGS_DEBUG)
|
||||||
|
@ -10,6 +10,11 @@ set(__WINDOWS_EMBARCADERO 1)
|
|||||||
|
|
||||||
set(BORLAND 1)
|
set(BORLAND 1)
|
||||||
|
|
||||||
|
set(__pch_header_C "c-header")
|
||||||
|
set(__pch_header_CXX "c++-header")
|
||||||
|
set(__pch_header_OBJC "objective-c-header")
|
||||||
|
set(__pch_header_OBJCXX "objective-c++-header")
|
||||||
|
|
||||||
if("${CMAKE_${_lang}_COMPILER_VERSION}" VERSION_LESS 6.30)
|
if("${CMAKE_${_lang}_COMPILER_VERSION}" VERSION_LESS 6.30)
|
||||||
# Borland target type flags (bcc32 -h -t):
|
# Borland target type flags (bcc32 -h -t):
|
||||||
set(_tW "-tW") # -tW GUI App (implies -U__CONSOLE__)
|
set(_tW "-tW") # -tW GUI App (implies -U__CONSOLE__)
|
||||||
@ -123,7 +128,7 @@ macro(__embarcadero_language lang)
|
|||||||
if (EMBARCADERO)
|
if (EMBARCADERO)
|
||||||
set(CMAKE_PCH_EXTENSION .pch)
|
set(CMAKE_PCH_EXTENSION .pch)
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_USE_PCH -Xclang -include-pch -Xclang <PCH_FILE> -Xclang -include -Xclang <PCH_HEADER>)
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER>)
|
set(CMAKE_${lang}_COMPILE_OPTIONS_CREATE_PCH -Xclang -emit-pch -Xclang -include -Xclang <PCH_HEADER> -x ${__pch_header_${lang}})
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Initial configuration flags.
|
# Initial configuration flags.
|
||||||
|
@ -496,7 +496,8 @@ function(SWIG_ADD_SOURCE_TO_MODULE name outfiles infile)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
if (SWIG_MODULE_${name}_LANGUAGE STREQUAL "PYTHON" AND NOT SWIG_MODULE_${name}_NOPROXY)
|
if (SWIG_MODULE_${name}_LANGUAGE STREQUAL "PYTHON" AND NOT SWIG_MODULE_${name}_NOPROXY)
|
||||||
if(NOT ("-interface" IN_LIST swig_source_file_flags OR "-interface" IN_LIST SWIG_MODULE_${name}_EXTRA_FLAGS))
|
if(SWIG_USE_INTERFACE AND
|
||||||
|
NOT ("-interface" IN_LIST swig_source_file_flags OR "-interface" IN_LIST SWIG_MODULE_${name}_EXTRA_FLAGS))
|
||||||
# This makes sure that the name used in the proxy code
|
# This makes sure that the name used in the proxy code
|
||||||
# matches the library name created by CMake
|
# matches the library name created by CMake
|
||||||
list (APPEND SWIG_MODULE_${name}_EXTRA_FLAGS "-interface" "$<TARGET_FILE_PREFIX:${target_name}>$<TARGET_FILE_BASE_NAME:${target_name}>")
|
list (APPEND SWIG_MODULE_${name}_EXTRA_FLAGS "-interface" "$<TARGET_FILE_PREFIX:${target_name}>$<TARGET_FILE_BASE_NAME:${target_name}>")
|
||||||
@ -724,6 +725,13 @@ function(SWIG_ADD_LIBRARY name)
|
|||||||
|
|
||||||
set(swig_generated_sources)
|
set(swig_generated_sources)
|
||||||
set(swig_generated_timestamps)
|
set(swig_generated_timestamps)
|
||||||
|
list(LENGTH swig_dot_i_sources swig_sources_count)
|
||||||
|
if (swig_sources_count GREATER "1")
|
||||||
|
# option -interface cannot be used
|
||||||
|
set(SWIG_USE_INTERFACE FALSE)
|
||||||
|
else()
|
||||||
|
set(SWIG_USE_INTERFACE TRUE)
|
||||||
|
endif()
|
||||||
foreach(swig_it IN LISTS swig_dot_i_sources)
|
foreach(swig_it IN LISTS swig_dot_i_sources)
|
||||||
SWIG_ADD_SOURCE_TO_MODULE(${name} swig_generated_source "${swig_it}")
|
SWIG_ADD_SOURCE_TO_MODULE(${name} swig_generated_source "${swig_it}")
|
||||||
list (APPEND swig_generated_sources "${swig_generated_source}")
|
list (APPEND swig_generated_sources "${swig_generated_source}")
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# CMake version number components.
|
# CMake version number components.
|
||||||
set(CMake_VERSION_MAJOR 3)
|
set(CMake_VERSION_MAJOR 3)
|
||||||
set(CMake_VERSION_MINOR 18)
|
set(CMake_VERSION_MINOR 18)
|
||||||
set(CMake_VERSION_PATCH 2)
|
set(CMake_VERSION_PATCH 4)
|
||||||
#set(CMake_VERSION_RC 0)
|
#set(CMake_VERSION_RC 0)
|
||||||
set(CMake_VERSION_IS_DIRTY 0)
|
set(CMake_VERSION_IS_DIRTY 0)
|
||||||
|
|
||||||
@ -21,7 +21,7 @@ endif()
|
|||||||
|
|
||||||
if(NOT CMake_VERSION_NO_GIT)
|
if(NOT CMake_VERSION_NO_GIT)
|
||||||
# If this source was exported by 'git archive', use its commit info.
|
# If this source was exported by 'git archive', use its commit info.
|
||||||
set(git_info [==[aaa5eab410 CMake 3.18.2]==])
|
set(git_info [==[3cc3d42aba CMake 3.18.4]==])
|
||||||
|
|
||||||
# Otherwise, try to identify the current development source version.
|
# Otherwise, try to identify the current development source version.
|
||||||
if(NOT git_info MATCHES "^([0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]?[0-9a-f]?)[0-9a-f]* "
|
if(NOT git_info MATCHES "^([0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f][0-9a-f]?[0-9a-f]?)[0-9a-f]* "
|
||||||
|
@ -365,6 +365,12 @@ bool TryParseInteger(cmExecutionStatus& status, const std::string& str, int& i)
|
|||||||
status.SetError(e.str());
|
status.SetError(e.str());
|
||||||
cmSystemTools::SetFatalErrorOccured();
|
cmSystemTools::SetFatalErrorOccured();
|
||||||
return false;
|
return false;
|
||||||
|
} catch (std::out_of_range&) {
|
||||||
|
std::ostringstream e;
|
||||||
|
e << "Integer out of range: '" << str << "'";
|
||||||
|
status.SetError(e.str());
|
||||||
|
cmSystemTools::SetFatalErrorOccured();
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -1611,6 +1611,8 @@ bool cmGlobalGenerator::AddAutomaticSources()
|
|||||||
{
|
{
|
||||||
for (const auto& lg : this->LocalGenerators) {
|
for (const auto& lg : this->LocalGenerators) {
|
||||||
lg->CreateEvaluationFileOutputs();
|
lg->CreateEvaluationFileOutputs();
|
||||||
|
}
|
||||||
|
for (const auto& lg : this->LocalGenerators) {
|
||||||
for (const auto& gt : lg->GetGeneratorTargets()) {
|
for (const auto& gt : lg->GetGeneratorTargets()) {
|
||||||
if (gt->GetType() == cmStateEnums::INTERFACE_LIBRARY ||
|
if (gt->GetType() == cmStateEnums::INTERFACE_LIBRARY ||
|
||||||
gt->GetType() == cmStateEnums::UTILITY ||
|
gt->GetType() == cmStateEnums::UTILITY ||
|
||||||
|
@ -1170,7 +1170,9 @@ void cmGlobalNinjaGenerator::AppendTargetDependsClosure(
|
|||||||
|
|
||||||
for (auto const& dep_target : this->GetTargetDirectDepends(target)) {
|
for (auto const& dep_target : this->GetTargetDirectDepends(target)) {
|
||||||
if (dep_target->GetType() == cmStateEnums::INTERFACE_LIBRARY ||
|
if (dep_target->GetType() == cmStateEnums::INTERFACE_LIBRARY ||
|
||||||
(this->EnableCrossConfigBuild() && !dep_target.IsCross())) {
|
(target->GetType() != cmStateEnums::UTILITY &&
|
||||||
|
dep_target->GetType() != cmStateEnums::UTILITY &&
|
||||||
|
this->EnableCrossConfigBuild() && !dep_target.IsCross())) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1863,6 +1865,7 @@ void cmGlobalNinjaGenerator::WriteTargetClean(std::ostream& os)
|
|||||||
byproducts.push_back(
|
byproducts.push_back(
|
||||||
this->BuildAlias(GetByproductsForCleanTargetName(), config));
|
this->BuildAlias(GetByproductsForCleanTargetName(), config));
|
||||||
}
|
}
|
||||||
|
byproducts.emplace_back(GetByproductsForCleanTargetName());
|
||||||
build.Variables["TARGETS"] = cmJoin(byproducts, " ");
|
build.Variables["TARGETS"] = cmJoin(byproducts, " ");
|
||||||
|
|
||||||
for (auto const& fileConfig : configs) {
|
for (auto const& fileConfig : configs) {
|
||||||
|
@ -2682,17 +2682,29 @@ void cmLocalGenerator::AddPchDependencies(cmGeneratorTarget* target)
|
|||||||
this->Makefile->GetSafeDefinition(
|
this->Makefile->GetSafeDefinition(
|
||||||
cmStrCat("CMAKE_", lang, "_FLAGS_", configUpper));
|
cmStrCat("CMAKE_", lang, "_FLAGS_", configUpper));
|
||||||
|
|
||||||
|
bool editAndContinueDebugInfo =
|
||||||
|
langFlags.find("/ZI") != std::string::npos ||
|
||||||
|
langFlags.find("-ZI") != std::string::npos;
|
||||||
|
|
||||||
|
bool enableDebuggingInformation =
|
||||||
|
langFlags.find("/Zi") != std::string::npos ||
|
||||||
|
langFlags.find("-Zi") != std::string::npos;
|
||||||
|
|
||||||
// MSVC 2008 is producing both .pdb and .idb files with /Zi.
|
// MSVC 2008 is producing both .pdb and .idb files with /Zi.
|
||||||
if ((langFlags.find("/ZI") != std::string::npos ||
|
bool msvc2008OrLess =
|
||||||
langFlags.find("-ZI") != std::string::npos) ||
|
cmSystemTools::VersionCompare(
|
||||||
(cmSystemTools::VersionCompare(cmSystemTools::OP_LESS,
|
cmSystemTools::OP_LESS, compilerVersion.c_str(), "16.0") &&
|
||||||
compilerVersion.c_str(),
|
compilerId == "MSVC";
|
||||||
"16.0") &&
|
// but not when used via toolset -Tv90
|
||||||
compilerId == "MSVC")) {
|
if (this->Makefile->GetSafeDefinition(
|
||||||
|
"CMAKE_VS_PLATFORM_TOOLSET") == "v90") {
|
||||||
|
msvc2008OrLess = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (editAndContinueDebugInfo || msvc2008OrLess) {
|
||||||
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
||||||
{ ".pdb", ".idb" });
|
{ ".pdb", ".idb" });
|
||||||
} else if ((langFlags.find("/Zi") != std::string::npos ||
|
} else if (enableDebuggingInformation) {
|
||||||
langFlags.find("-Zi") != std::string::npos)) {
|
|
||||||
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
||||||
{ ".pdb" });
|
{ ".pdb" });
|
||||||
}
|
}
|
||||||
|
@ -100,6 +100,8 @@ void cmNinjaUtilityTargetGenerator::Generate(const std::string& config)
|
|||||||
if (genTarget->Target->GetType() != cmStateEnums::GLOBAL_TARGET) {
|
if (genTarget->Target->GetType() != cmStateEnums::GLOBAL_TARGET) {
|
||||||
lg->AppendTargetOutputs(genTarget, gg->GetByproductsForCleanTarget(),
|
lg->AppendTargetOutputs(genTarget, gg->GetByproductsForCleanTarget(),
|
||||||
config);
|
config);
|
||||||
|
std::copy(util_outputs.begin(), util_outputs.end(),
|
||||||
|
std::back_inserter(gg->GetByproductsForCleanTarget()));
|
||||||
}
|
}
|
||||||
lg->AppendTargetDepends(genTarget, deps, config, config);
|
lg->AppendTargetDepends(genTarget, deps, config, config);
|
||||||
|
|
||||||
|
@ -1224,9 +1224,13 @@ bool cmQtAutoGenInitializer::InitAutogenTarget()
|
|||||||
|
|
||||||
if (this->Moc.ExecutableTarget != nullptr) {
|
if (this->Moc.ExecutableTarget != nullptr) {
|
||||||
dependencies.push_back(this->Moc.ExecutableTarget->Target->GetName());
|
dependencies.push_back(this->Moc.ExecutableTarget->Target->GetName());
|
||||||
|
} else if (!this->Moc.Executable.empty()) {
|
||||||
|
dependencies.push_back(this->Moc.Executable);
|
||||||
}
|
}
|
||||||
if (this->Uic.ExecutableTarget != nullptr) {
|
if (this->Uic.ExecutableTarget != nullptr) {
|
||||||
dependencies.push_back(this->Uic.ExecutableTarget->Target->GetName());
|
dependencies.push_back(this->Uic.ExecutableTarget->Target->GetName());
|
||||||
|
} else if (!this->Uic.Executable.empty()) {
|
||||||
|
dependencies.push_back(this->Uic.Executable);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Create the custom command that outputs the timestamp file.
|
// Create the custom command that outputs the timestamp file.
|
||||||
@ -1514,6 +1518,7 @@ bool cmQtAutoGenInitializer::SetupWriteAutogenInfo()
|
|||||||
info.SetConfig("PARSE_CACHE_FILE", this->AutogenTarget.ParseCacheFile);
|
info.SetConfig("PARSE_CACHE_FILE", this->AutogenTarget.ParseCacheFile);
|
||||||
info.Set("DEP_FILE", this->AutogenTarget.DepFile);
|
info.Set("DEP_FILE", this->AutogenTarget.DepFile);
|
||||||
info.Set("DEP_FILE_RULE_NAME", this->AutogenTarget.DepFileRuleName);
|
info.Set("DEP_FILE_RULE_NAME", this->AutogenTarget.DepFileRuleName);
|
||||||
|
info.SetArray("CMAKE_LIST_FILES", this->Makefile->GetListFiles());
|
||||||
info.SetArray("HEADER_EXTENSIONS",
|
info.SetArray("HEADER_EXTENSIONS",
|
||||||
this->Makefile->GetCMakeInstance()->GetHeaderExtensions());
|
this->Makefile->GetCMakeInstance()->GetHeaderExtensions());
|
||||||
info.SetArrayArray(
|
info.SetArrayArray(
|
||||||
|
@ -184,6 +184,7 @@ public:
|
|||||||
std::string DepFile;
|
std::string DepFile;
|
||||||
std::string DepFileRuleName;
|
std::string DepFileRuleName;
|
||||||
std::vector<std::string> HeaderExtensions;
|
std::vector<std::string> HeaderExtensions;
|
||||||
|
std::vector<std::string> ListFiles;
|
||||||
};
|
};
|
||||||
|
|
||||||
/** Shared common variables. */
|
/** Shared common variables. */
|
||||||
@ -191,7 +192,7 @@ public:
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
// -- Parse Cache
|
// -- Parse Cache
|
||||||
bool ParseCacheChanged = false;
|
std::atomic<bool> ParseCacheChanged = ATOMIC_VAR_INIT(false);
|
||||||
cmFileTime ParseCacheTime;
|
cmFileTime ParseCacheTime;
|
||||||
ParseCacheT ParseCache;
|
ParseCacheT ParseCache;
|
||||||
|
|
||||||
@ -1776,16 +1777,24 @@ bool cmQtAutoMocUicT::JobProbeDepsMocT::Probe(MappingT const& mapping,
|
|||||||
{
|
{
|
||||||
// Check dependency timestamps
|
// Check dependency timestamps
|
||||||
std::string const sourceDir = SubDirPrefix(sourceFile);
|
std::string const sourceDir = SubDirPrefix(sourceFile);
|
||||||
for (std::string const& dep : mapping.SourceFile->ParseData->Moc.Depends) {
|
auto& dependencies = mapping.SourceFile->ParseData->Moc.Depends;
|
||||||
|
for (auto it = dependencies.begin(); it != dependencies.end(); ++it) {
|
||||||
|
auto& dep = *it;
|
||||||
|
|
||||||
// Find dependency file
|
// Find dependency file
|
||||||
auto const depMatch = FindDependency(sourceDir, dep);
|
auto const depMatch = FindDependency(sourceDir, dep);
|
||||||
if (depMatch.first.empty()) {
|
if (depMatch.first.empty()) {
|
||||||
Log().Warning(GenT::MOC,
|
if (reason != nullptr) {
|
||||||
cmStrCat(MessagePath(sourceFile), " depends on ",
|
*reason =
|
||||||
MessagePath(dep),
|
cmStrCat("Generating ", MessagePath(outputFile), " from ",
|
||||||
" but the file does not exist."));
|
MessagePath(sourceFile), ", because its dependency ",
|
||||||
continue;
|
MessagePath(dep), " vanished.");
|
||||||
|
}
|
||||||
|
dependencies.erase(it);
|
||||||
|
BaseEval().ParseCacheChanged = true;
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test if dependency file is older
|
// Test if dependency file is older
|
||||||
if (outputFileTime.Older(depMatch.second)) {
|
if (outputFileTime.Older(depMatch.second)) {
|
||||||
if (reason != nullptr) {
|
if (reason != nullptr) {
|
||||||
@ -2176,7 +2185,7 @@ void cmQtAutoMocUicT::JobDepFilesMergeT::Process()
|
|||||||
return dependenciesFromDepFile(f.c_str());
|
return dependenciesFromDepFile(f.c_str());
|
||||||
};
|
};
|
||||||
|
|
||||||
std::vector<std::string> dependencies;
|
std::vector<std::string> dependencies = BaseConst().ListFiles;
|
||||||
ParseCacheT& parseCache = BaseEval().ParseCache;
|
ParseCacheT& parseCache = BaseEval().ParseCache;
|
||||||
auto processMappingEntry = [&](const MappingMapT::value_type& m) {
|
auto processMappingEntry = [&](const MappingMapT::value_type& m) {
|
||||||
auto cacheEntry = parseCache.GetOrInsert(m.first);
|
auto cacheEntry = parseCache.GetOrInsert(m.first);
|
||||||
@ -2257,6 +2266,7 @@ bool cmQtAutoMocUicT::InitFromInfo(InfoT const& info)
|
|||||||
!info.GetString("DEP_FILE_RULE_NAME", BaseConst_.DepFileRuleName,
|
!info.GetString("DEP_FILE_RULE_NAME", BaseConst_.DepFileRuleName,
|
||||||
false) ||
|
false) ||
|
||||||
!info.GetStringConfig("SETTINGS_FILE", SettingsFile_, true) ||
|
!info.GetStringConfig("SETTINGS_FILE", SettingsFile_, true) ||
|
||||||
|
!info.GetArray("CMAKE_LIST_FILES", BaseConst_.ListFiles, true) ||
|
||||||
!info.GetArray("HEADER_EXTENSIONS", BaseConst_.HeaderExtensions, true) ||
|
!info.GetArray("HEADER_EXTENSIONS", BaseConst_.HeaderExtensions, true) ||
|
||||||
!info.GetString("QT_MOC_EXECUTABLE", MocConst_.Executable, false) ||
|
!info.GetString("QT_MOC_EXECUTABLE", MocConst_.Executable, false) ||
|
||||||
!info.GetString("QT_UIC_EXECUTABLE", UicConst_.Executable, false)) {
|
!info.GetString("QT_UIC_EXECUTABLE", UicConst_.Executable, false)) {
|
||||||
|
@ -4927,6 +4927,7 @@ std::string cmVisualStudio10TargetGenerator::GetCSharpSourceLink(
|
|||||||
// for this file exists, otherwise we check if the path relative to current
|
// for this file exists, otherwise we check if the path relative to current
|
||||||
// source- or binary-dir is used within the link and return that
|
// source- or binary-dir is used within the link and return that
|
||||||
std::string link;
|
std::string link;
|
||||||
|
std::string sourceGroupedFile;
|
||||||
std::string const& fullFileName = source->GetFullPath();
|
std::string const& fullFileName = source->GetFullPath();
|
||||||
std::string const& srcDir = this->Makefile->GetCurrentSourceDirectory();
|
std::string const& srcDir = this->Makefile->GetCurrentSourceDirectory();
|
||||||
std::string const& binDir = this->Makefile->GetCurrentBinaryDirectory();
|
std::string const& binDir = this->Makefile->GetCurrentBinaryDirectory();
|
||||||
@ -4936,8 +4937,14 @@ std::string cmVisualStudio10TargetGenerator::GetCSharpSourceLink(
|
|||||||
cmSourceGroup* sourceGroup =
|
cmSourceGroup* sourceGroup =
|
||||||
this->Makefile->FindSourceGroup(fullFileName, sourceGroups);
|
this->Makefile->FindSourceGroup(fullFileName, sourceGroups);
|
||||||
if (sourceGroup && !sourceGroup->GetFullName().empty()) {
|
if (sourceGroup && !sourceGroup->GetFullName().empty()) {
|
||||||
link = sourceGroup->GetFullName() + "/" +
|
sourceGroupedFile = sourceGroup->GetFullName() + "/" +
|
||||||
cmsys::SystemTools::GetFilenameName(fullFileName);
|
cmsys::SystemTools::GetFilenameName(fullFileName);
|
||||||
|
cmsys::SystemTools::ConvertToUnixSlashes(sourceGroupedFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!sourceGroupedFile.empty() &&
|
||||||
|
cmHasSuffix(fullFileName, sourceGroupedFile)) {
|
||||||
|
link = sourceGroupedFile;
|
||||||
} else if (cmHasPrefix(fullFileName, srcDir)) {
|
} else if (cmHasPrefix(fullFileName, srcDir)) {
|
||||||
link = fullFileName.substr(srcDir.length() + 1);
|
link = fullFileName.substr(srcDir.length() + 1);
|
||||||
} else if (cmHasPrefix(fullFileName, binDir)) {
|
} else if (cmHasPrefix(fullFileName, binDir)) {
|
||||||
|
@ -454,6 +454,20 @@
|
|||||||
"value": "stdcpplatest",
|
"value": "stdcpplatest",
|
||||||
"flags": []
|
"flags": []
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "LanguageStandard_C",
|
||||||
|
"switch": "std:c11",
|
||||||
|
"comment": "ISO C11 Standard",
|
||||||
|
"value": "stdc11",
|
||||||
|
"flags": []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "LanguageStandard_C",
|
||||||
|
"switch": "std:c17",
|
||||||
|
"comment": "ISO C17 (2018) Standard",
|
||||||
|
"value": "stdc17",
|
||||||
|
"flags": []
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "PrecompiledHeader",
|
"name": "PrecompiledHeader",
|
||||||
"switch": "Yc",
|
"switch": "Yc",
|
||||||
|
@ -2,3 +2,4 @@ ADD_TEST_MACRO(ObjCXX.ObjC++ ObjC++)
|
|||||||
ADD_TEST_MACRO(ObjCXX.simple-build-test simple-build-test)
|
ADD_TEST_MACRO(ObjCXX.simple-build-test simple-build-test)
|
||||||
ADD_TEST_MACRO(ObjCXX.cxx-file-extension-test cxx-file-extension-test)
|
ADD_TEST_MACRO(ObjCXX.cxx-file-extension-test cxx-file-extension-test)
|
||||||
ADD_TEST_MACRO(ObjCXX.objcxx-file-extension-test objcxx-file-extension-test)
|
ADD_TEST_MACRO(ObjCXX.objcxx-file-extension-test objcxx-file-extension-test)
|
||||||
|
ADD_TEST_MACRO(ObjCXX.cxx-as-objcxx cxx-as-objcxx)
|
||||||
|
5
Tests/ObjCXX/cxx-as-objcxx/CMakeLists.txt
Normal file
5
Tests/ObjCXX/cxx-as-objcxx/CMakeLists.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
project(cxx-as-objcxx LANGUAGES OBJCXX)
|
||||||
|
|
||||||
|
add_executable(cxx-as-objcxx main.cpp)
|
||||||
|
set_source_files_properties(main.cpp PROPERTIES LANGUAGE OBJCXX)
|
6
Tests/ObjCXX/cxx-as-objcxx/main.cpp
Normal file
6
Tests/ObjCXX/cxx-as-objcxx/main.cpp
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#import <Foundation/Foundation.h>
|
||||||
|
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
96
Tests/QtAutogen/RerunMocOnAddFile/CMakeLists.txt
Normal file
96
Tests/QtAutogen/RerunMocOnAddFile/CMakeLists.txt
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
# This test checks whether adding a source file to the project triggers an AUTOMOC re-run.
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
project(RerunMocOnAddFile)
|
||||||
|
include("../AutogenCoreTest.cmake")
|
||||||
|
|
||||||
|
# Create an executable to generate a clean target
|
||||||
|
set(main_source "${CMAKE_CURRENT_BINARY_DIR}/generated_main.cpp")
|
||||||
|
file(WRITE "${main_source}" "int main() {}")
|
||||||
|
add_executable(exe "${main_source}")
|
||||||
|
|
||||||
|
# Utility variables
|
||||||
|
set(timeformat "%Y.%j.%H.%M%S")
|
||||||
|
set(testProjectTemplateDir "${CMAKE_CURRENT_SOURCE_DIR}/MocOnAddFile")
|
||||||
|
set(testProjectSrc "${CMAKE_CURRENT_BINARY_DIR}/MocOnAddFile")
|
||||||
|
set(testProjectBinDir "${CMAKE_CURRENT_BINARY_DIR}/MocOnAddFile-build")
|
||||||
|
|
||||||
|
# Utility macros
|
||||||
|
macro(sleep)
|
||||||
|
message(STATUS "Sleeping for a few seconds.")
|
||||||
|
execute_process(COMMAND "${CMAKE_COMMAND}" -E sleep 1)
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(acquire_timestamp When)
|
||||||
|
file(TIMESTAMP "${mocBasicBin}" time${When} "${timeformat}")
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(rebuild buildName)
|
||||||
|
message(STATUS "Starting build ${buildName}.")
|
||||||
|
execute_process(COMMAND "${CMAKE_COMMAND}" --build . WORKING_DIRECTORY "${testProjectBinDir}" RESULT_VARIABLE result)
|
||||||
|
if (result)
|
||||||
|
message(FATAL_ERROR "Build ${buildName} failed.")
|
||||||
|
else()
|
||||||
|
message(STATUS "Build ${buildName} finished.")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(require_change)
|
||||||
|
if (timeAfter VERSION_GREATER timeBefore)
|
||||||
|
message(STATUS "As expected the file ${mocBasicBin} changed.")
|
||||||
|
else()
|
||||||
|
message(SEND_ERROR "Unexpectedly the file ${mocBasicBin} did not change!\nTimestamp pre: ${timeBefore}\nTimestamp aft: ${timeAfter}\n")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(require_change_not)
|
||||||
|
if (timeAfter VERSION_GREATER timeBefore)
|
||||||
|
message(SEND_ERROR "Unexpectedly the file ${mocBasicBin} changed!\nTimestamp pre: ${timeBefore}\nTimestamp aft: ${timeAfter}\n")
|
||||||
|
else()
|
||||||
|
message(STATUS "As expected the file ${mocBasicBin} did not change.")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
# Create the test project from the template
|
||||||
|
unset(additional_project_sources)
|
||||||
|
unset(main_cpp_includes)
|
||||||
|
configure_file("${testProjectTemplateDir}/CMakeLists.txt.in" "${testProjectSrc}/CMakeLists.txt")
|
||||||
|
configure_file("${testProjectTemplateDir}/main.cpp.in" "${testProjectSrc}/main.cpp")
|
||||||
|
|
||||||
|
# Initial build
|
||||||
|
try_compile(MOC_RERUN
|
||||||
|
"${testProjectBinDir}"
|
||||||
|
"${testProjectSrc}"
|
||||||
|
MocOnAddFile
|
||||||
|
CMAKE_FLAGS "-DQT_TEST_VERSION=${QT_TEST_VERSION}"
|
||||||
|
"-DCMAKE_AUTOGEN_VERBOSE=${CMAKE_AUTOGEN_VERBOSE}"
|
||||||
|
"-DQT_QMAKE_EXECUTABLE:FILEPATH=${QT_QMAKE_EXECUTABLE}"
|
||||||
|
OUTPUT_VARIABLE output
|
||||||
|
)
|
||||||
|
if (NOT MOC_RERUN)
|
||||||
|
message(FATAL_ERROR "Initial build of mocOnAddFile failed. Output: ${output}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Sleep to ensure new timestamps
|
||||||
|
sleep()
|
||||||
|
|
||||||
|
# Add a QObject class (defined in header) to the project and build
|
||||||
|
set(additional_project_sources myobject.cpp)
|
||||||
|
set(main_cpp_includes "#include \"myobject.h\"")
|
||||||
|
configure_file("${testProjectTemplateDir}/CMakeLists.txt.in" "${testProjectSrc}/CMakeLists.txt"
|
||||||
|
@ONLY)
|
||||||
|
configure_file("${testProjectTemplateDir}/main.cpp.in" "${testProjectSrc}/main.cpp" @ONLY)
|
||||||
|
configure_file("${testProjectTemplateDir}/myobject.h" "${testProjectSrc}/myobject.h" COPYONLY)
|
||||||
|
configure_file("${testProjectTemplateDir}/myobject.cpp" "${testProjectSrc}/myobject.cpp" COPYONLY)
|
||||||
|
rebuild(2)
|
||||||
|
|
||||||
|
# Sleep to ensure new timestamps
|
||||||
|
sleep()
|
||||||
|
|
||||||
|
# Add a QObject class (defined in source) to the project and build
|
||||||
|
set(additional_project_sources myobject.cpp anotherobject.cpp)
|
||||||
|
configure_file("${testProjectTemplateDir}/CMakeLists.txt.in" "${testProjectSrc}/CMakeLists.txt"
|
||||||
|
@ONLY)
|
||||||
|
configure_file("${testProjectTemplateDir}/anotherobject.cpp" "${testProjectSrc}/anotherobject.cpp"
|
||||||
|
COPYONLY)
|
||||||
|
rebuild(3)
|
@ -0,0 +1,9 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
project(MocOnAddFile)
|
||||||
|
include("@CMAKE_CURRENT_LIST_DIR@/../AutogenCoreTest.cmake")
|
||||||
|
|
||||||
|
set(CMAKE_AUTOMOC ON)
|
||||||
|
set(CMAKE_AUTORCC ON)
|
||||||
|
|
||||||
|
add_executable(mocOnAddFile main.cpp @additional_project_sources@)
|
||||||
|
target_link_libraries(mocOnAddFile ${QT_QTCORE_TARGET})
|
@ -0,0 +1,15 @@
|
|||||||
|
#include <qobject.h>
|
||||||
|
|
||||||
|
class AnotherObject : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
AnotherObject() {}
|
||||||
|
};
|
||||||
|
|
||||||
|
AnotherObject* createAnotherObject()
|
||||||
|
{
|
||||||
|
return new AnotherObject();
|
||||||
|
}
|
||||||
|
|
||||||
|
#include "anotherobject.moc"
|
@ -0,0 +1,6 @@
|
|||||||
|
@main_cpp_includes@
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
@ -0,0 +1,6 @@
|
|||||||
|
#include "myobject.h"
|
||||||
|
|
||||||
|
MyObject::MyObject(QObject* parent)
|
||||||
|
: QObject(parent)
|
||||||
|
{
|
||||||
|
}
|
13
Tests/QtAutogen/RerunMocOnAddFile/MocOnAddFile/myobject.h
Normal file
13
Tests/QtAutogen/RerunMocOnAddFile/MocOnAddFile/myobject.h
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#ifndef MYOBJECT_H
|
||||||
|
#define MYOBJECT_H
|
||||||
|
|
||||||
|
#include <qobject.h>
|
||||||
|
|
||||||
|
class MyObject : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
MyObject(QObject* parent = 0);
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
80
Tests/QtAutogen/RerunMocOnMissingDependency/CMakeLists.txt
Normal file
80
Tests/QtAutogen/RerunMocOnMissingDependency/CMakeLists.txt
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
# This test checks whether a missing dependency of the moc output triggers an AUTOMOC re-run.
|
||||||
|
|
||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
project(RerunMocOnMissingDependency)
|
||||||
|
include("../AutogenCoreTest.cmake")
|
||||||
|
|
||||||
|
# Create an executable to generate a clean target
|
||||||
|
set(main_source "${CMAKE_CURRENT_BINARY_DIR}/generated_main.cpp")
|
||||||
|
file(WRITE "${main_source}" "int main() {}")
|
||||||
|
add_executable(exe "${main_source}")
|
||||||
|
|
||||||
|
# Utility variables
|
||||||
|
set(testProjectTemplateDir "${CMAKE_CURRENT_SOURCE_DIR}/MocOnMissingDependency")
|
||||||
|
set(testProjectSrc "${CMAKE_CURRENT_BINARY_DIR}/MocOnMissingDependency")
|
||||||
|
set(testProjectBinDir "${CMAKE_CURRENT_BINARY_DIR}/MocOnMissingDependency-build")
|
||||||
|
if(DEFINED Qt5Core_VERSION AND Qt5Core_VERSION VERSION_GREATER_EQUAL "5.15.0")
|
||||||
|
set(moc_depfiles_supported TRUE)
|
||||||
|
else()
|
||||||
|
set(moc_depfiles_supported FALSE)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Utility macros
|
||||||
|
macro(sleep)
|
||||||
|
message(STATUS "Sleeping for a few seconds.")
|
||||||
|
execute_process(COMMAND "${CMAKE_COMMAND}" -E sleep 1)
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(rebuild buildName)
|
||||||
|
message(STATUS "Starting build ${buildName}.")
|
||||||
|
execute_process(COMMAND "${CMAKE_COMMAND}" --build . WORKING_DIRECTORY "${testProjectBinDir}"
|
||||||
|
RESULT_VARIABLE result OUTPUT_VARIABLE output)
|
||||||
|
if (result)
|
||||||
|
message(FATAL_ERROR "Build ${buildName} failed.")
|
||||||
|
else()
|
||||||
|
message(STATUS "Build ${buildName} finished.")
|
||||||
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
# Create the test project from the template
|
||||||
|
file(COPY "${testProjectTemplateDir}" DESTINATION "${CMAKE_CURRENT_BINARY_DIR}")
|
||||||
|
configure_file("${testProjectTemplateDir}/CMakeLists.txt.in" "${testProjectSrc}/CMakeLists.txt" @ONLY)
|
||||||
|
|
||||||
|
# Initial build
|
||||||
|
file(REMOVE_RECURSE "${testProjectBinDir}")
|
||||||
|
try_compile(MOC_RERUN
|
||||||
|
"${testProjectBinDir}"
|
||||||
|
"${testProjectSrc}"
|
||||||
|
MocOnMissingDependency
|
||||||
|
CMAKE_FLAGS "-DQT_TEST_VERSION=${QT_TEST_VERSION}"
|
||||||
|
"-DCMAKE_AUTOGEN_VERBOSE=ON"
|
||||||
|
"-DQT_QMAKE_EXECUTABLE:FILEPATH=${QT_QMAKE_EXECUTABLE}"
|
||||||
|
OUTPUT_VARIABLE output
|
||||||
|
)
|
||||||
|
if (NOT MOC_RERUN)
|
||||||
|
message(FATAL_ERROR "Initial build of mocOnMissingDependency failed. Output: ${output}")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Sleep to ensure new timestamps
|
||||||
|
sleep()
|
||||||
|
|
||||||
|
if(moc_depfiles_supported)
|
||||||
|
# Remove the dependency inc1/foo.h and build again.
|
||||||
|
# We expect that the moc_XXX.cpp file gets re-generated. But only if we have depfile support.
|
||||||
|
file(REMOVE_RECURSE "${testProjectSrc}/inc1")
|
||||||
|
rebuild(2)
|
||||||
|
if(NOT output MATCHES "AutoMoc: Generating \"[^\"]*moc_myobject.cpp\"")
|
||||||
|
message(FATAL_ERROR "moc_myobject.cpp was not re-generated "
|
||||||
|
"after removing one of its dependencies")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Sleep to ensure new timestamps
|
||||||
|
sleep()
|
||||||
|
|
||||||
|
# The next build should *not* re-renerate any moc outputs
|
||||||
|
rebuild(3)
|
||||||
|
if(output MATCHES "AutoMoc: Generating")
|
||||||
|
message(FATAL_ERROR "moc_myobject.cpp was not re-generated "
|
||||||
|
"after removing one of its dependencies")
|
||||||
|
endif()
|
@ -0,0 +1,7 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
project(MocOnMissingDependency)
|
||||||
|
include("@CMAKE_CURRENT_LIST_DIR@/../AutogenCoreTest.cmake")
|
||||||
|
set(CMAKE_AUTOMOC ON)
|
||||||
|
add_executable(MocOnMissingDependency main.cpp myobject.cpp)
|
||||||
|
target_include_directories(MocOnMissingDependency PRIVATE inc1 inc2)
|
||||||
|
target_link_libraries(MocOnMissingDependency PRIVATE ${QT_QTCORE_TARGET})
|
@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
#include <qobject.h>
|
@ -0,0 +1,2 @@
|
|||||||
|
|
||||||
|
#include <qobject.h>
|
@ -0,0 +1,9 @@
|
|||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
#include "myobject.h"
|
||||||
|
|
||||||
|
int main(int argc, char* argv[])
|
||||||
|
{
|
||||||
|
MyObject obj;
|
||||||
|
return 0;
|
||||||
|
}
|
@ -0,0 +1,6 @@
|
|||||||
|
#include "myobject.h"
|
||||||
|
|
||||||
|
MyObject::MyObject(QObject* parent)
|
||||||
|
: QObject(parent)
|
||||||
|
{
|
||||||
|
}
|
@ -0,0 +1,10 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <foo.h>
|
||||||
|
|
||||||
|
class MyObject : public QObject
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
MyObject(QObject* parent = 0);
|
||||||
|
};
|
@ -20,6 +20,8 @@ ADD_AUTOGEN_TEST(RccOffMocLibrary)
|
|||||||
ADD_AUTOGEN_TEST(RccOnly rccOnly)
|
ADD_AUTOGEN_TEST(RccOnly rccOnly)
|
||||||
ADD_AUTOGEN_TEST(RccSkipSource)
|
ADD_AUTOGEN_TEST(RccSkipSource)
|
||||||
ADD_AUTOGEN_TEST(RerunMocBasic)
|
ADD_AUTOGEN_TEST(RerunMocBasic)
|
||||||
|
ADD_AUTOGEN_TEST(RerunMocOnAddFile)
|
||||||
|
ADD_AUTOGEN_TEST(RerunMocOnMissingDependency)
|
||||||
ADD_AUTOGEN_TEST(RerunRccConfigChange)
|
ADD_AUTOGEN_TEST(RerunRccConfigChange)
|
||||||
ADD_AUTOGEN_TEST(RerunRccDepends)
|
ADD_AUTOGEN_TEST(RerunRccDepends)
|
||||||
ADD_AUTOGEN_TEST(SameName sameName)
|
ADD_AUTOGEN_TEST(SameName sameName)
|
||||||
|
@ -143,14 +143,14 @@ if(CMAKE_GENERATOR MATCHES "Ninja")
|
|||||||
list(APPEND Ninja_ARGS -DTEST_Fortran=1)
|
list(APPEND Ninja_ARGS -DTEST_Fortran=1)
|
||||||
endif()
|
endif()
|
||||||
if(CMake_TEST_Qt5 AND Qt5Core_FOUND)
|
if(CMake_TEST_Qt5 AND Qt5Core_FOUND)
|
||||||
list(APPEND Ninja_ARGS -DCMake_TEST_Qt5=1 -DCMAKE_TEST_Qt5Core_Version=${Qt5Core_VERSION})
|
list(APPEND Ninja_ARGS -DCMake_TEST_Qt5=1 -DQt5Core_DIR=${Qt5Core_DIR} -DCMAKE_TEST_Qt5Core_Version=${Qt5Core_VERSION})
|
||||||
endif()
|
endif()
|
||||||
add_RunCMake_test(Ninja)
|
add_RunCMake_test(Ninja)
|
||||||
set(NinjaMultiConfig_ARGS
|
set(NinjaMultiConfig_ARGS
|
||||||
-DCYGWIN=${CYGWIN}
|
-DCYGWIN=${CYGWIN}
|
||||||
)
|
)
|
||||||
if(CMake_TEST_Qt5 AND Qt5Core_FOUND)
|
if(CMake_TEST_Qt5 AND Qt5Core_FOUND)
|
||||||
list(APPEND NinjaMultiConfig_ARGS -DCMake_TEST_Qt5=1)
|
list(APPEND NinjaMultiConfig_ARGS -DCMake_TEST_Qt5=1 -DQt5Core_DIR=${Qt5Core_DIR} -DCMAKE_TEST_Qt5Core_Version=${Qt5Core_VERSION})
|
||||||
endif()
|
endif()
|
||||||
if(DEFINED CMake_TEST_CUDA)
|
if(DEFINED CMake_TEST_CUDA)
|
||||||
list(APPEND NinjaMultiConfig_ARGS -DCMake_TEST_CUDA=${CMake_TEST_CUDA})
|
list(APPEND NinjaMultiConfig_ARGS -DCMake_TEST_CUDA=${CMake_TEST_CUDA})
|
||||||
|
@ -327,6 +327,7 @@ run_ChangeBuildType()
|
|||||||
function(run_Qt5AutoMocDeps)
|
function(run_Qt5AutoMocDeps)
|
||||||
if(CMake_TEST_Qt5 AND CMAKE_TEST_Qt5Core_Version VERSION_GREATER_EQUAL 5.15.0)
|
if(CMake_TEST_Qt5 AND CMAKE_TEST_Qt5Core_Version VERSION_GREATER_EQUAL 5.15.0)
|
||||||
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Qt5AutoMocDeps-build)
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Qt5AutoMocDeps-build)
|
||||||
|
set(RunCMake_TEST_OPTIONS "-DQt5Core_DIR=${Qt5Core_DIR}")
|
||||||
run_cmake(Qt5AutoMocDeps)
|
run_cmake(Qt5AutoMocDeps)
|
||||||
unset(RunCMake_TEST_OPTIONS)
|
unset(RunCMake_TEST_OPTIONS)
|
||||||
# Build the project.
|
# Build the project.
|
||||||
|
@ -0,0 +1,3 @@
|
|||||||
|
check_files("${RunCMake_TEST_BINARY_DIR}"
|
||||||
|
INCLUDE
|
||||||
|
)
|
@ -0,0 +1,5 @@
|
|||||||
|
check_files("${RunCMake_TEST_BINARY_DIR}"
|
||||||
|
INCLUDE
|
||||||
|
${TARGET_BYPRODUCTS_LeafExe}
|
||||||
|
${TARGET_BYPRODUCTS_RootCustom}
|
||||||
|
)
|
@ -0,0 +1,6 @@
|
|||||||
|
check_files("${RunCMake_TEST_BINARY_DIR}"
|
||||||
|
INCLUDE
|
||||||
|
${TARGET_BYPRODUCTS_LeafCustom}
|
||||||
|
${TARGET_BYPRODUCTS_RootCustom}
|
||||||
|
${TARGET_FILE_RootExe_Release}
|
||||||
|
)
|
@ -0,0 +1,7 @@
|
|||||||
|
check_files("${RunCMake_TEST_BINARY_DIR}"
|
||||||
|
INCLUDE
|
||||||
|
${TARGET_FILE_LeafExe_Release}
|
||||||
|
${TARGET_BYPRODUCTS_LeafExe}
|
||||||
|
${TARGET_BYPRODUCTS_RootCustom}
|
||||||
|
${TARGET_FILE_RootExe_Release}
|
||||||
|
)
|
@ -34,6 +34,18 @@ add_subdirectory(CustomCommandsAndTargetsSubdir)
|
|||||||
|
|
||||||
create_targets(Top)
|
create_targets(Top)
|
||||||
|
|
||||||
|
add_executable(RootExe main.c)
|
||||||
|
add_custom_target(RootCustom COMMAND ${CMAKE_COMMAND} -E touch RootCustom.txt BYPRODUCTS RootCustom.txt)
|
||||||
|
add_custom_command(OUTPUT main.c COMMAND ${CMAKE_COMMAND} -E copy ${CMAKE_CURRENT_SOURCE_DIR}/main.c ${CMAKE_CURRENT_BINARY_DIR}/main.c DEPENDS RootCustom)
|
||||||
|
add_executable(LeafExe ${CMAKE_CURRENT_BINARY_DIR}/main.c)
|
||||||
|
add_custom_target(LeafCustom COMMAND ${CMAKE_COMMAND} -E touch LeafCustom.txt BYPRODUCTS LeafCustom.txt DEPENDS RootCustom RootExe)
|
||||||
|
add_dependencies(LeafExe RootExe)
|
||||||
|
file(APPEND "${CMAKE_BINARY_DIR}/target_files_custom.cmake"
|
||||||
|
"set(TARGET_BYPRODUCTS_LeafCustom [==[${CMAKE_CURRENT_BINARY_DIR}/LeafCustom.txt]==])
|
||||||
|
set(TARGET_BYPRODUCTS_LeafExe [==[${CMAKE_CURRENT_BINARY_DIR}/main.c]==])
|
||||||
|
set(TARGET_BYPRODUCTS_RootCustom [==[${CMAKE_CURRENT_BINARY_DIR}/RootCustom.txt]==])
|
||||||
|
")
|
||||||
|
|
||||||
include(${CMAKE_CURRENT_LIST_DIR}/Common.cmake)
|
include(${CMAKE_CURRENT_LIST_DIR}/Common.cmake)
|
||||||
generate_output_files(TopPostBuild SubdirPostBuild)
|
generate_output_files(TopPostBuild SubdirPostBuild RootExe LeafExe)
|
||||||
file(APPEND "${CMAKE_BINARY_DIR}/target_files.cmake" "include(\${CMAKE_CURRENT_LIST_DIR}/target_files_custom.cmake)\n")
|
file(APPEND "${CMAKE_BINARY_DIR}/target_files.cmake" "include(\${CMAKE_CURRENT_LIST_DIR}/target_files_custom.cmake)\n")
|
||||||
|
@ -0,0 +1,7 @@
|
|||||||
|
input: CUSTOM_COMMAND(
|
||||||
|
[^
|
||||||
|
]*)*
|
||||||
|
\|\| exe_autogen_timestamp_deps:Debug(
|
||||||
|
[^
|
||||||
|
]*)*
|
||||||
|
outputs:
|
@ -235,6 +235,12 @@ run_cmake_build(CustomCommandsAndTargets debug-in-release-graph-postbuild Releas
|
|||||||
run_ninja(CustomCommandsAndTargets release-postbuild build-Release.ninja SubdirPostBuild)
|
run_ninja(CustomCommandsAndTargets release-postbuild build-Release.ninja SubdirPostBuild)
|
||||||
run_cmake_build(CustomCommandsAndTargets debug-targetpostbuild Debug TopTargetPostBuild)
|
run_cmake_build(CustomCommandsAndTargets debug-targetpostbuild Debug TopTargetPostBuild)
|
||||||
run_ninja(CustomCommandsAndTargets release-targetpostbuild build-Release.ninja SubdirTargetPostBuild)
|
run_ninja(CustomCommandsAndTargets release-targetpostbuild build-Release.ninja SubdirTargetPostBuild)
|
||||||
|
run_cmake_build(CustomCommandsAndTargets release-clean Release clean:all)
|
||||||
|
run_ninja(CustomCommandsAndTargets release-leaf-custom build-Release.ninja LeafCustom.txt)
|
||||||
|
run_cmake_build(CustomCommandsAndTargets release-clean Release clean:all)
|
||||||
|
run_ninja(CustomCommandsAndTargets release-leaf-exe build-Release.ninja LeafExe)
|
||||||
|
run_cmake_build(CustomCommandsAndTargets release-clean Release clean:all)
|
||||||
|
run_ninja(CustomCommandsAndTargets release-leaf-byproduct build-Release.ninja main.c)
|
||||||
|
|
||||||
unset(RunCMake_TEST_BINARY_DIR)
|
unset(RunCMake_TEST_BINARY_DIR)
|
||||||
|
|
||||||
@ -300,9 +306,12 @@ endif()
|
|||||||
|
|
||||||
if(CMake_TEST_Qt5)
|
if(CMake_TEST_Qt5)
|
||||||
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Qt5-build)
|
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/Qt5-build)
|
||||||
set(RunCMake_TEST_OPTIONS "-DCMAKE_CROSS_CONFIGS=all")
|
set(RunCMake_TEST_OPTIONS "-DCMAKE_CROSS_CONFIGS=all" "-DQt5Core_DIR=${Qt5Core_DIR}")
|
||||||
run_cmake_configure(Qt5)
|
run_cmake_configure(Qt5)
|
||||||
unset(RunCMake_TEST_OPTIONS)
|
unset(RunCMake_TEST_OPTIONS)
|
||||||
include(${RunCMake_TEST_BINARY_DIR}/target_files.cmake)
|
include(${RunCMake_TEST_BINARY_DIR}/target_files.cmake)
|
||||||
run_cmake_build(Qt5 debug-in-release-graph Release exe:Debug)
|
run_cmake_build(Qt5 debug-in-release-graph Release exe:Debug)
|
||||||
|
if(CMAKE_TEST_Qt5Core_Version VERSION_GREATER_EQUAL 5.15.0)
|
||||||
|
run_ninja(Qt5 automoc-check build-Debug.ninja -t query exe_autogen/timestamp)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
@ -9,12 +9,13 @@ file(STRINGS "${csProjFile}" lines)
|
|||||||
include(${RunCMake_TEST_SOURCE_DIR}/VsCsharpSourceGroupHelpers.cmake)
|
include(${RunCMake_TEST_SOURCE_DIR}/VsCsharpSourceGroupHelpers.cmake)
|
||||||
|
|
||||||
set(SOURCE_GROUPS_TO_FIND
|
set(SOURCE_GROUPS_TO_FIND
|
||||||
"CSharpSourceGroup"
|
"CSharpSourceGroup\\\\foo\\.cs"
|
||||||
"CSharpSourceGroup/nested"
|
"CSharpSourceGroup\\\\nested\\\\baz\\.cs"
|
||||||
"Images"
|
"CSharpSourceGroup\\\\images\\\\empty\\.bmp"
|
||||||
|
"VsCsharpSourceGroup\\.png"
|
||||||
)
|
)
|
||||||
|
|
||||||
foreach(GROUP_NAME IN LISTS ${SOURCE_GROUPS_TO_FIND})
|
foreach(GROUP_NAME IN LISTS SOURCE_GROUPS_TO_FIND)
|
||||||
find_source_group("${lines}" ${GROUP_NAME})
|
find_source_group("${lines}" ${GROUP_NAME})
|
||||||
if(NOT ${SOURCE_GROUP_FOUND})
|
if(NOT ${SOURCE_GROUP_FOUND})
|
||||||
return()
|
return()
|
||||||
|
@ -9,8 +9,14 @@ set(SRC_FILES
|
|||||||
set(IMAGE_FILES
|
set(IMAGE_FILES
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/Images/empty.bmp
|
${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/Images/empty.bmp
|
||||||
)
|
)
|
||||||
|
# We explicitly don't set a source group for a source in the root level
|
||||||
|
# because of https://gitlab.kitware.com/cmake/cmake/-/issues/21221
|
||||||
|
set(RESOURCE_FILES
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/VsCsharpSourceGroup.png
|
||||||
|
)
|
||||||
|
|
||||||
add_library(VsCsharpSourceGroup SHARED ${SRC_FILES} ${IMAGE_FILES})
|
|
||||||
|
add_library(VsCsharpSourceGroup SHARED ${SRC_FILES} ${IMAGE_FILES} ${RESOURCE_FILES})
|
||||||
source_group("CSharpSourceGroup" FILES ${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/foo.cs)
|
source_group("CSharpSourceGroup" FILES ${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/foo.cs)
|
||||||
source_group("CSharpSourceGroup/nested" FILES ${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/nested/baz.cs)
|
source_group("CSharpSourceGroup/nested" FILES ${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/nested/baz.cs)
|
||||||
source_group("Images" FILES ${IMAGE_FILES})
|
source_group("Images" FILES ${IMAGE_FILES})
|
||||||
|
0
Tests/RunCMake/VS10Project/VsCsharpSourceGroup.png
Normal file
0
Tests/RunCMake/VS10Project/VsCsharpSourceGroup.png
Normal file
@ -19,3 +19,4 @@ run_cmake(foreach-RANGE-non-int-test-3-1)
|
|||||||
run_cmake(foreach-RANGE-non-int-test-3-2)
|
run_cmake(foreach-RANGE-non-int-test-3-2)
|
||||||
run_cmake(foreach-RANGE-non-int-test-3-3)
|
run_cmake(foreach-RANGE-non-int-test-3-3)
|
||||||
run_cmake(foreach-RANGE-invalid-test)
|
run_cmake(foreach-RANGE-invalid-test)
|
||||||
|
run_cmake(foreach-RANGE-out-of-range-test)
|
||||||
|
@ -0,0 +1 @@
|
|||||||
|
1
|
@ -0,0 +1,4 @@
|
|||||||
|
^CMake Error at foreach-RANGE-out-of-range-test\.cmake:[0-9]+ \(foreach\):
|
||||||
|
foreach Integer out of range: '10000000000000000000'
|
||||||
|
Call Stack \(most recent call first\):
|
||||||
|
CMakeLists\.txt:3 \(include\)$
|
@ -0,0 +1,3 @@
|
|||||||
|
foreach(a RANGE 10000000000000000000)
|
||||||
|
break()
|
||||||
|
endforeach()
|
@ -91,6 +91,15 @@ add_test(NAME UseSWIG.MultiplePython COMMAND
|
|||||||
--build-options ${build_options}
|
--build-options ${build_options}
|
||||||
--test-command ${CMAKE_CTEST_COMMAND} -V -C $<CONFIGURATION>
|
--test-command ${CMAKE_CTEST_COMMAND} -V -C $<CONFIGURATION>
|
||||||
)
|
)
|
||||||
|
add_test(NAME UseSWIG.MultipleFiles COMMAND
|
||||||
|
${CMAKE_CTEST_COMMAND} -C $<CONFIGURATION>
|
||||||
|
--build-and-test
|
||||||
|
"${CMake_SOURCE_DIR}/Tests/UseSWIG/MultipleFiles"
|
||||||
|
"${CMake_BINARY_DIR}/Tests/UseSWIG/MultipleFiles"
|
||||||
|
${build_generator_args}
|
||||||
|
--build-project TestMultipleFiles
|
||||||
|
--build-options ${build_options}
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
add_test(NAME UseSWIG.ModuleVersion2 COMMAND
|
add_test(NAME UseSWIG.ModuleVersion2 COMMAND
|
||||||
|
30
Tests/UseSWIG/MultipleFiles/CMakeLists.txt
Normal file
30
Tests/UseSWIG/MultipleFiles/CMakeLists.txt
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.18)
|
||||||
|
|
||||||
|
project(TestMultipleFiles CXX)
|
||||||
|
|
||||||
|
find_package(SWIG REQUIRED)
|
||||||
|
include(UseSWIG)
|
||||||
|
|
||||||
|
unset(SWIG_LANG_TYPE)
|
||||||
|
unset(SWIG_LANG_INCLUDE_DIRECTORIES)
|
||||||
|
unset(SWIG_LANG_DEFINITIONS)
|
||||||
|
unset(SWIG_LANG_OPTIONS)
|
||||||
|
unset(SWIG_LANG_LIBRARIES)
|
||||||
|
|
||||||
|
find_package(Python3 REQUIRED COMPONENTS Development)
|
||||||
|
|
||||||
|
set_property(SOURCE "${CMAKE_CURRENT_SOURCE_DIR}/add.i" PROPERTY CPLUSPLUS ON)
|
||||||
|
set_property(SOURCE "${CMAKE_CURRENT_SOURCE_DIR}/sub.i" PROPERTY CPLUSPLUS ON)
|
||||||
|
set_property(SOURCE "${CMAKE_CURRENT_SOURCE_DIR}/add.i" PROPERTY SWIG_MODULE_NAME _add)
|
||||||
|
set_property(SOURCE "${CMAKE_CURRENT_SOURCE_DIR}/sub.i" PROPERTY SWIG_MODULE_NAME _sub)
|
||||||
|
|
||||||
|
|
||||||
|
swig_add_library(example
|
||||||
|
LANGUAGE python
|
||||||
|
TYPE MODULE
|
||||||
|
SOURCES "${CMAKE_CURRENT_SOURCE_DIR}/add.i"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/sub.i"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/add.cxx"
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/sub.cxx")
|
||||||
|
target_include_directories(example PUBLIC "${CMAKE_CURRENT_SOURCE_DIR}")
|
||||||
|
target_link_libraries(example PRIVATE Python3::Module)
|
6
Tests/UseSWIG/MultipleFiles/add.cxx
Normal file
6
Tests/UseSWIG/MultipleFiles/add.cxx
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#include "add.h"
|
||||||
|
|
||||||
|
int add(int a, int b)
|
||||||
|
{
|
||||||
|
return a + b;
|
||||||
|
}
|
1
Tests/UseSWIG/MultipleFiles/add.h
Normal file
1
Tests/UseSWIG/MultipleFiles/add.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
int add(int a, int b);
|
4
Tests/UseSWIG/MultipleFiles/add.i
Normal file
4
Tests/UseSWIG/MultipleFiles/add.i
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
%{
|
||||||
|
#include "add.h"
|
||||||
|
%}
|
||||||
|
%include "add.h"
|
6
Tests/UseSWIG/MultipleFiles/sub.cxx
Normal file
6
Tests/UseSWIG/MultipleFiles/sub.cxx
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#include "sub.h"
|
||||||
|
|
||||||
|
int sub(int a, int b)
|
||||||
|
{
|
||||||
|
return a - b;
|
||||||
|
}
|
1
Tests/UseSWIG/MultipleFiles/sub.h
Normal file
1
Tests/UseSWIG/MultipleFiles/sub.h
Normal file
@ -0,0 +1 @@
|
|||||||
|
int sub(int a, int b);
|
5
Tests/UseSWIG/MultipleFiles/sub.i
Normal file
5
Tests/UseSWIG/MultipleFiles/sub.i
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
%{
|
||||||
|
#include "sub.h"
|
||||||
|
%}
|
||||||
|
|
||||||
|
%include "sub.h"
|
Loading…
x
Reference in New Issue
Block a user