Update upstream source from tag 'upstream/3.18.4'
Update to upstream version '3.18.4' with Debian dir 5d63debb0cc47d74e0a1a342ea49cf982eb180ff
This commit is contained in:
commit
96d9723647
@ -178,17 +178,15 @@ Modules
|
||||
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
|
||||
on different build setups (given, that the headers compiled by ``moc`` are
|
||||
in an :command:`include directory <target_include_directories>`).
|
||||
Also it ensures that ``moc`` output files will compile correctly when the
|
||||
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
|
||||
-----
|
||||
|
||||
@ -316,3 +314,11 @@ Changes made since CMake 3.16.0 include the following.
|
||||
:prop_tgt:`INTERFACE_INCLUDE_DIRECTORIES` target properties.
|
||||
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
||||
: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.
|
||||
Previously they would be places in ``*_CFLAGS_OTHER`` variables and
|
||||
: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.
|
||||
|
||||
* The :manual:`Compile Features <cmake-compile-features(7)>` functionality
|
||||
is now aware of the availability of C11 features in MSVC 19.27 and above,
|
||||
including support for the ``c_restrict`` feature and the ``-std:c11`` flag.
|
||||
is now aware of the availability of C11 features in MSVC 19.27 and 19.28,
|
||||
including support for the ``c_restrict``, ``c_static_assert`` features and
|
||||
the ``-std:c11`` flag.
|
||||
|
||||
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
|
||||
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 and 3.17.5.
|
||||
|
||||
* 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")
|
||||
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_AR_NAMES "llvm-lib")
|
||||
endif()
|
||||
|
||||
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})
|
||||
|
||||
list(APPEND _CMAKE_TOOL_VARS LINKER MT)
|
||||
|
@ -170,7 +170,7 @@ endif()
|
||||
# compile an Objective-C file into an object file
|
||||
if(NOT 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()
|
||||
|
||||
if(NOT CMAKE_OBJC_LINK_EXECUTABLE)
|
||||
|
@ -263,7 +263,7 @@ endif()
|
||||
# compile an Objective-C++ file into an object file
|
||||
if(NOT 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()
|
||||
|
||||
if(NOT CMAKE_OBJCXX_LINK_EXECUTABLE)
|
||||
|
@ -54,5 +54,4 @@ function(check_c_compiler_flag _flag _var)
|
||||
foreach(v IN LISTS _locale_vars)
|
||||
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
||||
endforeach()
|
||||
set(${_var} "${${_var}}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
@ -54,5 +54,4 @@ function(check_cxx_compiler_flag _flag _var)
|
||||
foreach(v IN LISTS _locale_vars)
|
||||
set(ENV{${v}} ${_locale_vars_saved_${v}})
|
||||
endforeach()
|
||||
set(${_var} "${${_var}}" PARENT_SCOPE)
|
||||
endfunction()
|
||||
|
@ -115,11 +115,12 @@ macro(__compiler_armclang lang)
|
||||
endif()
|
||||
|
||||
if(__CMAKE_ARMClang_USING_armlink)
|
||||
unset(CMAKE_${lang}_LINKER_WRAPPER_FLAG)
|
||||
set(__CMAKE_ARMClang_USING_armlink_WRAPPER "")
|
||||
else()
|
||||
set(__CMAKE_ARMClang_USING_armlink_WRAPPER ${CMAKE_${lang}_LINKER_WRAPPER_FLAG})
|
||||
set(__CMAKE_ARMClang_USING_armlink_WRAPPER "-Xlinker")
|
||||
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}_ARCHIVE_CREATE "<CMAKE_AR> --create -cr <TARGET> <LINK_FLAGS> <OBJECTS>")
|
||||
set(CMAKE_${lang}_RESPONSE_FILE_LINK_FLAG "${__CMAKE_ARMClang_USING_armlink_WRAPPER} --via=")
|
||||
|
@ -10,6 +10,11 @@ set(__COMPILER_CLANG 1)
|
||||
|
||||
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"
|
||||
OR "x${CMAKE_CXX_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")
|
||||
endif()
|
||||
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()
|
||||
endif()
|
||||
|
||||
|
@ -1,9 +1,7 @@
|
||||
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_static_assert "_MSC_VER >= 1928")
|
||||
|
||||
set(_cmake_feature_test_c_variadic_macros "${_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_C99_COMPILE_FEATURES c_restrict)
|
||||
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
|
||||
endmacro()
|
||||
|
||||
|
@ -68,20 +68,22 @@ if(UNIX)
|
||||
endif()
|
||||
|
||||
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_EXTENSION_COMPILE_OPTION "")
|
||||
|
||||
# MSVC requires c++14 as the minimum level
|
||||
set(CMAKE_CUDA11_STANDARD_COMPILE_OPTION "")
|
||||
set(CMAKE_CUDA11_EXTENSION_COMPILE_OPTION "")
|
||||
|
||||
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 9.0)
|
||||
set(CMAKE_CUDA14_STANDARD_COMPILE_OPTION "")
|
||||
set(CMAKE_CUDA14_EXTENSION_COMPILE_OPTION "")
|
||||
set(CMAKE_CUDA14_STANDARD_COMPILE_OPTION "-std=c++14")
|
||||
set(CMAKE_CUDA14_EXTENSION_COMPILE_OPTION "-std=c++14")
|
||||
endif()
|
||||
|
||||
if (NOT CMAKE_CUDA_COMPILER_VERSION VERSION_LESS 11.0)
|
||||
set(CMAKE_CUDA17_STANDARD_COMPILE_OPTION "")
|
||||
set(CMAKE_CUDA17_EXTENSION_COMPILE_OPTION "")
|
||||
set(CMAKE_CUDA17_STANDARD_COMPILE_OPTION "-std=c++17")
|
||||
set(CMAKE_CUDA17_EXTENSION_COMPILE_OPTION "-std=c++17")
|
||||
endif()
|
||||
|
||||
else()
|
||||
|
@ -7,7 +7,7 @@
|
||||
# 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
|
||||
# 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}
|
||||
# Additionally, sets ${out_variable}_readable to the resulting numeric list
|
||||
# Example:
|
||||
@ -82,16 +82,26 @@ if(CUDA_VERSION VERSION_GREATER_EQUAL "10.0")
|
||||
list(APPEND CUDA_ALL_GPU_ARCHITECTURES "7.5")
|
||||
|
||||
if(CUDA_VERSION VERSION_LESS "11.0")
|
||||
set(CUDA_LIMIT_GPU_ARCHITECTURE "8.0")
|
||||
list(APPEND CUDA_COMMON_GPU_ARCHITECTURES "7.5+PTX")
|
||||
set(CUDA_LIMIT_GPU_ARCHITECTURE "8.0")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if(CUDA_VERSION VERSION_GREATER_EQUAL "11.0")
|
||||
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")
|
||||
|
||||
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")
|
||||
set(CUDA_LIMIT_GPU_ARCHITECTURE "9.0")
|
||||
endif()
|
||||
|
@ -59,6 +59,8 @@ macro(java_append_library_directories _var)
|
||||
endif()
|
||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^i.86$")
|
||||
set(_java_libarch "i386")
|
||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^aarch64")
|
||||
set(_java_libarch "arm64" "aarch64")
|
||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^alpha")
|
||||
set(_java_libarch "alpha")
|
||||
elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "^arm")
|
||||
|
@ -241,6 +241,7 @@ if(NOT MATLAB_ADDITIONAL_VERSIONS)
|
||||
endif()
|
||||
|
||||
set(MATLAB_VERSIONS_MAPPING
|
||||
"R2020b=9.9"
|
||||
"R2020a=9.8"
|
||||
"R2019b=9.7"
|
||||
"R2019a=9.6"
|
||||
|
@ -9,6 +9,9 @@
|
||||
# Initial configuration
|
||||
#
|
||||
|
||||
cmake_policy(PUSH)
|
||||
# numbers and boolean constants
|
||||
cmake_policy (SET CMP0012 NEW)
|
||||
# IN_LIST operator
|
||||
cmake_policy (SET CMP0057 NEW)
|
||||
|
||||
@ -44,7 +47,6 @@ macro (_PYTHON_DISPLAY_FAILURE _PYTHON_MSG)
|
||||
set (${_PYTHON_PREFIX}_FOUND FALSE)
|
||||
string (TOUPPER "${_PYTHON_PREFIX}" _${_PYTHON_PREFIX}_UPPER_PREFIX)
|
||||
set (${_PYTHON_UPPER_PREFIX}_FOUND FALSE)
|
||||
return()
|
||||
endmacro()
|
||||
|
||||
|
||||
@ -607,14 +609,24 @@ function (_PYTHON_GET_VERSION)
|
||||
# ABI not used on Windows
|
||||
set (abi "")
|
||||
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")
|
||||
if (NOT config)
|
||||
# pyconfig.h can be a wrapper to a platform specific pyconfig.h
|
||||
# In this case, try to identify ABI from include directory
|
||||
if (_${_PYTHON_PREFIX}_INCLUDE_DIR MATCHES "python${version_major}\\.${version_minor}+([dmu]*)")
|
||||
set (abi "${CMAKE_MATCH_1}")
|
||||
else()
|
||||
set (abi "")
|
||||
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()
|
||||
set (${_PGV_PREFIX}ABI "${abi}" PARENT_SCOPE)
|
||||
endif()
|
||||
@ -1012,6 +1024,9 @@ endfunction()
|
||||
if (DEFINED ${_PYTHON_PREFIX}_FIND_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}\"")
|
||||
|
||||
cmake_policy(POP)
|
||||
return()
|
||||
endif()
|
||||
|
||||
|
||||
@ -2952,6 +2967,9 @@ endif()
|
||||
if (${_PYTHON_PREFIX}_VERSION_MAJOR AND
|
||||
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}\"")
|
||||
|
||||
cmake_policy(POP)
|
||||
return()
|
||||
endif()
|
||||
|
||||
unset (_${_PYTHON_PREFIX}_REASON_FAILURE)
|
||||
@ -3160,3 +3178,5 @@ if (DEFINED _${_PYTHON_PREFIX}_CMAKE_FIND_FRAMEWORK)
|
||||
else()
|
||||
unset (CMAKE_FIND_FRAMEWORK)
|
||||
endif()
|
||||
|
||||
cmake_policy(POP)
|
||||
|
@ -8,6 +8,11 @@ if(__WINDOWS_CLANG)
|
||||
endif()
|
||||
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)
|
||||
set(CMAKE_LIBRARY_PATH_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_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_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_DEBUG)
|
||||
|
@ -10,6 +10,11 @@ set(__WINDOWS_EMBARCADERO 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)
|
||||
# Borland target type flags (bcc32 -h -t):
|
||||
set(_tW "-tW") # -tW GUI App (implies -U__CONSOLE__)
|
||||
@ -123,7 +128,7 @@ macro(__embarcadero_language lang)
|
||||
if (EMBARCADERO)
|
||||
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_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()
|
||||
|
||||
# Initial configuration flags.
|
||||
|
@ -496,7 +496,8 @@ function(SWIG_ADD_SOURCE_TO_MODULE name outfiles infile)
|
||||
endif()
|
||||
endif()
|
||||
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
|
||||
# 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}>")
|
||||
@ -724,6 +725,13 @@ function(SWIG_ADD_LIBRARY name)
|
||||
|
||||
set(swig_generated_sources)
|
||||
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)
|
||||
SWIG_ADD_SOURCE_TO_MODULE(${name} swig_generated_source "${swig_it}")
|
||||
list (APPEND swig_generated_sources "${swig_generated_source}")
|
||||
|
@ -1,7 +1,7 @@
|
||||
# CMake version number components.
|
||||
set(CMake_VERSION_MAJOR 3)
|
||||
set(CMake_VERSION_MINOR 18)
|
||||
set(CMake_VERSION_PATCH 2)
|
||||
set(CMake_VERSION_PATCH 4)
|
||||
#set(CMake_VERSION_RC 0)
|
||||
set(CMake_VERSION_IS_DIRTY 0)
|
||||
|
||||
@ -21,7 +21,7 @@ endif()
|
||||
|
||||
if(NOT CMake_VERSION_NO_GIT)
|
||||
# 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.
|
||||
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());
|
||||
cmSystemTools::SetFatalErrorOccured();
|
||||
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;
|
||||
|
@ -1611,6 +1611,8 @@ bool cmGlobalGenerator::AddAutomaticSources()
|
||||
{
|
||||
for (const auto& lg : this->LocalGenerators) {
|
||||
lg->CreateEvaluationFileOutputs();
|
||||
}
|
||||
for (const auto& lg : this->LocalGenerators) {
|
||||
for (const auto& gt : lg->GetGeneratorTargets()) {
|
||||
if (gt->GetType() == cmStateEnums::INTERFACE_LIBRARY ||
|
||||
gt->GetType() == cmStateEnums::UTILITY ||
|
||||
|
@ -1170,7 +1170,9 @@ void cmGlobalNinjaGenerator::AppendTargetDependsClosure(
|
||||
|
||||
for (auto const& dep_target : this->GetTargetDirectDepends(target)) {
|
||||
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;
|
||||
}
|
||||
|
||||
@ -1863,6 +1865,7 @@ void cmGlobalNinjaGenerator::WriteTargetClean(std::ostream& os)
|
||||
byproducts.push_back(
|
||||
this->BuildAlias(GetByproductsForCleanTargetName(), config));
|
||||
}
|
||||
byproducts.emplace_back(GetByproductsForCleanTargetName());
|
||||
build.Variables["TARGETS"] = cmJoin(byproducts, " ");
|
||||
|
||||
for (auto const& fileConfig : configs) {
|
||||
|
@ -2682,17 +2682,29 @@ void cmLocalGenerator::AddPchDependencies(cmGeneratorTarget* target)
|
||||
this->Makefile->GetSafeDefinition(
|
||||
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.
|
||||
if ((langFlags.find("/ZI") != std::string::npos ||
|
||||
langFlags.find("-ZI") != std::string::npos) ||
|
||||
(cmSystemTools::VersionCompare(cmSystemTools::OP_LESS,
|
||||
compilerVersion.c_str(),
|
||||
"16.0") &&
|
||||
compilerId == "MSVC")) {
|
||||
bool msvc2008OrLess =
|
||||
cmSystemTools::VersionCompare(
|
||||
cmSystemTools::OP_LESS, compilerVersion.c_str(), "16.0") &&
|
||||
compilerId == "MSVC";
|
||||
// but not when used via toolset -Tv90
|
||||
if (this->Makefile->GetSafeDefinition(
|
||||
"CMAKE_VS_PLATFORM_TOOLSET") == "v90") {
|
||||
msvc2008OrLess = false;
|
||||
}
|
||||
|
||||
if (editAndContinueDebugInfo || msvc2008OrLess) {
|
||||
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
||||
{ ".pdb", ".idb" });
|
||||
} else if ((langFlags.find("/Zi") != std::string::npos ||
|
||||
langFlags.find("-Zi") != std::string::npos)) {
|
||||
} else if (enableDebuggingInformation) {
|
||||
CopyPchCompilePdb(config, target, *ReuseFrom, reuseTarget,
|
||||
{ ".pdb" });
|
||||
}
|
||||
|
@ -100,6 +100,8 @@ void cmNinjaUtilityTargetGenerator::Generate(const std::string& config)
|
||||
if (genTarget->Target->GetType() != cmStateEnums::GLOBAL_TARGET) {
|
||||
lg->AppendTargetOutputs(genTarget, gg->GetByproductsForCleanTarget(),
|
||||
config);
|
||||
std::copy(util_outputs.begin(), util_outputs.end(),
|
||||
std::back_inserter(gg->GetByproductsForCleanTarget()));
|
||||
}
|
||||
lg->AppendTargetDepends(genTarget, deps, config, config);
|
||||
|
||||
|
@ -1224,9 +1224,13 @@ bool cmQtAutoGenInitializer::InitAutogenTarget()
|
||||
|
||||
if (this->Moc.ExecutableTarget != nullptr) {
|
||||
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) {
|
||||
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.
|
||||
@ -1514,6 +1518,7 @@ bool cmQtAutoGenInitializer::SetupWriteAutogenInfo()
|
||||
info.SetConfig("PARSE_CACHE_FILE", this->AutogenTarget.ParseCacheFile);
|
||||
info.Set("DEP_FILE", this->AutogenTarget.DepFile);
|
||||
info.Set("DEP_FILE_RULE_NAME", this->AutogenTarget.DepFileRuleName);
|
||||
info.SetArray("CMAKE_LIST_FILES", this->Makefile->GetListFiles());
|
||||
info.SetArray("HEADER_EXTENSIONS",
|
||||
this->Makefile->GetCMakeInstance()->GetHeaderExtensions());
|
||||
info.SetArrayArray(
|
||||
|
@ -184,6 +184,7 @@ public:
|
||||
std::string DepFile;
|
||||
std::string DepFileRuleName;
|
||||
std::vector<std::string> HeaderExtensions;
|
||||
std::vector<std::string> ListFiles;
|
||||
};
|
||||
|
||||
/** Shared common variables. */
|
||||
@ -191,7 +192,7 @@ public:
|
||||
{
|
||||
public:
|
||||
// -- Parse Cache
|
||||
bool ParseCacheChanged = false;
|
||||
std::atomic<bool> ParseCacheChanged = ATOMIC_VAR_INIT(false);
|
||||
cmFileTime ParseCacheTime;
|
||||
ParseCacheT ParseCache;
|
||||
|
||||
@ -1776,16 +1777,24 @@ bool cmQtAutoMocUicT::JobProbeDepsMocT::Probe(MappingT const& mapping,
|
||||
{
|
||||
// Check dependency timestamps
|
||||
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
|
||||
auto const depMatch = FindDependency(sourceDir, dep);
|
||||
if (depMatch.first.empty()) {
|
||||
Log().Warning(GenT::MOC,
|
||||
cmStrCat(MessagePath(sourceFile), " depends on ",
|
||||
MessagePath(dep),
|
||||
" but the file does not exist."));
|
||||
continue;
|
||||
if (reason != nullptr) {
|
||||
*reason =
|
||||
cmStrCat("Generating ", MessagePath(outputFile), " from ",
|
||||
MessagePath(sourceFile), ", because its dependency ",
|
||||
MessagePath(dep), " vanished.");
|
||||
}
|
||||
dependencies.erase(it);
|
||||
BaseEval().ParseCacheChanged = true;
|
||||
return true;
|
||||
}
|
||||
|
||||
// Test if dependency file is older
|
||||
if (outputFileTime.Older(depMatch.second)) {
|
||||
if (reason != nullptr) {
|
||||
@ -2176,7 +2185,7 @@ void cmQtAutoMocUicT::JobDepFilesMergeT::Process()
|
||||
return dependenciesFromDepFile(f.c_str());
|
||||
};
|
||||
|
||||
std::vector<std::string> dependencies;
|
||||
std::vector<std::string> dependencies = BaseConst().ListFiles;
|
||||
ParseCacheT& parseCache = BaseEval().ParseCache;
|
||||
auto processMappingEntry = [&](const MappingMapT::value_type& m) {
|
||||
auto cacheEntry = parseCache.GetOrInsert(m.first);
|
||||
@ -2257,6 +2266,7 @@ bool cmQtAutoMocUicT::InitFromInfo(InfoT const& info)
|
||||
!info.GetString("DEP_FILE_RULE_NAME", BaseConst_.DepFileRuleName,
|
||||
false) ||
|
||||
!info.GetStringConfig("SETTINGS_FILE", SettingsFile_, true) ||
|
||||
!info.GetArray("CMAKE_LIST_FILES", BaseConst_.ListFiles, true) ||
|
||||
!info.GetArray("HEADER_EXTENSIONS", BaseConst_.HeaderExtensions, true) ||
|
||||
!info.GetString("QT_MOC_EXECUTABLE", MocConst_.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
|
||||
// source- or binary-dir is used within the link and return that
|
||||
std::string link;
|
||||
std::string sourceGroupedFile;
|
||||
std::string const& fullFileName = source->GetFullPath();
|
||||
std::string const& srcDir = this->Makefile->GetCurrentSourceDirectory();
|
||||
std::string const& binDir = this->Makefile->GetCurrentBinaryDirectory();
|
||||
@ -4936,8 +4937,14 @@ std::string cmVisualStudio10TargetGenerator::GetCSharpSourceLink(
|
||||
cmSourceGroup* sourceGroup =
|
||||
this->Makefile->FindSourceGroup(fullFileName, sourceGroups);
|
||||
if (sourceGroup && !sourceGroup->GetFullName().empty()) {
|
||||
link = sourceGroup->GetFullName() + "/" +
|
||||
sourceGroupedFile = sourceGroup->GetFullName() + "/" +
|
||||
cmsys::SystemTools::GetFilenameName(fullFileName);
|
||||
cmsys::SystemTools::ConvertToUnixSlashes(sourceGroupedFile);
|
||||
}
|
||||
|
||||
if (!sourceGroupedFile.empty() &&
|
||||
cmHasSuffix(fullFileName, sourceGroupedFile)) {
|
||||
link = sourceGroupedFile;
|
||||
} else if (cmHasPrefix(fullFileName, srcDir)) {
|
||||
link = fullFileName.substr(srcDir.length() + 1);
|
||||
} else if (cmHasPrefix(fullFileName, binDir)) {
|
||||
|
@ -454,6 +454,20 @@
|
||||
"value": "stdcpplatest",
|
||||
"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",
|
||||
"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.cxx-file-extension-test cxx-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(RccSkipSource)
|
||||
ADD_AUTOGEN_TEST(RerunMocBasic)
|
||||
ADD_AUTOGEN_TEST(RerunMocOnAddFile)
|
||||
ADD_AUTOGEN_TEST(RerunMocOnMissingDependency)
|
||||
ADD_AUTOGEN_TEST(RerunRccConfigChange)
|
||||
ADD_AUTOGEN_TEST(RerunRccDepends)
|
||||
ADD_AUTOGEN_TEST(SameName sameName)
|
||||
|
@ -143,14 +143,14 @@ if(CMAKE_GENERATOR MATCHES "Ninja")
|
||||
list(APPEND Ninja_ARGS -DTEST_Fortran=1)
|
||||
endif()
|
||||
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()
|
||||
add_RunCMake_test(Ninja)
|
||||
set(NinjaMultiConfig_ARGS
|
||||
-DCYGWIN=${CYGWIN}
|
||||
)
|
||||
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()
|
||||
if(DEFINED CMake_TEST_CUDA)
|
||||
list(APPEND NinjaMultiConfig_ARGS -DCMake_TEST_CUDA=${CMake_TEST_CUDA})
|
||||
|
@ -327,6 +327,7 @@ run_ChangeBuildType()
|
||||
function(run_Qt5AutoMocDeps)
|
||||
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_OPTIONS "-DQt5Core_DIR=${Qt5Core_DIR}")
|
||||
run_cmake(Qt5AutoMocDeps)
|
||||
unset(RunCMake_TEST_OPTIONS)
|
||||
# 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)
|
||||
|
||||
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)
|
||||
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")
|
||||
|
@ -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_cmake_build(CustomCommandsAndTargets debug-targetpostbuild Debug TopTargetPostBuild)
|
||||
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)
|
||||
|
||||
@ -300,9 +306,12 @@ endif()
|
||||
|
||||
if(CMake_TEST_Qt5)
|
||||
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)
|
||||
unset(RunCMake_TEST_OPTIONS)
|
||||
include(${RunCMake_TEST_BINARY_DIR}/target_files.cmake)
|
||||
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()
|
||||
|
@ -9,12 +9,13 @@ file(STRINGS "${csProjFile}" lines)
|
||||
include(${RunCMake_TEST_SOURCE_DIR}/VsCsharpSourceGroupHelpers.cmake)
|
||||
|
||||
set(SOURCE_GROUPS_TO_FIND
|
||||
"CSharpSourceGroup"
|
||||
"CSharpSourceGroup/nested"
|
||||
"Images"
|
||||
"CSharpSourceGroup\\\\foo\\.cs"
|
||||
"CSharpSourceGroup\\\\nested\\\\baz\\.cs"
|
||||
"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})
|
||||
if(NOT ${SOURCE_GROUP_FOUND})
|
||||
return()
|
||||
|
@ -9,8 +9,14 @@ set(SRC_FILES
|
||||
set(IMAGE_FILES
|
||||
${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/nested" FILES ${CMAKE_CURRENT_SOURCE_DIR}/CSharpSourceGroup/nested/baz.cs)
|
||||
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-3)
|
||||
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}
|
||||
--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
|
||||
|
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