|
|
@ -45,7 +45,7 @@ if (NOT CMAKE_SCRIPT_MODE_FILE)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
set (COTIRE_CMAKE_MODULE_FILE "${CMAKE_CURRENT_LIST_FILE}")
|
|
|
|
set (COTIRE_CMAKE_MODULE_FILE "${CMAKE_CURRENT_LIST_FILE}")
|
|
|
|
set (COTIRE_CMAKE_MODULE_VERSION "1.5.2")
|
|
|
|
set (COTIRE_CMAKE_MODULE_VERSION "1.6.6")
|
|
|
|
|
|
|
|
|
|
|
|
include(CMakeParseArguments)
|
|
|
|
include(CMakeParseArguments)
|
|
|
|
include(ProcessorCount)
|
|
|
|
include(ProcessorCount)
|
|
|
@ -59,13 +59,15 @@ function (cotire_determine_compiler_version _language _versionPrefix)
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
string (STRIP "${CMAKE_${_language}_COMPILER_ARG1}" _compilerArg1)
|
|
|
|
string (STRIP "${CMAKE_${_language}_COMPILER_ARG1}" _compilerArg1)
|
|
|
|
execute_process (COMMAND ${CMAKE_${_language}_COMPILER} ${_compilerArg1}
|
|
|
|
execute_process (
|
|
|
|
|
|
|
|
COMMAND ${CMAKE_${_language}_COMPILER} ${_compilerArg1}
|
|
|
|
ERROR_VARIABLE _versionLine OUTPUT_QUIET TIMEOUT 10)
|
|
|
|
ERROR_VARIABLE _versionLine OUTPUT_QUIET TIMEOUT 10)
|
|
|
|
string (REGEX REPLACE ".*Version *([0-9]+(\\.[0-9]+)*).*" "\\1" ${_versionPrefix}_VERSION "${_versionLine}")
|
|
|
|
string (REGEX REPLACE ".*Version *([0-9]+(\\.[0-9]+)*).*" "\\1" ${_versionPrefix}_VERSION "${_versionLine}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
# assume GCC like command line interface
|
|
|
|
# assume GCC like command line interface
|
|
|
|
string (STRIP "${CMAKE_${_language}_COMPILER_ARG1}" _compilerArg1)
|
|
|
|
string (STRIP "${CMAKE_${_language}_COMPILER_ARG1}" _compilerArg1)
|
|
|
|
execute_process (COMMAND ${CMAKE_${_language}_COMPILER} ${_compilerArg1} "-dumpversion"
|
|
|
|
execute_process (
|
|
|
|
|
|
|
|
COMMAND ${CMAKE_${_language}_COMPILER} ${_compilerArg1} "-dumpversion"
|
|
|
|
OUTPUT_VARIABLE ${_versionPrefix}_VERSION
|
|
|
|
OUTPUT_VARIABLE ${_versionPrefix}_VERSION
|
|
|
|
RESULT_VARIABLE _result
|
|
|
|
RESULT_VARIABLE _result
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE TIMEOUT 10)
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE TIMEOUT 10)
|
|
|
@ -255,6 +257,28 @@ function (cotire_copy_set_properites _configurations _type _source _target)
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_get_target_link_libraries_for_usage_requirements _target _targetLinkLibrariesVar)
|
|
|
|
|
|
|
|
set (_targetLinkLibraries "")
|
|
|
|
|
|
|
|
get_target_property(_librariesToProcess ${_target} LINK_LIBRARIES)
|
|
|
|
|
|
|
|
while (_librariesToProcess)
|
|
|
|
|
|
|
|
# remove from head
|
|
|
|
|
|
|
|
list (GET _librariesToProcess 0 _library)
|
|
|
|
|
|
|
|
list (REMOVE_AT _librariesToProcess 0)
|
|
|
|
|
|
|
|
list (FIND _targetLinkLibraries ${_library} _index)
|
|
|
|
|
|
|
|
if (_index LESS 0)
|
|
|
|
|
|
|
|
list (APPEND _targetLinkLibraries ${_library})
|
|
|
|
|
|
|
|
# process transitive libraries
|
|
|
|
|
|
|
|
if (TARGET ${_library})
|
|
|
|
|
|
|
|
get_target_property(_libraries ${_library} INTERFACE_LINK_LIBRARIES)
|
|
|
|
|
|
|
|
if (_libraries)
|
|
|
|
|
|
|
|
list (APPEND _librariesToProcess ${_libraries})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endwhile()
|
|
|
|
|
|
|
|
set (${_targetLinkLibrariesVar} ${_targetLinkLibraries} PARENT_SCOPE)
|
|
|
|
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_filter_compile_flags _language _flagFilter _matchedOptionsVar _unmatchedOptionsVar)
|
|
|
|
function (cotire_filter_compile_flags _language _flagFilter _matchedOptionsVar _unmatchedOptionsVar)
|
|
|
|
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
|
|
|
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
|
|
|
set (_flagPrefix "[/-]")
|
|
|
|
set (_flagPrefix "[/-]")
|
|
|
@ -366,6 +390,16 @@ function (cotire_get_target_compile_flags _config _language _directory _target _
|
|
|
|
if (_targetOptions)
|
|
|
|
if (_targetOptions)
|
|
|
|
set (_compileFlags "${_compileFlags} ${_targetOptions}")
|
|
|
|
set (_compileFlags "${_compileFlags} ${_targetOptions}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# interface compile options from linked library targets
|
|
|
|
|
|
|
|
cotire_get_target_link_libraries_for_usage_requirements(${_target} _linkLibraries)
|
|
|
|
|
|
|
|
foreach (_library ${_linkLibraries})
|
|
|
|
|
|
|
|
if (TARGET ${_library})
|
|
|
|
|
|
|
|
get_target_property(_targetOptions ${_library} INTERFACE_COMPILE_OPTIONS)
|
|
|
|
|
|
|
|
if (_targetOptions)
|
|
|
|
|
|
|
|
set (_compileFlags "${_compileFlags} ${_targetOptions}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endforeach()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if (UNIX)
|
|
|
|
if (UNIX)
|
|
|
|
separate_arguments(_compileFlags UNIX_COMMAND "${_compileFlags}")
|
|
|
|
separate_arguments(_compileFlags UNIX_COMMAND "${_compileFlags}")
|
|
|
@ -380,9 +414,11 @@ function (cotire_get_target_compile_flags _config _language _directory _target _
|
|
|
|
if (NOT _architectures)
|
|
|
|
if (NOT _architectures)
|
|
|
|
get_target_property(_architectures ${_target} OSX_ARCHITECTURES)
|
|
|
|
get_target_property(_architectures ${_target} OSX_ARCHITECTURES)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (_architectures)
|
|
|
|
foreach (_arch ${_architectures})
|
|
|
|
foreach (_arch ${_architectures})
|
|
|
|
list (APPEND _compileFlags "-arch" "${_arch}")
|
|
|
|
list (APPEND _compileFlags "-arch" "${_arch}")
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
if (CMAKE_OSX_SYSROOT)
|
|
|
|
if (CMAKE_OSX_SYSROOT)
|
|
|
|
if (CMAKE_${_language}_SYSROOT_FLAG)
|
|
|
|
if (CMAKE_${_language}_SYSROOT_FLAG)
|
|
|
|
list (APPEND _compileFlags "${CMAKE_${_language}_SYSROOT_FLAG}" "${CMAKE_OSX_SYSROOT}")
|
|
|
|
list (APPEND _compileFlags "${CMAKE_${_language}_SYSROOT_FLAG}" "${CMAKE_OSX_SYSROOT}")
|
|
|
@ -404,8 +440,9 @@ function (cotire_get_target_compile_flags _config _language _directory _target _
|
|
|
|
set (${_flagsVar} ${_compileFlags} PARENT_SCOPE)
|
|
|
|
set (${_flagsVar} ${_compileFlags} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_get_target_include_directories _config _language _targetSourceDir _targetBinaryDir _target _includeDirsVar)
|
|
|
|
function (cotire_get_target_include_directories _config _language _targetSourceDir _targetBinaryDir _target _includeDirsVar _systemIncludeDirsVar)
|
|
|
|
set (_includeDirs "")
|
|
|
|
set (_includeDirs "")
|
|
|
|
|
|
|
|
set (_systemIncludeDirs "")
|
|
|
|
# default include dirs
|
|
|
|
# default include dirs
|
|
|
|
if (CMAKE_INCLUDE_CURRENT_DIR)
|
|
|
|
if (CMAKE_INCLUDE_CURRENT_DIR)
|
|
|
|
list (APPEND _includeDirs "${_targetBinaryDir}")
|
|
|
|
list (APPEND _includeDirs "${_targetBinaryDir}")
|
|
|
@ -424,8 +461,29 @@ function (cotire_get_target_include_directories _config _language _targetSourceD
|
|
|
|
get_target_property(_targetDirs ${_target} INCLUDE_DIRECTORIES)
|
|
|
|
get_target_property(_targetDirs ${_target} INCLUDE_DIRECTORIES)
|
|
|
|
if (_targetDirs)
|
|
|
|
if (_targetDirs)
|
|
|
|
list (APPEND _dirs ${_targetDirs})
|
|
|
|
list (APPEND _dirs ${_targetDirs})
|
|
|
|
list (REMOVE_DUPLICATES _dirs)
|
|
|
|
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(_targetDirs ${_target} INTERFACE_SYSTEM_INCLUDE_DIRECTORIES)
|
|
|
|
|
|
|
|
if (_targetDirs)
|
|
|
|
|
|
|
|
list (APPEND _systemIncludeDirs ${_targetDirs})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# interface include directories from linked library targets
|
|
|
|
|
|
|
|
cotire_get_target_link_libraries_for_usage_requirements(${_target} _linkLibraries)
|
|
|
|
|
|
|
|
foreach (_library ${_linkLibraries})
|
|
|
|
|
|
|
|
if (TARGET ${_library})
|
|
|
|
|
|
|
|
get_target_property(_targetDirs ${_library} INTERFACE_INCLUDE_DIRECTORIES)
|
|
|
|
|
|
|
|
if (_targetDirs)
|
|
|
|
|
|
|
|
list (APPEND _dirs ${_targetDirs})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(_targetDirs ${_library} INTERFACE_SYSTEM_INCLUDE_DIRECTORIES)
|
|
|
|
|
|
|
|
if (_targetDirs)
|
|
|
|
|
|
|
|
list (APPEND _systemIncludeDirs ${_targetDirs})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (dirs)
|
|
|
|
|
|
|
|
list (REMOVE_DUPLICATES _dirs)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
list (LENGTH _includeDirs _projectInsertIndex)
|
|
|
|
list (LENGTH _includeDirs _projectInsertIndex)
|
|
|
|
foreach (_dir ${_dirs})
|
|
|
|
foreach (_dir ${_dirs})
|
|
|
@ -447,6 +505,7 @@ function (cotire_get_target_include_directories _config _language _targetSourceD
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
list (REMOVE_DUPLICATES _includeDirs)
|
|
|
|
list (REMOVE_DUPLICATES _includeDirs)
|
|
|
|
|
|
|
|
list (REMOVE_DUPLICATES _systemIncludeDirs)
|
|
|
|
if (CMAKE_${_language}_IMPLICIT_INCLUDE_DIRECTORIES)
|
|
|
|
if (CMAKE_${_language}_IMPLICIT_INCLUDE_DIRECTORIES)
|
|
|
|
list (REMOVE_ITEM _includeDirs ${CMAKE_${_language}_IMPLICIT_INCLUDE_DIRECTORIES})
|
|
|
|
list (REMOVE_ITEM _includeDirs ${CMAKE_${_language}_IMPLICIT_INCLUDE_DIRECTORIES})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -454,6 +513,10 @@ function (cotire_get_target_include_directories _config _language _targetSourceD
|
|
|
|
message (STATUS "Target ${_target} include dirs ${_includeDirs}")
|
|
|
|
message (STATUS "Target ${_target} include dirs ${_includeDirs}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_includeDirsVar} ${_includeDirs} PARENT_SCOPE)
|
|
|
|
set (${_includeDirsVar} ${_includeDirs} PARENT_SCOPE)
|
|
|
|
|
|
|
|
if (COTIRE_DEBUG AND _systemIncludeDirs)
|
|
|
|
|
|
|
|
message (STATUS "Target ${_target} system include dirs ${_systemIncludeDirs}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set (${_systemIncludeDirsVar} ${_systemIncludeDirs} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
macro (cotire_make_C_identifier _identifierVar _str)
|
|
|
|
macro (cotire_make_C_identifier _identifierVar _str)
|
|
|
@ -464,7 +527,7 @@ macro (cotire_make_C_identifier _identifierVar _str)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
string (REGEX REPLACE "[^a-zA-Z0-9]" "_" ${_identifierVar} "${_str}")
|
|
|
|
string (REGEX REPLACE "[^a-zA-Z0-9]" "_" ${_identifierVar} "${_str}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
string (MAKE_C_IDENTIFIER "${_identifierVar}" "${_str}")
|
|
|
|
string (MAKE_C_IDENTIFIER "${_str}" "${_identifierVar}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endmacro()
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
|
|
|
@ -513,6 +576,16 @@ function (cotire_get_target_compile_definitions _config _language _directory _ta
|
|
|
|
if (_definitions)
|
|
|
|
if (_definitions)
|
|
|
|
list (APPEND _configDefinitions ${_definitions})
|
|
|
|
list (APPEND _configDefinitions ${_definitions})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# interface compile definitions from linked library targets
|
|
|
|
|
|
|
|
cotire_get_target_link_libraries_for_usage_requirements(${_target} _linkLibraries)
|
|
|
|
|
|
|
|
foreach (_library ${_linkLibraries})
|
|
|
|
|
|
|
|
if (TARGET ${_library})
|
|
|
|
|
|
|
|
get_target_property(_definitions ${_library} INTERFACE_COMPILE_DEFINITIONS)
|
|
|
|
|
|
|
|
if (_definitions)
|
|
|
|
|
|
|
|
list (APPEND _configDefinitions ${_definitions})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endforeach()
|
|
|
|
# parse additional compile definitions from target compile flags
|
|
|
|
# parse additional compile definitions from target compile flags
|
|
|
|
# and don't look at directory compile definitions, which we already handled
|
|
|
|
# and don't look at directory compile definitions, which we already handled
|
|
|
|
set (_targetFlags "")
|
|
|
|
set (_targetFlags "")
|
|
|
@ -678,14 +751,19 @@ macro (cotire_add_definitions_to_cmd _cmdVar _language)
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endmacro()
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
|
|
|
|
macro (cotire_add_includes_to_cmd _cmdVar _language)
|
|
|
|
macro (cotire_add_includes_to_cmd _cmdVar _language _includeSystemFlag _includesVar _systemIncludesVar)
|
|
|
|
foreach (_include ${ARGN})
|
|
|
|
foreach (_include ${${_includesVar}})
|
|
|
|
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
|
|
|
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
|
|
|
file (TO_NATIVE_PATH "${_include}" _include)
|
|
|
|
file (TO_NATIVE_PATH "${_include}" _include)
|
|
|
|
list (APPEND ${_cmdVar} "/I${_include}")
|
|
|
|
list (APPEND ${_cmdVar} "/I${_include}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
list (FIND ${_systemIncludesVar} ${_include} _index)
|
|
|
|
|
|
|
|
if(_index GREATER -1 AND NOT "${_includeSystemFlag}" STREQUAL "")
|
|
|
|
|
|
|
|
list (APPEND ${_cmdVar} "${_includeSystemFlag}${_include}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
list (APPEND ${_cmdVar} "-I${_include}")
|
|
|
|
list (APPEND ${_cmdVar} "-I${_include}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
endmacro()
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
|
|
|
@ -856,7 +934,7 @@ function (cotire_parse_includes _language _scanOutput _ignoredIncudeDirs _honore
|
|
|
|
# remove duplicate lines to speed up parsing
|
|
|
|
# remove duplicate lines to speed up parsing
|
|
|
|
list (REMOVE_DUPLICATES _scanOutput)
|
|
|
|
list (REMOVE_DUPLICATES _scanOutput)
|
|
|
|
list (LENGTH _scanOutput _uniqueLen)
|
|
|
|
list (LENGTH _scanOutput _uniqueLen)
|
|
|
|
if (COTIRE_VERBOSE)
|
|
|
|
if (COTIRE_VERBOSE OR COTIRE_DEBUG)
|
|
|
|
message (STATUS "Scanning ${_uniqueLen} unique lines of ${_len} for includes")
|
|
|
|
message (STATUS "Scanning ${_uniqueLen} unique lines of ${_len} for includes")
|
|
|
|
if (_ignoredExtensions)
|
|
|
|
if (_ignoredExtensions)
|
|
|
|
message (STATUS "Ignored extensions: ${_ignoredExtensions}")
|
|
|
|
message (STATUS "Ignored extensions: ${_ignoredExtensions}")
|
|
|
@ -945,8 +1023,8 @@ endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_scan_includes _includesVar)
|
|
|
|
function (cotire_scan_includes _includesVar)
|
|
|
|
set(_options "")
|
|
|
|
set(_options "")
|
|
|
|
set(_oneValueArgs COMPILER_ID COMPILER_EXECUTABLE COMPILER_VERSION LANGUAGE UNPARSED_LINES)
|
|
|
|
set(_oneValueArgs COMPILER_ID COMPILER_EXECUTABLE COMPILER_VERSION INCLUDE_SYSTEM_FLAG LANGUAGE UNPARSED_LINES)
|
|
|
|
set(_multiValueArgs COMPILE_DEFINITIONS COMPILE_FLAGS INCLUDE_DIRECTORIES IGNORE_PATH INCLUDE_PATH IGNORE_EXTENSIONS)
|
|
|
|
set(_multiValueArgs COMPILE_DEFINITIONS COMPILE_FLAGS INCLUDE_DIRECTORIES SYSTEM_INCLUDE_DIRECTORIES IGNORE_PATH INCLUDE_PATH IGNORE_EXTENSIONS)
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
set (_sourceFiles ${_option_UNPARSED_ARGUMENTS})
|
|
|
|
set (_sourceFiles ${_option_UNPARSED_ARGUMENTS})
|
|
|
|
if (NOT _option_LANGUAGE)
|
|
|
|
if (NOT _option_LANGUAGE)
|
|
|
@ -959,7 +1037,7 @@ function (cotire_scan_includes _includesVar)
|
|
|
|
cotire_init_compile_cmd(_cmd "${_option_LANGUAGE}" "${_option_COMPILER_EXECUTABLE}" "${_option_COMPILER_ARG1}")
|
|
|
|
cotire_init_compile_cmd(_cmd "${_option_LANGUAGE}" "${_option_COMPILER_EXECUTABLE}" "${_option_COMPILER_ARG1}")
|
|
|
|
cotire_add_definitions_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_COMPILE_DEFINITIONS})
|
|
|
|
cotire_add_definitions_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_COMPILE_DEFINITIONS})
|
|
|
|
cotire_add_compile_flags_to_cmd(_cmd ${_option_COMPILE_FLAGS})
|
|
|
|
cotire_add_compile_flags_to_cmd(_cmd ${_option_COMPILE_FLAGS})
|
|
|
|
cotire_add_includes_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_includes_to_cmd(_cmd "${_option_LANGUAGE}" "${_option_INCLUDE_SYSTEM_FLAG}" _option_INCLUDE_DIRECTORIES _option_SYSTEM_INCLUDE_DIRECTORIES)
|
|
|
|
cotire_add_frameworks_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_frameworks_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_makedep_flags("${_option_LANGUAGE}" "${_option_COMPILER_ID}" "${_option_COMPILER_VERSION}" _cmd)
|
|
|
|
cotire_add_makedep_flags("${_option_LANGUAGE}" "${_option_COMPILER_ID}" "${_option_COMPILER_VERSION}" _cmd)
|
|
|
|
# only consider existing source files for scanning
|
|
|
|
# only consider existing source files for scanning
|
|
|
@ -984,7 +1062,8 @@ function (cotire_scan_includes _includesVar)
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
execute_process(COMMAND ${_cmd} WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
|
|
|
execute_process(
|
|
|
|
|
|
|
|
COMMAND ${_cmd} WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
|
|
|
RESULT_VARIABLE _result OUTPUT_QUIET ERROR_VARIABLE _output)
|
|
|
|
RESULT_VARIABLE _result OUTPUT_QUIET ERROR_VARIABLE _output)
|
|
|
|
if (_result)
|
|
|
|
if (_result)
|
|
|
|
message (STATUS "Result ${_result} scanning includes of ${_existingSourceFiles}.")
|
|
|
|
message (STATUS "Result ${_result} scanning includes of ${_existingSourceFiles}.")
|
|
|
@ -1136,18 +1215,28 @@ endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_generate_prefix_header _prefixFile)
|
|
|
|
function (cotire_generate_prefix_header _prefixFile)
|
|
|
|
set(_options "")
|
|
|
|
set(_options "")
|
|
|
|
set(_oneValueArgs LANGUAGE COMPILER_EXECUTABLE COMPILER_ID COMPILER_VERSION)
|
|
|
|
set(_oneValueArgs LANGUAGE COMPILER_EXECUTABLE COMPILER_ID COMPILER_VERSION INCLUDE_SYSTEM_FLAG)
|
|
|
|
set(_multiValueArgs DEPENDS COMPILE_DEFINITIONS COMPILE_FLAGS
|
|
|
|
set(_multiValueArgs DEPENDS COMPILE_DEFINITIONS COMPILE_FLAGS
|
|
|
|
INCLUDE_DIRECTORIES IGNORE_PATH INCLUDE_PATH IGNORE_EXTENSIONS)
|
|
|
|
INCLUDE_DIRECTORIES SYSTEM_INCLUDE_DIRECTORIES IGNORE_PATH INCLUDE_PATH IGNORE_EXTENSIONS)
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
if (_option_DEPENDS)
|
|
|
|
if (_option_DEPENDS)
|
|
|
|
cotire_check_file_up_to_date(_prefixFileIsUpToDate "${_prefixFile}" ${_option_DEPENDS})
|
|
|
|
cotire_check_file_up_to_date(_prefixFileIsUpToDate "${_prefixFile}" ${_option_DEPENDS})
|
|
|
|
if (_prefixFileIsUpToDate)
|
|
|
|
if (_prefixFileIsUpToDate)
|
|
|
|
|
|
|
|
set (_unparsedLinesFile "${_prefixFile}.log")
|
|
|
|
|
|
|
|
file (WRITE "${_unparsedLinesFile}" "")
|
|
|
|
return()
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set (_prologue "")
|
|
|
|
set (_epilogue "")
|
|
|
|
set (_epilogue "")
|
|
|
|
if (_option_COMPILER_ID MATCHES "Intel")
|
|
|
|
if (_option_COMPILER_ID MATCHES "Clang")
|
|
|
|
|
|
|
|
set (_prologue "#pragma clang system_header")
|
|
|
|
|
|
|
|
elseif (_option_COMPILER_ID MATCHES "GNU")
|
|
|
|
|
|
|
|
set (_prologue "#pragma GCC system_header")
|
|
|
|
|
|
|
|
elseif (_option_COMPILER_ID MATCHES "MSVC")
|
|
|
|
|
|
|
|
set (_prologue "#pragma warning(push, 0)")
|
|
|
|
|
|
|
|
set (_epilogue "#pragma warning(pop)")
|
|
|
|
|
|
|
|
elseif (_option_COMPILER_ID MATCHES "Intel")
|
|
|
|
# Intel compiler requires hdrstop pragma to stop generating PCH file
|
|
|
|
# Intel compiler requires hdrstop pragma to stop generating PCH file
|
|
|
|
set (_epilogue "#pragma hdrstop")
|
|
|
|
set (_epilogue "#pragma hdrstop")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -1160,11 +1249,14 @@ function (cotire_generate_prefix_header _prefixFile)
|
|
|
|
COMPILE_DEFINITIONS ${_option_COMPILE_DEFINITIONS}
|
|
|
|
COMPILE_DEFINITIONS ${_option_COMPILE_DEFINITIONS}
|
|
|
|
COMPILE_FLAGS ${_option_COMPILE_FLAGS}
|
|
|
|
COMPILE_FLAGS ${_option_COMPILE_FLAGS}
|
|
|
|
INCLUDE_DIRECTORIES ${_option_INCLUDE_DIRECTORIES}
|
|
|
|
INCLUDE_DIRECTORIES ${_option_INCLUDE_DIRECTORIES}
|
|
|
|
|
|
|
|
INCLUDE_SYSTEM_FLAG ${_option_INCLUDE_SYSTEM_FLAG}
|
|
|
|
|
|
|
|
SYSTEM_INCLUDE_DIRECTORIES ${_option_SYSTEM_INCLUDE_DIRECTORIES}
|
|
|
|
IGNORE_PATH ${_option_IGNORE_PATH}
|
|
|
|
IGNORE_PATH ${_option_IGNORE_PATH}
|
|
|
|
INCLUDE_PATH ${_option_INCLUDE_PATH}
|
|
|
|
INCLUDE_PATH ${_option_INCLUDE_PATH}
|
|
|
|
IGNORE_EXTENSIONS ${_option_IGNORE_EXTENSIONS}
|
|
|
|
IGNORE_EXTENSIONS ${_option_IGNORE_EXTENSIONS}
|
|
|
|
UNPARSED_LINES _unparsedLines)
|
|
|
|
UNPARSED_LINES _unparsedLines)
|
|
|
|
cotire_generate_unity_source("${_prefixFile}" EPILOGUE ${_epilogue} LANGUAGE "${_option_LANGUAGE}" ${_selectedHeaders})
|
|
|
|
cotire_generate_unity_source("${_prefixFile}"
|
|
|
|
|
|
|
|
PROLOGUE ${_prologue} EPILOGUE ${_epilogue} LANGUAGE "${_option_LANGUAGE}" ${_selectedHeaders})
|
|
|
|
set (_unparsedLinesFile "${_prefixFile}.log")
|
|
|
|
set (_unparsedLinesFile "${_prefixFile}.log")
|
|
|
|
if (_unparsedLines)
|
|
|
|
if (_unparsedLines)
|
|
|
|
if (COTIRE_VERBOSE OR NOT _selectedHeaders)
|
|
|
|
if (COTIRE_VERBOSE OR NOT _selectedHeaders)
|
|
|
@ -1261,7 +1353,7 @@ function (cotire_add_makedep_flags _language _compilerID _compilerVersion _flags
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (FATAL_ERROR "Unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
message (FATAL_ERROR "cotire: unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
@ -1294,6 +1386,8 @@ function (cotire_add_pch_compilation_flags _language _compilerID _compilerVersio
|
|
|
|
# -x specify the source language
|
|
|
|
# -x specify the source language
|
|
|
|
# -c compile but do not link
|
|
|
|
# -c compile but do not link
|
|
|
|
# -o place output in file
|
|
|
|
# -o place output in file
|
|
|
|
|
|
|
|
# note that we cannot use -w to suppress all warnings upon pre-compiling, because turning off a warning may
|
|
|
|
|
|
|
|
# alter compile flags as a side effect (e.g., -Wwrite-string implies -fconst-strings)
|
|
|
|
set (_xLanguage_C "c-header")
|
|
|
|
set (_xLanguage_C "c-header")
|
|
|
|
set (_xLanguage_CXX "c++-header")
|
|
|
|
set (_xLanguage_CXX "c++-header")
|
|
|
|
if (_flags)
|
|
|
|
if (_flags)
|
|
|
@ -1362,7 +1456,7 @@ function (cotire_add_pch_compilation_flags _language _compilerID _compilerVersio
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (FATAL_ERROR "Unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
message (FATAL_ERROR "cotire: unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
@ -1398,17 +1492,20 @@ function (cotire_add_prefix_pch_inclusion_flags _language _compilerID _compilerV
|
|
|
|
# GCC options used
|
|
|
|
# GCC options used
|
|
|
|
# -include process include file as the first line of the primary source file
|
|
|
|
# -include process include file as the first line of the primary source file
|
|
|
|
# -Winvalid-pch warns if precompiled header is found but cannot be used
|
|
|
|
# -Winvalid-pch warns if precompiled header is found but cannot be used
|
|
|
|
|
|
|
|
# note: ccache requires the -include flag to be used in order to process precompiled header correctly
|
|
|
|
if (_flags)
|
|
|
|
if (_flags)
|
|
|
|
# append to list
|
|
|
|
# append to list
|
|
|
|
list (APPEND _flags "-include" "${_prefixFile}" "-Winvalid-pch")
|
|
|
|
list (APPEND _flags "-Winvalid-pch" "-include" "${_prefixFile}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
# return as a flag string
|
|
|
|
# return as a flag string
|
|
|
|
set (_flags "-include \"${_prefixFile}\" -Winvalid-pch")
|
|
|
|
set (_flags "-Winvalid-pch -include \"${_prefixFile}\"")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
elseif (_compilerID MATCHES "Clang")
|
|
|
|
elseif (_compilerID MATCHES "Clang")
|
|
|
|
# Clang options used
|
|
|
|
# Clang options used
|
|
|
|
# -include process include file as the first line of the primary source file
|
|
|
|
# -include process include file as the first line of the primary source file
|
|
|
|
|
|
|
|
# -include-pch include precompiled header file
|
|
|
|
# -Qunused-arguments don't emit warning for unused driver arguments
|
|
|
|
# -Qunused-arguments don't emit warning for unused driver arguments
|
|
|
|
|
|
|
|
# note: ccache requires the -include flag to be used in order to process precompiled header correctly
|
|
|
|
if (_flags)
|
|
|
|
if (_flags)
|
|
|
|
# append to list
|
|
|
|
# append to list
|
|
|
|
list (APPEND _flags "-Qunused-arguments" "-include" "${_prefixFile}")
|
|
|
|
list (APPEND _flags "-Qunused-arguments" "-include" "${_prefixFile}")
|
|
|
@ -1483,15 +1580,15 @@ function (cotire_add_prefix_pch_inclusion_flags _language _compilerID _compilerV
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (FATAL_ERROR "Unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
message (FATAL_ERROR "cotire: unsupported ${_language} compiler ${_compilerID} version ${_compilerVersion}.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
set (${_flagsVar} ${_flags} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_precompile_prefix_header _prefixFile _pchFile _hostFile)
|
|
|
|
function (cotire_precompile_prefix_header _prefixFile _pchFile _hostFile)
|
|
|
|
set(_options "")
|
|
|
|
set(_options "")
|
|
|
|
set(_oneValueArgs COMPILER_EXECUTABLE COMPILER_ID COMPILER_VERSION LANGUAGE)
|
|
|
|
set(_oneValueArgs COMPILER_EXECUTABLE COMPILER_ID COMPILER_VERSION INCLUDE_SYSTEM_FLAG LANGUAGE)
|
|
|
|
set(_multiValueArgs COMPILE_DEFINITIONS COMPILE_FLAGS INCLUDE_DIRECTORIES)
|
|
|
|
set(_multiValueArgs COMPILE_DEFINITIONS COMPILE_FLAGS INCLUDE_DIRECTORIES SYSTEM_INCLUDE_DIRECTORIES SYS)
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
cmake_parse_arguments(_option "${_options}" "${_oneValueArgs}" "${_multiValueArgs}" ${ARGN})
|
|
|
|
if (NOT _option_LANGUAGE)
|
|
|
|
if (NOT _option_LANGUAGE)
|
|
|
|
set (_option_LANGUAGE "CXX")
|
|
|
|
set (_option_LANGUAGE "CXX")
|
|
|
@ -1502,7 +1599,7 @@ function (cotire_precompile_prefix_header _prefixFile _pchFile _hostFile)
|
|
|
|
cotire_init_compile_cmd(_cmd "${_option_LANGUAGE}" "${_option_COMPILER_EXECUTABLE}" "${_option_COMPILER_ARG1}")
|
|
|
|
cotire_init_compile_cmd(_cmd "${_option_LANGUAGE}" "${_option_COMPILER_EXECUTABLE}" "${_option_COMPILER_ARG1}")
|
|
|
|
cotire_add_definitions_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_COMPILE_DEFINITIONS})
|
|
|
|
cotire_add_definitions_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_COMPILE_DEFINITIONS})
|
|
|
|
cotire_add_compile_flags_to_cmd(_cmd ${_option_COMPILE_FLAGS})
|
|
|
|
cotire_add_compile_flags_to_cmd(_cmd ${_option_COMPILE_FLAGS})
|
|
|
|
cotire_add_includes_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_includes_to_cmd(_cmd "${_option_LANGUAGE}" "${_option_INCLUDE_SYSTEM_FLAG}" _option_INCLUDE_DIRECTORIES _option_SYSTEM_INCLUDE_DIRECTORIES)
|
|
|
|
cotire_add_frameworks_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_frameworks_to_cmd(_cmd "${_option_LANGUAGE}" ${_option_INCLUDE_DIRECTORIES})
|
|
|
|
cotire_add_pch_compilation_flags(
|
|
|
|
cotire_add_pch_compilation_flags(
|
|
|
|
"${_option_LANGUAGE}" "${_option_COMPILER_ID}" "${_option_COMPILER_VERSION}"
|
|
|
|
"${_option_LANGUAGE}" "${_option_COMPILER_ID}" "${_option_COMPILER_VERSION}"
|
|
|
@ -1517,9 +1614,12 @@ function (cotire_precompile_prefix_header _prefixFile _pchFile _hostFile)
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
# cl.exe messes with the output streams unless the environment variable VS_UNICODE_OUTPUT is cleared
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
unset (ENV{VS_UNICODE_OUTPUT})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
execute_process(COMMAND ${_cmd} WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" RESULT_VARIABLE _result)
|
|
|
|
execute_process(
|
|
|
|
|
|
|
|
COMMAND ${_cmd}
|
|
|
|
|
|
|
|
WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}"
|
|
|
|
|
|
|
|
RESULT_VARIABLE _result)
|
|
|
|
if (_result)
|
|
|
|
if (_result)
|
|
|
|
message (FATAL_ERROR "Error ${_result} precompiling ${_prefixFile}.")
|
|
|
|
message (FATAL_ERROR "cotire: error ${_result} precompiling ${_prefixFile}.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
@ -1554,6 +1654,13 @@ function (cotire_check_precompiled_header_support _language _targetSourceDir _ta
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
set (${_msgVar} "${_unsupportedCompiler}." PARENT_SCOPE)
|
|
|
|
set (${_msgVar} "${_unsupportedCompiler}." PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER MATCHES "ccache")
|
|
|
|
|
|
|
|
if (NOT "$ENV{CCACHE_SLOPPINESS}" MATCHES "time_macros")
|
|
|
|
|
|
|
|
set (${_msgVar}
|
|
|
|
|
|
|
|
"ccache requires the environment variable CCACHE_SLOPPINESS to be set to time_macros."
|
|
|
|
|
|
|
|
PARENT_SCOPE)
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
if (APPLE)
|
|
|
|
if (APPLE)
|
|
|
|
# PCH compilation not supported by GCC / Clang for multi-architecture builds (e.g., i386, x86_64)
|
|
|
|
# PCH compilation not supported by GCC / Clang for multi-architecture builds (e.g., i386, x86_64)
|
|
|
|
if (CMAKE_CONFIGURATION_TYPES)
|
|
|
|
if (CMAKE_CONFIGURATION_TYPES)
|
|
|
@ -1588,6 +1695,8 @@ macro (cotire_setup_file_extension_variables)
|
|
|
|
set (_unityFileExt_CXX ".cxx")
|
|
|
|
set (_unityFileExt_CXX ".cxx")
|
|
|
|
set (_prefixFileExt_C ".h")
|
|
|
|
set (_prefixFileExt_C ".h")
|
|
|
|
set (_prefixFileExt_CXX ".hxx")
|
|
|
|
set (_prefixFileExt_CXX ".hxx")
|
|
|
|
|
|
|
|
set (_prefixSourceFileExt_C ".c")
|
|
|
|
|
|
|
|
set (_prefixSourceFileExt_CXX ".cxx")
|
|
|
|
endmacro()
|
|
|
|
endmacro()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_make_single_unity_source_file_path _language _target _unityFileVar)
|
|
|
|
function (cotire_make_single_unity_source_file_path _language _target _unityFileVar)
|
|
|
@ -1661,6 +1770,16 @@ function (cotire_unity_to_prefix_file_path _language _target _unityFile _prefixF
|
|
|
|
set (${_prefixFileVar} "${_prefixFile}" PARENT_SCOPE)
|
|
|
|
set (${_prefixFileVar} "${_prefixFile}" PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_prefix_header_to_source_file_path _language _prefixHeaderFile _prefixSourceFileVar)
|
|
|
|
|
|
|
|
cotire_setup_file_extension_variables()
|
|
|
|
|
|
|
|
if (NOT DEFINED _prefixSourceFileExt_${_language})
|
|
|
|
|
|
|
|
set (${_prefixSourceFileVar} "" PARENT_SCOPE)
|
|
|
|
|
|
|
|
return()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
string (REGEX REPLACE "${_prefixFileExt_${_language}}$" "${_prefixSourceFileExt_${_language}}" _prefixSourceFile "${_prefixHeaderFile}")
|
|
|
|
|
|
|
|
set (${_prefixSourceFileVar} "${_prefixSourceFile}" PARENT_SCOPE)
|
|
|
|
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_make_prefix_file_name _language _target _prefixFileBaseNameVar _prefixFileNameVar)
|
|
|
|
function (cotire_make_prefix_file_name _language _target _prefixFileBaseNameVar _prefixFileNameVar)
|
|
|
|
cotire_setup_file_extension_variables()
|
|
|
|
cotire_setup_file_extension_variables()
|
|
|
|
if (NOT _language)
|
|
|
|
if (NOT _language)
|
|
|
@ -1705,8 +1824,11 @@ function (cotire_make_pch_file_path _language _targetSourceDir _target _pchFileV
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC")
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC")
|
|
|
|
# MSVC uses the extension .pch added to the prefix header base name
|
|
|
|
# MSVC uses the extension .pch added to the prefix header base name
|
|
|
|
set (${_pchFileVar} "${_baseDir}/${_prefixFileBaseName}.pch" PARENT_SCOPE)
|
|
|
|
set (${_pchFileVar} "${_baseDir}/${_prefixFileBaseName}.pch" PARENT_SCOPE)
|
|
|
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Clang")
|
|
|
|
# GCC / Clang look for a precompiled header corresponding to the prefix header with the extension .gch appended
|
|
|
|
# Clang looks for a precompiled header corresponding to the prefix header with the extension .pch appended
|
|
|
|
|
|
|
|
set (${_pchFileVar} "${_baseDir}/${_prefixFileName}.pch" PARENT_SCOPE)
|
|
|
|
|
|
|
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "GNU")
|
|
|
|
|
|
|
|
# GCC looks for a precompiled header corresponding to the prefix header with the extension .gch appended
|
|
|
|
set (${_pchFileVar} "${_baseDir}/${_prefixFileName}.gch" PARENT_SCOPE)
|
|
|
|
set (${_pchFileVar} "${_baseDir}/${_prefixFileName}.gch" PARENT_SCOPE)
|
|
|
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Intel")
|
|
|
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Intel")
|
|
|
|
# Intel uses the extension .pchi added to the prefix header base name
|
|
|
|
# Intel uses the extension .pchi added to the prefix header base name
|
|
|
@ -1768,16 +1890,22 @@ function (cotire_get_prefix_header_dependencies _language _target _dependencySou
|
|
|
|
# depend on target source files marked with custom COTIRE_DEPENDENCY property
|
|
|
|
# depend on target source files marked with custom COTIRE_DEPENDENCY property
|
|
|
|
set (_dependencySources "")
|
|
|
|
set (_dependencySources "")
|
|
|
|
cotire_get_objects_with_property_on(_dependencySources COTIRE_DEPENDENCY SOURCE ${ARGN})
|
|
|
|
cotire_get_objects_with_property_on(_dependencySources COTIRE_DEPENDENCY SOURCE ${ARGN})
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
|
|
|
|
# GCC and clang raise a fatal error if a file is not found during preprocessing
|
|
|
|
|
|
|
|
# thus we depend on target's generated source files for prefix header generation
|
|
|
|
|
|
|
|
cotire_get_objects_with_property_on(_generatedSources GENERATED SOURCE ${ARGN})
|
|
|
|
|
|
|
|
if (_generatedSources)
|
|
|
|
|
|
|
|
list (APPEND _dependencySources ${_generatedSources})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
if (COTIRE_DEBUG AND _dependencySources)
|
|
|
|
if (COTIRE_DEBUG AND _dependencySources)
|
|
|
|
message (STATUS "${_language} ${_target} prefix header DEPENDS ${_dependencySources}")
|
|
|
|
message (STATUS "${_language} ${_target} prefix header DEPENDS ${_dependencySources}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_dependencySourcesVar} ${_dependencySources} PARENT_SCOPE)
|
|
|
|
set (${_dependencySourcesVar} ${_dependencySources} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_generate_target_script _language _configurations _targetSourceDir _targetBinaryDir _target _targetScriptVar)
|
|
|
|
function (cotire_generate_target_script _language _configurations _targetSourceDir _targetBinaryDir _target _targetScriptVar _targetConfigScriptVar)
|
|
|
|
set (COTIRE_TARGET_SOURCES ${ARGN})
|
|
|
|
set (COTIRE_TARGET_SOURCES ${ARGN})
|
|
|
|
get_filename_component(_moduleName "${COTIRE_CMAKE_MODULE_FILE}" NAME)
|
|
|
|
|
|
|
|
set (_targetCotireScript "${CMAKE_CURRENT_BINARY_DIR}/${_target}_${_language}_${_moduleName}")
|
|
|
|
|
|
|
|
cotire_get_prefix_header_dependencies(${_language} ${_target} COTIRE_TARGET_PREFIX_DEPENDS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_prefix_header_dependencies(${_language} ${_target} COTIRE_TARGET_PREFIX_DEPENDS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_unity_source_dependencies(${_language} ${_target} COTIRE_TARGET_UNITY_DEPENDS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_unity_source_dependencies(${_language} ${_target} COTIRE_TARGET_UNITY_DEPENDS ${COTIRE_TARGET_SOURCES})
|
|
|
|
# set up variables to be configured
|
|
|
|
# set up variables to be configured
|
|
|
@ -1792,11 +1920,12 @@ function (cotire_generate_target_script _language _configurations _targetSourceD
|
|
|
|
get_target_property(COTIRE_TARGET_MAXIMUM_NUMBER_OF_INCLUDES ${_target} COTIRE_UNITY_SOURCE_MAXIMUM_NUMBER_OF_INCLUDES)
|
|
|
|
get_target_property(COTIRE_TARGET_MAXIMUM_NUMBER_OF_INCLUDES ${_target} COTIRE_UNITY_SOURCE_MAXIMUM_NUMBER_OF_INCLUDES)
|
|
|
|
cotire_get_source_files_undefs(COTIRE_UNITY_SOURCE_PRE_UNDEFS COTIRE_TARGET_SOURCES_PRE_UNDEFS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_source_files_undefs(COTIRE_UNITY_SOURCE_PRE_UNDEFS COTIRE_TARGET_SOURCES_PRE_UNDEFS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_source_files_undefs(COTIRE_UNITY_SOURCE_POST_UNDEFS COTIRE_TARGET_SOURCES_POST_UNDEFS ${COTIRE_TARGET_SOURCES})
|
|
|
|
cotire_get_source_files_undefs(COTIRE_UNITY_SOURCE_POST_UNDEFS COTIRE_TARGET_SOURCES_POST_UNDEFS ${COTIRE_TARGET_SOURCES})
|
|
|
|
|
|
|
|
string (STRIP "${CMAKE_INCLUDE_SYSTEM_FLAG_${_language}}" COTIRE_INCLUDE_SYSTEM_FLAG)
|
|
|
|
set (COTIRE_TARGET_CONFIGURATION_TYPES "${_configurations}")
|
|
|
|
set (COTIRE_TARGET_CONFIGURATION_TYPES "${_configurations}")
|
|
|
|
foreach (_config ${_configurations})
|
|
|
|
foreach (_config ${_configurations})
|
|
|
|
string (TOUPPER "${_config}" _upperConfig)
|
|
|
|
string (TOUPPER "${_config}" _upperConfig)
|
|
|
|
cotire_get_target_include_directories(
|
|
|
|
cotire_get_target_include_directories(
|
|
|
|
"${_config}" "${_language}" "${_targetSourceDir}" "${_targetBinaryDir}" "${_target}" COTIRE_TARGET_INCLUDE_DIRECTORIES_${_upperConfig})
|
|
|
|
"${_config}" "${_language}" "${_targetSourceDir}" "${_targetBinaryDir}" "${_target}" COTIRE_TARGET_INCLUDE_DIRECTORIES_${_upperConfig} COTIRE_TARGET_SYSTEM_INCLUDE_DIRECTORIES_${_upperConfig})
|
|
|
|
cotire_get_target_compile_definitions(
|
|
|
|
cotire_get_target_compile_definitions(
|
|
|
|
"${_config}" "${_language}" "${_targetSourceDir}" "${_target}" COTIRE_TARGET_COMPILE_DEFINITIONS_${_upperConfig})
|
|
|
|
"${_config}" "${_language}" "${_targetSourceDir}" "${_target}" COTIRE_TARGET_COMPILE_DEFINITIONS_${_upperConfig})
|
|
|
|
cotire_get_target_compiler_flags(
|
|
|
|
cotire_get_target_compiler_flags(
|
|
|
@ -1809,6 +1938,7 @@ function (cotire_generate_target_script _language _configurations _targetSourceD
|
|
|
|
# remove COTIRE_VERBOSE which is passed as a CMake define on command line
|
|
|
|
# remove COTIRE_VERBOSE which is passed as a CMake define on command line
|
|
|
|
list (REMOVE_ITEM _matchVars COTIRE_VERBOSE)
|
|
|
|
list (REMOVE_ITEM _matchVars COTIRE_VERBOSE)
|
|
|
|
set (_contents "")
|
|
|
|
set (_contents "")
|
|
|
|
|
|
|
|
set (_contentsHasGeneratorExpressions FALSE)
|
|
|
|
foreach (_var IN LISTS _matchVars ITEMS
|
|
|
|
foreach (_var IN LISTS _matchVars ITEMS
|
|
|
|
MSVC CMAKE_GENERATOR CMAKE_BUILD_TYPE CMAKE_CONFIGURATION_TYPES
|
|
|
|
MSVC CMAKE_GENERATOR CMAKE_BUILD_TYPE CMAKE_CONFIGURATION_TYPES
|
|
|
|
CMAKE_${_language}_COMPILER_ID CMAKE_${_language}_COMPILER CMAKE_${_language}_COMPILER_ARG1
|
|
|
|
CMAKE_${_language}_COMPILER_ID CMAKE_${_language}_COMPILER CMAKE_${_language}_COMPILER_ARG1
|
|
|
@ -1816,10 +1946,32 @@ function (cotire_generate_target_script _language _configurations _targetSourceD
|
|
|
|
if (DEFINED ${_var})
|
|
|
|
if (DEFINED ${_var})
|
|
|
|
string (REPLACE "\"" "\\\"" _value "${${_var}}")
|
|
|
|
string (REPLACE "\"" "\\\"" _value "${${_var}}")
|
|
|
|
set (_contents "${_contents}set (${_var} \"${_value}\")\n")
|
|
|
|
set (_contents "${_contents}set (${_var} \"${_value}\")\n")
|
|
|
|
|
|
|
|
if (NOT _contentsHasGeneratorExpressions)
|
|
|
|
|
|
|
|
if ("${_value}" MATCHES "\\$<.*>")
|
|
|
|
|
|
|
|
set (_contentsHasGeneratorExpressions TRUE)
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
get_filename_component(_moduleName "${COTIRE_CMAKE_MODULE_FILE}" NAME)
|
|
|
|
|
|
|
|
set (_targetCotireScript "${CMAKE_CURRENT_BINARY_DIR}/${_target}_${_language}_${_moduleName}")
|
|
|
|
cotire_write_file("CMAKE" "${_targetCotireScript}" "${_contents}" FALSE)
|
|
|
|
cotire_write_file("CMAKE" "${_targetCotireScript}" "${_contents}" FALSE)
|
|
|
|
|
|
|
|
if (_contentsHasGeneratorExpressions)
|
|
|
|
|
|
|
|
# use file(GENERATE ...) to expand generator expressions in the target script at CMake generate-time
|
|
|
|
|
|
|
|
if (NOT CMAKE_VERSION VERSION_LESS "2.8.12")
|
|
|
|
|
|
|
|
# the file(GENERATE ...) command requires cmake 2.8.12 or later
|
|
|
|
|
|
|
|
set (_configNameOrNoneGeneratorExpression "$<$<CONFIG:>:None>$<$<NOT:$<CONFIG:>>:$<CONFIGURATION>>")
|
|
|
|
|
|
|
|
set (_targetCotireConfigScript "${CMAKE_CURRENT_BINARY_DIR}/${_target}_${_language}_${_configNameOrNoneGeneratorExpression}_${_moduleName}")
|
|
|
|
|
|
|
|
file (GENERATE OUTPUT "${_targetCotireConfigScript}" INPUT "${_targetCotireScript}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
message (WARNING "cotire: generator expression used in target ${_target}. This requires CMake 2.8.12 or later.")
|
|
|
|
|
|
|
|
set (_targetCotireConfigScript "${_targetCotireScript}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
set (_targetCotireConfigScript "${_targetCotireScript}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
set (${_targetScriptVar} "${_targetCotireScript}" PARENT_SCOPE)
|
|
|
|
set (${_targetScriptVar} "${_targetCotireScript}" PARENT_SCOPE)
|
|
|
|
|
|
|
|
set (${_targetConfigScriptVar} "${_targetCotireConfigScript}" PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_setup_pch_file_compilation _language _target _targetSourceDir _targetScript _prefixFile _pchFile)
|
|
|
|
function (cotire_setup_pch_file_compilation _language _target _targetSourceDir _targetScript _prefixFile _pchFile)
|
|
|
@ -1854,7 +2006,8 @@ function (cotire_setup_pch_file_compilation _language _target _targetSourceDir _
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_pchFile} ${_cmds} DEPENDS ${_prefixFile} IMPLICIT_DEPENDS ${_language} ${_prefixFile}")
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_pchFile} ${_cmds} DEPENDS ${_prefixFile} IMPLICIT_DEPENDS ${_language} ${_prefixFile}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set_property (SOURCE "${_pchFile}" PROPERTY GENERATED TRUE)
|
|
|
|
set_property (SOURCE "${_pchFile}" PROPERTY GENERATED TRUE)
|
|
|
|
add_custom_command(OUTPUT "${_pchFile}"
|
|
|
|
add_custom_command(
|
|
|
|
|
|
|
|
OUTPUT "${_pchFile}"
|
|
|
|
COMMAND ${_cmds}
|
|
|
|
COMMAND ${_cmds}
|
|
|
|
DEPENDS "${_prefixFile}"
|
|
|
|
DEPENDS "${_prefixFile}"
|
|
|
|
IMPLICIT_DEPENDS ${_language} "${_prefixFile}"
|
|
|
|
IMPLICIT_DEPENDS ${_language} "${_prefixFile}"
|
|
|
@ -1955,11 +2108,16 @@ function (cotire_setup_combine_command _language _sourceDir _targetScript _joine
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set_property (SOURCE "${_joinedFile}" PROPERTY GENERATED TRUE)
|
|
|
|
set_property (SOURCE "${_joinedFile}" PROPERTY GENERATED TRUE)
|
|
|
|
file (RELATIVE_PATH _joinedFileRelPath "${CMAKE_BINARY_DIR}" "${_joinedFile}")
|
|
|
|
file (RELATIVE_PATH _joinedFileRelPath "${CMAKE_BINARY_DIR}" "${_joinedFile}")
|
|
|
|
get_filename_component(_joinedFileName "${_joinedFileRelPath}" NAME_WE)
|
|
|
|
get_filename_component(_joinedFileBaseName "${_joinedFile}" NAME_WE)
|
|
|
|
if (_language AND _joinedFileName MATCHES "${COTIRE_UNITY_SOURCE_FILENAME_SUFFIX}$")
|
|
|
|
get_filename_component(_joinedFileExt "${_joinedFile}" EXT)
|
|
|
|
|
|
|
|
if (_language AND _joinedFileBaseName MATCHES "${COTIRE_UNITY_SOURCE_FILENAME_SUFFIX}$")
|
|
|
|
set (_comment "Generating ${_language} unity source ${_joinedFileRelPath}")
|
|
|
|
set (_comment "Generating ${_language} unity source ${_joinedFileRelPath}")
|
|
|
|
elseif (_language AND _joinedFileName MATCHES "${COTIRE_UNITY_SOURCE_FILENAME_SUFFIX}$")
|
|
|
|
elseif (_language AND _joinedFileBaseName MATCHES "${COTIRE_PREFIX_HEADER_FILENAME_SUFFIX}$")
|
|
|
|
|
|
|
|
if (_joinedFileExt MATCHES "^\\.c")
|
|
|
|
|
|
|
|
set (_comment "Generating ${_language} prefix source ${_joinedFileRelPath}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
set (_comment "Generating ${_language} prefix header ${_joinedFileRelPath}")
|
|
|
|
set (_comment "Generating ${_language} prefix header ${_joinedFileRelPath}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
set (_comment "Generating ${_joinedFileRelPath}")
|
|
|
|
set (_comment "Generating ${_joinedFileRelPath}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -2023,7 +2181,7 @@ function (cotire_setup_target_pch_usage _languages _targetSourceDir _target _who
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_setup_unity_generation_commands _language _targetSourceDir _target _targetScript _unityFiles _cmdsVar)
|
|
|
|
function (cotire_setup_unity_generation_commands _language _targetSourceDir _target _targetScript _targetConfigScript _unityFiles _cmdsVar)
|
|
|
|
set (_dependencySources "")
|
|
|
|
set (_dependencySources "")
|
|
|
|
cotire_get_unity_source_dependencies(${_language} ${_target} _dependencySources ${ARGN})
|
|
|
|
cotire_get_unity_source_dependencies(${_language} ${_target} _dependencySources ${ARGN})
|
|
|
|
foreach (_unityFile ${_unityFiles})
|
|
|
|
foreach (_unityFile ${_unityFiles})
|
|
|
@ -2042,7 +2200,7 @@ function (cotire_setup_unity_generation_commands _language _targetSourceDir _tar
|
|
|
|
set_property (SOURCE "${_unityFile}" APPEND_STRING PROPERTY COMPILE_FLAGS "/bigobj")
|
|
|
|
set_property (SOURCE "${_unityFile}" APPEND_STRING PROPERTY COMPILE_FLAGS "/bigobj")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
cotire_set_cmd_to_prologue(_unityCmd)
|
|
|
|
cotire_set_cmd_to_prologue(_unityCmd)
|
|
|
|
list (APPEND _unityCmd -P "${COTIRE_CMAKE_MODULE_FILE}" "unity" "${_targetScript}" "${_unityFile}")
|
|
|
|
list (APPEND _unityCmd -P "${COTIRE_CMAKE_MODULE_FILE}" "unity" "${_targetConfigScript}" "${_unityFile}")
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_unityFile} COMMAND ${_unityCmd} DEPENDS ${_targetScript}")
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_unityFile} COMMAND ${_unityCmd} DEPENDS ${_targetScript}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -2058,12 +2216,12 @@ function (cotire_setup_unity_generation_commands _language _targetSourceDir _tar
|
|
|
|
if (_numberOfUnityFiles GREATER 1)
|
|
|
|
if (_numberOfUnityFiles GREATER 1)
|
|
|
|
# create a joint unity file from all unity file segments
|
|
|
|
# create a joint unity file from all unity file segments
|
|
|
|
cotire_make_single_unity_source_file_path(${_language} ${_target} _unityFile)
|
|
|
|
cotire_make_single_unity_source_file_path(${_language} ${_target} _unityFile)
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetScript}" "${_unityFile}" ${_cmdsVar} ${_unityFiles})
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetConfigScript}" "${_unityFile}" ${_cmdsVar} ${_unityFiles})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_setup_single_prefix_generation_command _language _target _targetSourceDir _targetScript _prefixFile _unityFile _cmdsVar)
|
|
|
|
function (cotire_setup_prefix_generation_command _language _target _targetSourceDir _targetScript _prefixFile _unityFile _cmdsVar)
|
|
|
|
set (_sourceFiles ${ARGN})
|
|
|
|
set (_sourceFiles ${ARGN})
|
|
|
|
set (_dependencySources "")
|
|
|
|
set (_dependencySources "")
|
|
|
|
cotire_get_prefix_header_dependencies(${_language} ${_target} _dependencySources ${_sourceFiles})
|
|
|
|
cotire_get_prefix_header_dependencies(${_language} ${_target} _dependencySources ${_sourceFiles})
|
|
|
@ -2071,31 +2229,61 @@ function (cotire_setup_single_prefix_generation_command _language _target _targe
|
|
|
|
list (APPEND _prefixCmd -P "${COTIRE_CMAKE_MODULE_FILE}" "prefix" "${_targetScript}" "${_prefixFile}" "${_unityFile}")
|
|
|
|
list (APPEND _prefixCmd -P "${COTIRE_CMAKE_MODULE_FILE}" "prefix" "${_targetScript}" "${_prefixFile}" "${_unityFile}")
|
|
|
|
set_property (SOURCE "${_prefixFile}" PROPERTY GENERATED TRUE)
|
|
|
|
set_property (SOURCE "${_prefixFile}" PROPERTY GENERATED TRUE)
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_prefixFile} COMMAND ${_prefixCmd} DEPENDS ${_targetScript} ${_unityFile} ${_dependencySources}")
|
|
|
|
message (STATUS "add_custom_command: OUTPUT ${_prefixFile} COMMAND ${_prefixCmd} DEPENDS ${_unityFile} ${_dependencySources}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
file (RELATIVE_PATH _prefixFileRelPath "${CMAKE_BINARY_DIR}" "${_prefixFile}")
|
|
|
|
file (RELATIVE_PATH _prefixFileRelPath "${CMAKE_BINARY_DIR}" "${_prefixFile}")
|
|
|
|
|
|
|
|
get_filename_component(_prefixFileExt "${_prefixFile}" EXT)
|
|
|
|
|
|
|
|
if (_prefixFileExt MATCHES "^\\.c")
|
|
|
|
|
|
|
|
set (_comment "Generating ${_language} prefix source ${_prefixFileRelPath}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
set (_comment "Generating ${_language} prefix header ${_prefixFileRelPath}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
add_custom_command(
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT "${_prefixFile}" "${_prefixFile}.log"
|
|
|
|
OUTPUT "${_prefixFile}" "${_prefixFile}.log"
|
|
|
|
COMMAND ${_prefixCmd}
|
|
|
|
COMMAND ${_prefixCmd}
|
|
|
|
DEPENDS "${_targetScript}" "${_unityFile}" ${_dependencySources}
|
|
|
|
DEPENDS "${_unityFile}" ${_dependencySources}
|
|
|
|
COMMENT "Generating ${_language} prefix header ${_prefixFileRelPath}"
|
|
|
|
COMMENT "${_comment}"
|
|
|
|
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}" VERBATIM)
|
|
|
|
WORKING_DIRECTORY "${CMAKE_BINARY_DIR}" VERBATIM)
|
|
|
|
list (APPEND ${_cmdsVar} COMMAND ${_prefixCmd})
|
|
|
|
list (APPEND ${_cmdsVar} COMMAND ${_prefixCmd})
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_setup_multi_prefix_generation_command _language _target _targetSourceDir _targetScript _prefixFile _unityFiles _cmdsVar)
|
|
|
|
function (cotire_setup_prefix_generation_from_unity_command _language _target _targetSourceDir _targetScript _prefixFile _unityFiles _cmdsVar)
|
|
|
|
set (_sourceFiles ${ARGN})
|
|
|
|
set (_sourceFiles ${ARGN})
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
|
|
|
|
# GNU and Clang require indirect compilation of the prefix header to make them honor the system_header pragma
|
|
|
|
|
|
|
|
cotire_prefix_header_to_source_file_path(${_language} "${_prefixFile}" _prefixSourceFile)
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
set (_prefixSourceFile "${_prefixFile}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
list (LENGTH _unityFiles _numberOfUnityFiles)
|
|
|
|
list (LENGTH _unityFiles _numberOfUnityFiles)
|
|
|
|
if (_numberOfUnityFiles GREATER 1)
|
|
|
|
if (_numberOfUnityFiles GREATER 1)
|
|
|
|
cotire_make_single_unity_source_file_path(${_language} ${_target} _unityFile)
|
|
|
|
cotire_make_single_unity_source_file_path(${_language} ${_target} _unityFile)
|
|
|
|
cotire_setup_single_prefix_generation_command(
|
|
|
|
cotire_setup_prefix_generation_command(
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}"
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}"
|
|
|
|
"${_prefixFile}" "${_unityFile}" ${_cmdsVar} ${_sourceFiles})
|
|
|
|
"${_prefixSourceFile}" "${_unityFile}" ${_cmdsVar} ${_sourceFiles})
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
cotire_setup_single_prefix_generation_command(
|
|
|
|
cotire_setup_prefix_generation_command(
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}"
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}"
|
|
|
|
"${_prefixFile}" "${_unityFiles}" ${_cmdsVar} ${_sourceFiles})
|
|
|
|
"${_prefixSourceFile}" "${_unityFiles}" ${_cmdsVar} ${_sourceFiles})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetScript}" "${_prefixFile}" ${_cmdsVar} ${_prefixSourceFile})
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_setup_prefix_generation_from_provided_command _language _target _targetSourceDir _targetScript _prefixFile _cmdsVar)
|
|
|
|
|
|
|
|
set (_prefixHeaderFiles ${ARGN})
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
|
|
|
|
# GNU and Clang require indirect compilation of the prefix header to make them honor the system_header pragma
|
|
|
|
|
|
|
|
cotire_prefix_header_to_source_file_path(${_language} "${_prefixFile}" _prefixSourceFile)
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
set (_prefixSourceFile "${_prefixFile}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetScript}" "${_prefixSourceFile}" _cmds ${_prefixHeaderFiles})
|
|
|
|
|
|
|
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "GNU|Clang")
|
|
|
|
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetScript}" "${_prefixFile}" _cmds ${_prefixSourceFile})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
set (${_cmdsVar} ${${_cmdsVar}} PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
endfunction()
|
|
|
@ -2210,11 +2398,11 @@ function (cotire_choose_target_languages _targetSourceDir _target _targetLanguag
|
|
|
|
get_target_property(_prefixHeader ${_target} COTIRE_${_language}_PREFIX_HEADER)
|
|
|
|
get_target_property(_prefixHeader ${_target} COTIRE_${_language}_PREFIX_HEADER)
|
|
|
|
get_target_property(_unityBuildFile ${_target} COTIRE_${_language}_UNITY_SOURCE)
|
|
|
|
get_target_property(_unityBuildFile ${_target} COTIRE_${_language}_UNITY_SOURCE)
|
|
|
|
if (_prefixHeader OR _unityBuildFile)
|
|
|
|
if (_prefixHeader OR _unityBuildFile)
|
|
|
|
message (STATUS "Target ${_target} has already been cotired.")
|
|
|
|
message (STATUS "cotire: target ${_target} has already been cotired.")
|
|
|
|
set (${_targetLanguagesVar} "" PARENT_SCOPE)
|
|
|
|
set (${_targetLanguagesVar} "" PARENT_SCOPE)
|
|
|
|
return()
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if (_targetUsePCH AND "${_language}" STREQUAL "C" OR "${_language}" STREQUAL "CXX")
|
|
|
|
if (_targetUsePCH AND "${_language}" MATCHES "^C|CXX$")
|
|
|
|
cotire_check_precompiled_header_support("${_language}" "${_targetSourceDir}" "${_target}" _disableMsg)
|
|
|
|
cotire_check_precompiled_header_support("${_language}" "${_targetSourceDir}" "${_target}" _disableMsg)
|
|
|
|
if (_disableMsg)
|
|
|
|
if (_disableMsg)
|
|
|
|
set (_targetUsePCH FALSE)
|
|
|
|
set (_targetUsePCH FALSE)
|
|
|
@ -2327,30 +2515,31 @@ function (cotire_process_target_language _language _configurations _targetSource
|
|
|
|
set (_unitySourceFiles ${_sourceFiles} ${_cotiredSources})
|
|
|
|
set (_unitySourceFiles ${_sourceFiles} ${_cotiredSources})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
cotire_generate_target_script(
|
|
|
|
cotire_generate_target_script(
|
|
|
|
${_language} "${_configurations}" "${_targetSourceDir}" "${_targetBinaryDir}" ${_target} _targetScript ${_unitySourceFiles})
|
|
|
|
${_language} "${_configurations}" "${_targetSourceDir}" "${_targetBinaryDir}" ${_target} _targetScript _targetConfigScript ${_unitySourceFiles})
|
|
|
|
cotire_compute_unity_max_number_of_includes(${_target} _maxIncludes ${_unitySourceFiles})
|
|
|
|
cotire_compute_unity_max_number_of_includes(${_target} _maxIncludes ${_unitySourceFiles})
|
|
|
|
cotire_make_unity_source_file_paths(${_language} ${_target} ${_maxIncludes} _unityFiles ${_unitySourceFiles})
|
|
|
|
cotire_make_unity_source_file_paths(${_language} ${_target} ${_maxIncludes} _unityFiles ${_unitySourceFiles})
|
|
|
|
if (NOT _unityFiles)
|
|
|
|
if (NOT _unityFiles)
|
|
|
|
return()
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
cotire_setup_unity_generation_commands(
|
|
|
|
cotire_setup_unity_generation_commands(
|
|
|
|
${_language} "${_targetSourceDir}" ${_target} "${_targetScript}" "${_unityFiles}" _cmds ${_unitySourceFiles})
|
|
|
|
${_language} "${_targetSourceDir}" ${_target} "${_targetScript}" "${_targetConfigScript}" "${_unityFiles}" _cmds ${_unitySourceFiles})
|
|
|
|
cotire_make_prefix_file_path(${_language} ${_target} _prefixFile)
|
|
|
|
cotire_make_prefix_file_path(${_language} ${_target} _prefixFile)
|
|
|
|
if (_prefixFile)
|
|
|
|
if (_prefixFile)
|
|
|
|
# check for user provided prefix header files
|
|
|
|
# check for user provided prefix header files
|
|
|
|
get_property(_prefixHeaderFiles TARGET ${_target} PROPERTY COTIRE_${_language}_PREFIX_HEADER_INIT)
|
|
|
|
get_property(_prefixHeaderFiles TARGET ${_target} PROPERTY COTIRE_${_language}_PREFIX_HEADER_INIT)
|
|
|
|
if (_prefixHeaderFiles)
|
|
|
|
if (_prefixHeaderFiles)
|
|
|
|
cotire_setup_combine_command(${_language} "${_targetSourceDir}" "${_targetScript}" "${_prefixFile}" _cmds ${_prefixHeaderFiles})
|
|
|
|
cotire_setup_prefix_generation_from_provided_command(
|
|
|
|
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetConfigScript}" "${_prefixFile}" _cmds ${_prefixHeaderFiles})
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
cotire_setup_multi_prefix_generation_command(
|
|
|
|
cotire_setup_prefix_generation_from_unity_command(
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}" "${_prefixFile}" "${_unityFiles}" _cmds ${_unitySourceFiles})
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetConfigScript}" "${_prefixFile}" "${_unityFiles}" _cmds ${_unitySourceFiles})
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
get_target_property(_targetUsePCH ${_target} COTIRE_ENABLE_PRECOMPILED_HEADER)
|
|
|
|
get_target_property(_targetUsePCH ${_target} COTIRE_ENABLE_PRECOMPILED_HEADER)
|
|
|
|
if (_targetUsePCH)
|
|
|
|
if (_targetUsePCH)
|
|
|
|
cotire_make_pch_file_path(${_language} "${_targetSourceDir}" ${_target} _pchFile)
|
|
|
|
cotire_make_pch_file_path(${_language} "${_targetSourceDir}" ${_target} _pchFile)
|
|
|
|
if (_pchFile)
|
|
|
|
if (_pchFile)
|
|
|
|
cotire_setup_pch_file_compilation(
|
|
|
|
cotire_setup_pch_file_compilation(
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetScript}" "${_prefixFile}" "${_pchFile}" ${_sourceFiles})
|
|
|
|
${_language} ${_target} "${_targetSourceDir}" "${_targetConfigScript}" "${_prefixFile}" "${_pchFile}" ${_sourceFiles})
|
|
|
|
if (_excludedSources)
|
|
|
|
if (_excludedSources)
|
|
|
|
set (_wholeTarget FALSE)
|
|
|
|
set (_wholeTarget FALSE)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -2426,7 +2615,7 @@ function (cotire_setup_unity_build_target _languages _configurations _targetSour
|
|
|
|
elseif (_targetType MATCHES "(STATIC|SHARED|MODULE|OBJECT)_LIBRARY")
|
|
|
|
elseif (_targetType MATCHES "(STATIC|SHARED|MODULE|OBJECT)_LIBRARY")
|
|
|
|
set (_unityTargetSubType "${CMAKE_MATCH_1}")
|
|
|
|
set (_unityTargetSubType "${CMAKE_MATCH_1}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (WARNING "Unknown target type ${_targetType}.")
|
|
|
|
message (WARNING "cotire: target ${_target} has unknown target type ${_targetType}.")
|
|
|
|
return()
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
# determine unity target sources
|
|
|
|
# determine unity target sources
|
|
|
@ -2523,9 +2712,10 @@ function (cotire_setup_unity_build_target _languages _configurations _targetSour
|
|
|
|
C_VISIBILITY_PRESET CXX_VISIBILITY_PRESET VISIBILITY_INLINES_HIDDEN)
|
|
|
|
C_VISIBILITY_PRESET CXX_VISIBILITY_PRESET VISIBILITY_INLINES_HIDDEN)
|
|
|
|
# copy interface stuff
|
|
|
|
# copy interface stuff
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
COMPATIBLE_INTERFACE_BOOL COMPATIBLE_INTERFACE_STRING
|
|
|
|
COMPATIBLE_INTERFACE_BOOL COMPATIBLE_INTERFACE_NUMBER_MAX COMPATIBLE_INTERFACE_NUMBER_MIN COMPATIBLE_INTERFACE_STRING
|
|
|
|
INTERFACE_COMPILE_DEFINITIONS INTERFACE_COMPILE_OPTIONS INTERFACE_INCLUDE_DIRECTORIES
|
|
|
|
INTERFACE_COMPILE_DEFINITIONS INTERFACE_COMPILE_OPTIONS INTERFACE_INCLUDE_DIRECTORIES
|
|
|
|
INTERFACE_LINK_LIBRARIES INTERFACE_POSITION_INDEPENDENT_CODE INTERFACE_SYSTEM_INCLUDE_DIRECTORIES)
|
|
|
|
INTERFACE_POSITION_INDEPENDENT_CODE INTERFACE_SYSTEM_INCLUDE_DIRECTORIES
|
|
|
|
|
|
|
|
INTERFACE_AUTOUIC_OPTIONS)
|
|
|
|
# copy link stuff
|
|
|
|
# copy link stuff
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
BUILD_WITH_INSTALL_RPATH INSTALL_RPATH INSTALL_RPATH_USE_LINK_PATH SKIP_BUILD_RPATH
|
|
|
|
BUILD_WITH_INSTALL_RPATH INSTALL_RPATH INSTALL_RPATH_USE_LINK_PATH SKIP_BUILD_RPATH
|
|
|
@ -2538,7 +2728,8 @@ function (cotire_setup_unity_build_target _languages _configurations _targetSour
|
|
|
|
NO_SONAME SOVERSION VERSION)
|
|
|
|
NO_SONAME SOVERSION VERSION)
|
|
|
|
# copy Qt stuff
|
|
|
|
# copy Qt stuff
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
AUTOMOC AUTOMOC_MOC_OPTIONS)
|
|
|
|
AUTOMOC AUTOMOC_MOC_OPTIONS AUTOUIC AUTOUIC_OPTIONS AUTORCC AUTORCC_OPTIONS
|
|
|
|
|
|
|
|
AUTOGEN_TARGET_DEPENDS)
|
|
|
|
# copy cmake stuff
|
|
|
|
# copy cmake stuff
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
cotire_copy_set_properites("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
|
|
|
IMPLICIT_DEPENDS_INCLUDE_TRANSFORM RULE_LAUNCH_COMPILE RULE_LAUNCH_CUSTOM RULE_LAUNCH_LINK)
|
|
|
|
IMPLICIT_DEPENDS_INCLUDE_TRANSFORM RULE_LAUNCH_COMPILE RULE_LAUNCH_CUSTOM RULE_LAUNCH_LINK)
|
|
|
@ -2597,7 +2788,7 @@ function (cotire_target _target)
|
|
|
|
# trivial checks
|
|
|
|
# trivial checks
|
|
|
|
get_target_property(_imported ${_target} IMPORTED)
|
|
|
|
get_target_property(_imported ${_target} IMPORTED)
|
|
|
|
if (_imported)
|
|
|
|
if (_imported)
|
|
|
|
message (WARNING "Imported target ${_target} cannot be cotired.")
|
|
|
|
message (WARNING "cotire: imported target ${_target} cannot be cotired.")
|
|
|
|
return()
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
# resolve alias
|
|
|
|
# resolve alias
|
|
|
@ -2658,6 +2849,24 @@ function (cotire_target _target)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endfunction(cotire_target)
|
|
|
|
endfunction(cotire_target)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_map_libraries _strategy _mappedLibrariesVar)
|
|
|
|
|
|
|
|
set (_mappedLibraries "")
|
|
|
|
|
|
|
|
foreach (_library ${ARGN})
|
|
|
|
|
|
|
|
if (TARGET "${_library}" AND "${_strategy}" MATCHES "COPY_UNITY")
|
|
|
|
|
|
|
|
get_target_property(_libraryUnityTargetName ${_library} COTIRE_UNITY_TARGET_NAME)
|
|
|
|
|
|
|
|
if (TARGET "${_libraryUnityTargetName}")
|
|
|
|
|
|
|
|
list (APPEND _mappedLibraries "${_libraryUnityTargetName}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
list (APPEND _mappedLibraries "${_library}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
list (APPEND _mappedLibraries "${_library}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
list (REMOVE_DUPLICATES _mappedLibraries)
|
|
|
|
|
|
|
|
set (${_mappedLibrariesVar} ${_mappedLibraries} PARENT_SCOPE)
|
|
|
|
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
|
|
|
|
function (cotire_target_link_libraries _target)
|
|
|
|
function (cotire_target_link_libraries _target)
|
|
|
|
get_target_property(_unityTargetName ${_target} COTIRE_UNITY_TARGET_NAME)
|
|
|
|
get_target_property(_unityTargetName ${_target} COTIRE_UNITY_TARGET_NAME)
|
|
|
|
if (TARGET "${_unityTargetName}")
|
|
|
|
if (TARGET "${_unityTargetName}")
|
|
|
@ -2667,30 +2876,16 @@ function(cotire_target_link_libraries _target)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
if ("${_linkLibrariesStrategy}" MATCHES "^(COPY|COPY_UNITY)$")
|
|
|
|
if ("${_linkLibrariesStrategy}" MATCHES "^(COPY|COPY_UNITY)$")
|
|
|
|
if (CMAKE_VERSION VERSION_LESS "2.8.11")
|
|
|
|
if (CMAKE_VERSION VERSION_LESS "2.8.11")
|
|
|
|
message (WARNING "Unity target link strategy ${_linkLibrariesStrategy} requires CMake 2.8.11 or later. Defaulting to NONE for ${_target}.")
|
|
|
|
message (WARNING "cotire: unity target link strategy ${_linkLibrariesStrategy} requires CMake 2.8.11 or later. Defaulting to NONE for ${_target}.")
|
|
|
|
return()
|
|
|
|
else()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(_linkLibraries ${_target} LINK_LIBRARIES)
|
|
|
|
get_target_property(_linkLibraries ${_target} LINK_LIBRARIES)
|
|
|
|
if (_linkLibraries)
|
|
|
|
get_target_property(_interfaceLinkLibraries ${_target} INTERFACE_LINK_LIBRARIES)
|
|
|
|
|
|
|
|
cotire_map_libraries("${_linkLibrariesStrategy}" _unityLinkLibraries ${_linkLibraries} ${_interfaceLinkLibraries})
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
message (STATUS "target ${_target} link libraries: ${_linkLibraries}")
|
|
|
|
message (STATUS "unity target ${_unityTargetName} libraries: ${_unityLinkLibraries}")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
set (_unityTargetLibraries "")
|
|
|
|
if (_unityLinkLibraries)
|
|
|
|
foreach (_library ${_linkLibraries})
|
|
|
|
target_link_libraries(${_unityTargetName} ${_unityLinkLibraries})
|
|
|
|
if (TARGET "${_library}" AND "${_linkLibrariesStrategy}" MATCHES "COPY_UNITY")
|
|
|
|
|
|
|
|
get_target_property(_libraryUnityTargetName ${_library} COTIRE_UNITY_TARGET_NAME)
|
|
|
|
|
|
|
|
if (TARGET "${_libraryUnityTargetName}")
|
|
|
|
|
|
|
|
list (APPEND _unityTargetLibraries "${_libraryUnityTargetName}")
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
list (APPEND _unityTargetLibraries "${_library}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
else()
|
|
|
|
|
|
|
|
list (APPEND _unityTargetLibraries "${_library}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
set_property(TARGET ${_unityTargetName} APPEND PROPERTY LINK_LIBRARIES ${_unityTargetLibraries})
|
|
|
|
|
|
|
|
if (COTIRE_DEBUG)
|
|
|
|
|
|
|
|
message (STATUS "set unity target ${_unityTargetName} link libraries: ${_unityTargetLibraries}")
|
|
|
|
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
@ -2777,7 +2972,7 @@ function (cotire)
|
|
|
|
cotire_target(${_target} LANGUAGES ${_option_LANGUAGES} CONFIGURATIONS ${_option_CONFIGURATIONS}
|
|
|
|
cotire_target(${_target} LANGUAGES ${_option_LANGUAGES} CONFIGURATIONS ${_option_CONFIGURATIONS}
|
|
|
|
SOURCE_DIR "${_option_SOURCE_DIR}" BINARY_DIR "${_option_BINARY_DIR}")
|
|
|
|
SOURCE_DIR "${_option_SOURCE_DIR}" BINARY_DIR "${_option_BINARY_DIR}")
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (WARNING "${_target} is not a target.")
|
|
|
|
message (WARNING "cotire: ${_target} is not a target.")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endforeach()
|
|
|
|
foreach (_target ${_targets})
|
|
|
|
foreach (_target ${_targets})
|
|
|
@ -2824,6 +3019,7 @@ if (CMAKE_SCRIPT_MODE_FILE)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
string (TOUPPER "${COTIRE_BUILD_TYPE}" _upperConfig)
|
|
|
|
string (TOUPPER "${COTIRE_BUILD_TYPE}" _upperConfig)
|
|
|
|
set (_includeDirs ${COTIRE_TARGET_INCLUDE_DIRECTORIES_${_upperConfig}})
|
|
|
|
set (_includeDirs ${COTIRE_TARGET_INCLUDE_DIRECTORIES_${_upperConfig}})
|
|
|
|
|
|
|
|
set (_systemIncludeDirs ${COTIRE_TARGET_SYSTEM_INCLUDE_DIRECTORIES_${_upperConfig}})
|
|
|
|
set (_compileDefinitions ${COTIRE_TARGET_COMPILE_DEFINITIONS_${_upperConfig}})
|
|
|
|
set (_compileDefinitions ${COTIRE_TARGET_COMPILE_DEFINITIONS_${_upperConfig}})
|
|
|
|
set (_compileFlags ${COTIRE_TARGET_COMPILE_FLAGS_${_upperConfig}})
|
|
|
|
set (_compileFlags ${COTIRE_TARGET_COMPILE_FLAGS_${_upperConfig}})
|
|
|
|
# check if target has been cotired for actual build type COTIRE_BUILD_TYPE
|
|
|
|
# check if target has been cotired for actual build type COTIRE_BUILD_TYPE
|
|
|
@ -2876,7 +3072,9 @@ if (CMAKE_SCRIPT_MODE_FILE)
|
|
|
|
IGNORE_PATH "${COTIRE_TARGET_IGNORE_PATH};${COTIRE_ADDITIONAL_PREFIX_HEADER_IGNORE_PATH}"
|
|
|
|
IGNORE_PATH "${COTIRE_TARGET_IGNORE_PATH};${COTIRE_ADDITIONAL_PREFIX_HEADER_IGNORE_PATH}"
|
|
|
|
INCLUDE_PATH ${COTIRE_TARGET_INCLUDE_PATH}
|
|
|
|
INCLUDE_PATH ${COTIRE_TARGET_INCLUDE_PATH}
|
|
|
|
IGNORE_EXTENSIONS "${CMAKE_${COTIRE_TARGET_LANGUAGE}_SOURCE_FILE_EXTENSIONS};${COTIRE_ADDITIONAL_PREFIX_HEADER_IGNORE_EXTENSIONS}"
|
|
|
|
IGNORE_EXTENSIONS "${CMAKE_${COTIRE_TARGET_LANGUAGE}_SOURCE_FILE_EXTENSIONS};${COTIRE_ADDITIONAL_PREFIX_HEADER_IGNORE_EXTENSIONS}"
|
|
|
|
|
|
|
|
INCLUDE_SYSTEM_FLAG "${COTIRE_INCLUDE_SYSTEM_FLAG}"
|
|
|
|
INCLUDE_DIRECTORIES ${_includeDirs}
|
|
|
|
INCLUDE_DIRECTORIES ${_includeDirs}
|
|
|
|
|
|
|
|
SYSTEM_INCLUDE_DIRECTORIES ${_systemIncludeDirs}
|
|
|
|
COMPILE_DEFINITIONS ${_compileDefinitions}
|
|
|
|
COMPILE_DEFINITIONS ${_compileDefinitions}
|
|
|
|
COMPILE_FLAGS ${_compileFlags})
|
|
|
|
COMPILE_FLAGS ${_compileFlags})
|
|
|
|
|
|
|
|
|
|
|
@ -2896,7 +3094,9 @@ if (CMAKE_SCRIPT_MODE_FILE)
|
|
|
|
COMPILER_ID "${CMAKE_${COTIRE_TARGET_LANGUAGE}_COMPILER_ID}"
|
|
|
|
COMPILER_ID "${CMAKE_${COTIRE_TARGET_LANGUAGE}_COMPILER_ID}"
|
|
|
|
COMPILER_VERSION "${COTIRE_${COTIRE_TARGET_LANGUAGE}_COMPILER_VERSION}"
|
|
|
|
COMPILER_VERSION "${COTIRE_${COTIRE_TARGET_LANGUAGE}_COMPILER_VERSION}"
|
|
|
|
LANGUAGE "${COTIRE_TARGET_LANGUAGE}"
|
|
|
|
LANGUAGE "${COTIRE_TARGET_LANGUAGE}"
|
|
|
|
|
|
|
|
INCLUDE_SYSTEM_FLAG "${COTIRE_INCLUDE_SYSTEM_FLAG}"
|
|
|
|
INCLUDE_DIRECTORIES ${_includeDirs}
|
|
|
|
INCLUDE_DIRECTORIES ${_includeDirs}
|
|
|
|
|
|
|
|
SYSTEM_INCLUDE_DIRECTORIES ${_systemIncludeDirs}
|
|
|
|
COMPILE_DEFINITIONS ${_compileDefinitions}
|
|
|
|
COMPILE_DEFINITIONS ${_compileDefinitions}
|
|
|
|
COMPILE_FLAGS ${_compileFlags})
|
|
|
|
COMPILE_FLAGS ${_compileFlags})
|
|
|
|
|
|
|
|
|
|
|
@ -2924,7 +3124,7 @@ if (CMAKE_SCRIPT_MODE_FILE)
|
|
|
|
cotire_cleanup("${COTIRE_ARGV2}" "${COTIRE_ARGV3}" "${COTIRE_ARGV4}")
|
|
|
|
cotire_cleanup("${COTIRE_ARGV2}" "${COTIRE_ARGV3}" "${COTIRE_ARGV4}")
|
|
|
|
|
|
|
|
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|
message (FATAL_ERROR "Unknown cotire command \"${COTIRE_ARGV1}\".")
|
|
|
|
message (FATAL_ERROR "cotire: unknown command \"${COTIRE_ARGV1}\".")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
else()
|
|
|
|
else()
|
|
|
|