CMake: Update cotire to version 1.8.0
This commit is contained in:
parent
a5b1a418bb
commit
a156cb5b6b
@ -3,7 +3,7 @@
|
|||||||
# See the cotire manual for usage hints.
|
# See the cotire manual for usage hints.
|
||||||
#
|
#
|
||||||
#=============================================================================
|
#=============================================================================
|
||||||
# Copyright 2012-2017 Sascha Kratky
|
# Copyright 2012-2018 Sascha Kratky
|
||||||
#
|
#
|
||||||
# Permission is hereby granted, free of charge, to any person
|
# Permission is hereby granted, free of charge, to any person
|
||||||
# obtaining a copy of this software and associated documentation
|
# obtaining a copy of this software and associated documentation
|
||||||
@ -43,7 +43,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.7.10")
|
set (COTIRE_CMAKE_MODULE_VERSION "1.8.0")
|
||||||
|
|
||||||
# activate select policies
|
# activate select policies
|
||||||
if (POLICY CMP0025)
|
if (POLICY CMP0025)
|
||||||
@ -239,7 +239,13 @@ function (cotire_filter_language_source_files _language _target _sourceFilesVar
|
|||||||
# add to excluded sources, if file has custom compile flags
|
# add to excluded sources, if file has custom compile flags
|
||||||
list (APPEND _excludedSourceFiles "${_sourceFile}")
|
list (APPEND _excludedSourceFiles "${_sourceFile}")
|
||||||
else()
|
else()
|
||||||
list (APPEND _sourceFiles "${_sourceFile}")
|
get_source_file_property(_sourceCompileOptions "${_sourceFile}" COMPILE_OPTIONS)
|
||||||
|
if (_sourceCompileOptions)
|
||||||
|
# add to excluded sources, if file has list of custom compile options
|
||||||
|
list (APPEND _excludedSourceFiles "${_sourceFile}")
|
||||||
|
else()
|
||||||
|
list (APPEND _sourceFiles "${_sourceFile}")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
@ -721,7 +727,7 @@ function (cotire_get_target_compile_definitions _config _language _target _defin
|
|||||||
endif()
|
endif()
|
||||||
endforeach()
|
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 do not look at directory compile definitions, which we already handled
|
||||||
set (_targetFlags "")
|
set (_targetFlags "")
|
||||||
cotire_get_target_compile_flags("${_config}" "${_language}" "${_target}" _targetFlags)
|
cotire_get_target_compile_flags("${_config}" "${_language}" "${_target}" _targetFlags)
|
||||||
cotire_filter_compile_flags("${_language}" "D" _definitions _ignore ${_targetFlags})
|
cotire_filter_compile_flags("${_language}" "D" _definitions _ignore ${_targetFlags})
|
||||||
@ -889,6 +895,9 @@ function (cotire_init_compile_cmd _cmdVar _language _compilerLauncher _compilerE
|
|||||||
if (NOT _compilerArg1)
|
if (NOT _compilerArg1)
|
||||||
set (_compilerArg1 ${CMAKE_${_language}_COMPILER_ARG1})
|
set (_compilerArg1 ${CMAKE_${_language}_COMPILER_ARG1})
|
||||||
endif()
|
endif()
|
||||||
|
if (WIN32)
|
||||||
|
file (TO_NATIVE_PATH "${_compilerExe}" _compilerExe)
|
||||||
|
endif()
|
||||||
string (STRIP "${_compilerArg1}" _compilerArg1)
|
string (STRIP "${_compilerArg1}" _compilerArg1)
|
||||||
if ("${CMAKE_GENERATOR}" MATCHES "Make|Ninja")
|
if ("${CMAKE_GENERATOR}" MATCHES "Make|Ninja")
|
||||||
# compiler launcher is only supported for Makefile and Ninja
|
# compiler launcher is only supported for Makefile and Ninja
|
||||||
@ -1083,12 +1092,11 @@ endmacro()
|
|||||||
|
|
||||||
macro (cotire_parse_line _line _headerFileVar _headerDepthVar)
|
macro (cotire_parse_line _line _headerFileVar _headerDepthVar)
|
||||||
if (MSVC)
|
if (MSVC)
|
||||||
# cl.exe /showIncludes output looks different depending on the language pack used, e.g.:
|
# cl.exe /showIncludes produces different output, depending on the language pack used, e.g.:
|
||||||
# English: "Note: including file: C:\directory\file"
|
# English: "Note: including file: C:\directory\file"
|
||||||
# German: "Hinweis: Einlesen der Datei: C:\directory\file"
|
# German: "Hinweis: Einlesen der Datei: C:\directory\file"
|
||||||
# We use a very general regular expression, relying on the presence of the : characters
|
# We use a very general regular expression, relying on the presence of the : characters
|
||||||
if (_line MATCHES "( +)([a-zA-Z]:[^:]+)$")
|
if (_line MATCHES "( +)([a-zA-Z]:[^:]+)$")
|
||||||
# Visual Studio compiler output
|
|
||||||
string (LENGTH "${CMAKE_MATCH_1}" ${_headerDepthVar})
|
string (LENGTH "${CMAKE_MATCH_1}" ${_headerDepthVar})
|
||||||
get_filename_component(${_headerFileVar} "${CMAKE_MATCH_2}" ABSOLUTE)
|
get_filename_component(${_headerFileVar} "${CMAKE_MATCH_2}" ABSOLUTE)
|
||||||
else()
|
else()
|
||||||
@ -1246,11 +1254,19 @@ function (cotire_scan_includes _includesVar)
|
|||||||
set (${_includesVar} "" PARENT_SCOPE)
|
set (${_includesVar} "" PARENT_SCOPE)
|
||||||
return()
|
return()
|
||||||
endif()
|
endif()
|
||||||
list (APPEND _cmd ${_existingSourceFiles})
|
# add source files to be scanned
|
||||||
|
if (WIN32)
|
||||||
|
foreach (_sourceFile ${_existingSourceFiles})
|
||||||
|
file (TO_NATIVE_PATH "${_sourceFile}" _sourceFileNative)
|
||||||
|
list (APPEND _cmd "${_sourceFileNative}")
|
||||||
|
endforeach()
|
||||||
|
else()
|
||||||
|
list (APPEND _cmd ${_existingSourceFiles})
|
||||||
|
endif()
|
||||||
if (COTIRE_VERBOSE)
|
if (COTIRE_VERBOSE)
|
||||||
message (STATUS "execute_process: ${_cmd}")
|
message (STATUS "execute_process: ${_cmd}")
|
||||||
endif()
|
endif()
|
||||||
if (_option_COMPILER_ID MATCHES "MSVC")
|
if (MSVC_IDE OR _option_COMPILER_ID MATCHES "MSVC")
|
||||||
# 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()
|
||||||
@ -1486,11 +1502,16 @@ function (cotire_generate_prefix_header _prefixFile)
|
|||||||
if (_unparsedLines)
|
if (_unparsedLines)
|
||||||
if (COTIRE_VERBOSE OR _scanResult OR NOT _selectedHeaders)
|
if (COTIRE_VERBOSE OR _scanResult OR NOT _selectedHeaders)
|
||||||
list (LENGTH _unparsedLines _skippedLineCount)
|
list (LENGTH _unparsedLines _skippedLineCount)
|
||||||
message (STATUS "${_skippedLineCount} line(s) skipped, see ${_unparsedLinesFile}")
|
if (WIN32)
|
||||||
|
file (TO_NATIVE_PATH "${_unparsedLinesFile}" _unparsedLinesLogPath)
|
||||||
|
else()
|
||||||
|
set (_unparsedLinesLogPath "${_unparsedLinesFile}")
|
||||||
|
endif()
|
||||||
|
message (STATUS "${_skippedLineCount} line(s) skipped, see ${_unparsedLinesLogPath}")
|
||||||
endif()
|
endif()
|
||||||
string (REPLACE ";" "\n" _unparsedLines "${_unparsedLines}")
|
string (REPLACE ";" "\n" _unparsedLines "${_unparsedLines}")
|
||||||
endif()
|
endif()
|
||||||
file (WRITE "${_unparsedLinesFile}" "${_unparsedLines}")
|
file (WRITE "${_unparsedLinesFile}" "${_unparsedLines}\n")
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function (cotire_add_makedep_flags _language _compilerID _compilerVersion _flagsVar)
|
function (cotire_add_makedep_flags _language _compilerID _compilerVersion _flagsVar)
|
||||||
@ -1520,7 +1541,7 @@ function (cotire_add_makedep_flags _language _compilerID _compilerVersion _flags
|
|||||||
# append to list
|
# append to list
|
||||||
list (APPEND _flags -H -E)
|
list (APPEND _flags -H -E)
|
||||||
if (NOT "${_compilerVersion}" VERSION_LESS "4.3.0")
|
if (NOT "${_compilerVersion}" VERSION_LESS "4.3.0")
|
||||||
list (APPEND _flags "-fdirectives-only")
|
list (APPEND _flags -fdirectives-only)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
# return as a flag string
|
# return as a flag string
|
||||||
@ -1530,16 +1551,36 @@ function (cotire_add_makedep_flags _language _compilerID _compilerVersion _flags
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
elseif (_compilerID MATCHES "Clang")
|
elseif (_compilerID MATCHES "Clang")
|
||||||
# Clang options used
|
if (UNIX)
|
||||||
# -H print the name of each header file used
|
# Clang options used
|
||||||
# -E invoke preprocessor
|
# -H print the name of each header file used
|
||||||
# -fno-color-diagnostics don't prints diagnostics in color
|
# -E invoke preprocessor
|
||||||
if (_flags)
|
# -fno-color-diagnostics do not print diagnostics in color
|
||||||
# append to list
|
# -Eonly just run preprocessor, no output
|
||||||
list (APPEND _flags -H -E -fno-color-diagnostics)
|
if (_flags)
|
||||||
else()
|
# append to list
|
||||||
# return as a flag string
|
list (APPEND _flags -H -E -fno-color-diagnostics -Xclang -Eonly)
|
||||||
set (_flags "-H -E -fno-color-diagnostics")
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "-H -E -fno-color-diagnostics -Xclang -Eonly")
|
||||||
|
endif()
|
||||||
|
elseif (WIN32)
|
||||||
|
# Clang-cl.exe options used
|
||||||
|
# /TC treat all files named on the command line as C source files
|
||||||
|
# /TP treat all files named on the command line as C++ source files
|
||||||
|
# /EP preprocess to stdout without #line directives
|
||||||
|
# -H print the name of each header file used
|
||||||
|
# -fno-color-diagnostics do not print diagnostics in color
|
||||||
|
# -Eonly just run preprocessor, no output
|
||||||
|
set (_sourceFileTypeC "/TC")
|
||||||
|
set (_sourceFileTypeCXX "/TP")
|
||||||
|
if (_flags)
|
||||||
|
# append to list
|
||||||
|
list (APPEND _flags "${_sourceFileType${_language}}" /EP -fno-color-diagnostics -Xclang -H -Xclang -Eonly)
|
||||||
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "${_sourceFileType${_language}} /EP -fno-color-diagnostics -Xclang -H -Xclang -Eonly")
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
elseif (_compilerID MATCHES "Intel")
|
elseif (_compilerID MATCHES "Intel")
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
@ -1613,8 +1654,8 @@ function (cotire_add_pch_compilation_flags _language _compilerID _compilerVersio
|
|||||||
set (_flags "${_flags} /Zm${COTIRE_PCH_MEMORY_SCALING_FACTOR}")
|
set (_flags "${_flags} /Zm${COTIRE_PCH_MEMORY_SCALING_FACTOR}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
elseif (_compilerID MATCHES "GNU|Clang")
|
elseif (_compilerID MATCHES "GNU")
|
||||||
# GCC / Clang options used
|
# GCC options used
|
||||||
# -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
|
||||||
@ -1624,11 +1665,52 @@ function (cotire_add_pch_compilation_flags _language _compilerID _compilerVersio
|
|||||||
set (_xLanguage_CXX "c++-header")
|
set (_xLanguage_CXX "c++-header")
|
||||||
if (_flags)
|
if (_flags)
|
||||||
# append to list
|
# append to list
|
||||||
list (APPEND _flags "-x" "${_xLanguage_${_language}}" "-c" "${_prefixFile}" -o "${_pchFile}")
|
list (APPEND _flags -x "${_xLanguage_${_language}}" -c "${_prefixFile}" -o "${_pchFile}")
|
||||||
else()
|
else()
|
||||||
# return as a flag string
|
# return as a flag string
|
||||||
set (_flags "-x ${_xLanguage_${_language}} -c \"${_prefixFile}\" -o \"${_pchFile}\"")
|
set (_flags "-x ${_xLanguage_${_language}} -c \"${_prefixFile}\" -o \"${_pchFile}\"")
|
||||||
endif()
|
endif()
|
||||||
|
elseif (_compilerID MATCHES "Clang")
|
||||||
|
if (UNIX)
|
||||||
|
# Clang options used
|
||||||
|
# -x specify the source language
|
||||||
|
# -c compile but do not link
|
||||||
|
# -o place output in file
|
||||||
|
# -fno-pch-timestamp disable inclusion of timestamp in precompiled headers (clang 4.0.0+)
|
||||||
|
set (_xLanguage_C "c-header")
|
||||||
|
set (_xLanguage_CXX "c++-header")
|
||||||
|
if (_flags)
|
||||||
|
# append to list
|
||||||
|
list (APPEND _flags -x "${_xLanguage_${_language}}" -c "${_prefixFile}" -o "${_pchFile}")
|
||||||
|
if (NOT "${_compilerVersion}" VERSION_LESS "4.0.0")
|
||||||
|
list (APPEND _flags -Xclang -fno-pch-timestamp)
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "-x ${_xLanguage_${_language}} -c \"${_prefixFile}\" -o \"${_pchFile}\"")
|
||||||
|
if (NOT "${_compilerVersion}" VERSION_LESS "4.0.0")
|
||||||
|
set (_flags "${_flags} -Xclang -fno-pch-timestamp")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
elseif (WIN32)
|
||||||
|
# Clang-cl.exe options used
|
||||||
|
# /Yc creates a precompiled header file
|
||||||
|
# /Fp specifies precompiled header binary file name
|
||||||
|
# /FI forces inclusion of file
|
||||||
|
# /Zs syntax check only
|
||||||
|
# /TC treat all files named on the command line as C source files
|
||||||
|
# /TP treat all files named on the command line as C++ source files
|
||||||
|
set (_sourceFileTypeC "/TC")
|
||||||
|
set (_sourceFileTypeCXX "/TP")
|
||||||
|
if (_flags)
|
||||||
|
# append to list
|
||||||
|
list (APPEND _flags "${_sourceFileType${_language}}"
|
||||||
|
"/Yc${_prefixFile}" "/Fp${_pchFile}" "/FI${_prefixFile}" /Zs "${_hostFile}")
|
||||||
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "/Yc\"${_prefixFile}\" /Fp\"${_pchFile}\" /FI\"${_prefixFile}\"")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
elseif (_compilerID MATCHES "Intel")
|
elseif (_compilerID MATCHES "Intel")
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
file (TO_NATIVE_PATH "${_prefixFile}" _prefixFileNative)
|
file (TO_NATIVE_PATH "${_prefixFile}" _prefixFileNative)
|
||||||
@ -1679,10 +1761,10 @@ function (cotire_add_pch_compilation_flags _language _compilerID _compilerVersio
|
|||||||
if ("${_language}" STREQUAL "CXX")
|
if ("${_language}" STREQUAL "CXX")
|
||||||
list (APPEND _flags -Kc++)
|
list (APPEND _flags -Kc++)
|
||||||
endif()
|
endif()
|
||||||
list (APPEND _flags "-include" "${_prefixFile}" "-pch-dir" "${_pchDir}" "-pch-create" "${_pchName}" "-fsyntax-only" "${_hostFile}")
|
list (APPEND _flags -include "${_prefixFile}" -pch-dir "${_pchDir}" -pch-create "${_pchName}" -fsyntax-only "${_hostFile}")
|
||||||
if (NOT "${_compilerVersion}" VERSION_LESS "13.1.0")
|
if (NOT "${_compilerVersion}" VERSION_LESS "13.1.0")
|
||||||
if (NOT _pchSuppressMessages)
|
if (NOT _pchSuppressMessages)
|
||||||
list (APPEND _flags "-Wpch-messages")
|
list (APPEND _flags -Wpch-messages)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
@ -1742,23 +1824,46 @@ function (cotire_add_prefix_pch_inclusion_flags _language _compilerID _compilerV
|
|||||||
# note: ccache requires the -include flag to be used in order to process precompiled header correctly
|
# 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 "-Winvalid-pch" "-include" "${_prefixFile}")
|
list (APPEND _flags -Winvalid-pch -include "${_prefixFile}")
|
||||||
else()
|
else()
|
||||||
# return as a flag string
|
# return as a flag string
|
||||||
set (_flags "-Winvalid-pch -include \"${_prefixFile}\"")
|
set (_flags "-Winvalid-pch -include \"${_prefixFile}\"")
|
||||||
endif()
|
endif()
|
||||||
elseif (_compilerID MATCHES "Clang")
|
elseif (_compilerID MATCHES "Clang")
|
||||||
# Clang options used
|
if (UNIX)
|
||||||
# -include process include file as the first line of the primary source file
|
# Clang options used
|
||||||
# -include-pch include precompiled header file
|
# -include process include file as the first line of the primary source file
|
||||||
# -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
|
||||||
# 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}")
|
||||||
list (APPEND _flags "-Qunused-arguments" "-include" "${_prefixFile}")
|
else()
|
||||||
else()
|
# return as a flag string
|
||||||
# return as a flag string
|
set (_flags "-include \"${_prefixFile}\"")
|
||||||
set (_flags "-Qunused-arguments -include \"${_prefixFile}\"")
|
endif()
|
||||||
|
elseif (WIN32)
|
||||||
|
# Clang-cl.exe options used
|
||||||
|
# /Yu uses a precompiled header file during build
|
||||||
|
# /Fp specifies precompiled header binary file name
|
||||||
|
# /FI forces inclusion of file
|
||||||
|
if (_pchFile)
|
||||||
|
if (_flags)
|
||||||
|
# append to list
|
||||||
|
list (APPEND _flags "/Yu${_prefixFile}" "/Fp${_pchFile}" "/FI${_prefixFile}")
|
||||||
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "/Yu\"${_prefixFile}\" /Fp\"${_pchFile}\" /FI\"${_prefixFile}\"")
|
||||||
|
endif()
|
||||||
|
else()
|
||||||
|
# no precompiled header, force inclusion of prefix header
|
||||||
|
if (_flags)
|
||||||
|
# append to list
|
||||||
|
list (APPEND _flags "/FI${_prefixFile}")
|
||||||
|
else()
|
||||||
|
# return as a flag string
|
||||||
|
set (_flags "/FI\"${_prefixFile}\"")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
elseif (_compilerID MATCHES "Intel")
|
elseif (_compilerID MATCHES "Intel")
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
@ -1808,10 +1913,10 @@ function (cotire_add_prefix_pch_inclusion_flags _language _compilerID _compilerV
|
|||||||
endif()
|
endif()
|
||||||
if (_flags)
|
if (_flags)
|
||||||
# append to list
|
# append to list
|
||||||
list (APPEND _flags "-include" "${_prefixFile}" "-pch-dir" "${_pchDir}" "-pch-use" "${_pchName}")
|
list (APPEND _flags -include "${_prefixFile}" -pch-dir "${_pchDir}" -pch-use "${_pchName}")
|
||||||
if (NOT "${_compilerVersion}" VERSION_LESS "13.1.0")
|
if (NOT "${_compilerVersion}" VERSION_LESS "13.1.0")
|
||||||
if (NOT _pchSuppressMessages)
|
if (NOT _pchSuppressMessages)
|
||||||
list (APPEND _flags "-Wpch-messages")
|
list (APPEND _flags -Wpch-messages)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
@ -1827,7 +1932,7 @@ function (cotire_add_prefix_pch_inclusion_flags _language _compilerID _compilerV
|
|||||||
# no precompiled header, force inclusion of prefix header
|
# no precompiled header, force inclusion of prefix header
|
||||||
if (_flags)
|
if (_flags)
|
||||||
# append to list
|
# append to list
|
||||||
list (APPEND _flags "-include" "${_prefixFile}")
|
list (APPEND _flags -include "${_prefixFile}")
|
||||||
else()
|
else()
|
||||||
# return as a flag string
|
# return as a flag string
|
||||||
set (_flags "-include \"${_prefixFile}\"")
|
set (_flags "-include \"${_prefixFile}\"")
|
||||||
@ -1865,13 +1970,13 @@ function (cotire_precompile_prefix_header _prefixFile _pchFile _hostFile)
|
|||||||
if (COTIRE_VERBOSE)
|
if (COTIRE_VERBOSE)
|
||||||
message (STATUS "execute_process: ${_cmd}")
|
message (STATUS "execute_process: ${_cmd}")
|
||||||
endif()
|
endif()
|
||||||
if (_option_COMPILER_ID MATCHES "MSVC")
|
if (MSVC_IDE OR _option_COMPILER_ID MATCHES "MSVC")
|
||||||
# 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})
|
||||||
elseif (_option_COMPILER_ID MATCHES "GNU|Clang")
|
elseif (_option_COMPILER_ID MATCHES "Clang" AND _option_COMPILER_VERSION VERSION_LESS "4.0.0")
|
||||||
if (_option_COMPILER_LAUNCHER MATCHES "ccache" OR
|
if (_option_COMPILER_LAUNCHER MATCHES "ccache" OR
|
||||||
_option_COMPILER_EXECUTABLE MATCHES "ccache")
|
_option_COMPILER_EXECUTABLE MATCHES "ccache")
|
||||||
# Newer versions of Clang and GCC seem to embed a compilation timestamp into the precompiled header binary,
|
# Newer versions of Clang embed a compilation timestamp into the precompiled header binary,
|
||||||
# which results in "file has been modified since the precompiled header was built" errors if ccache is used.
|
# which results in "file has been modified since the precompiled header was built" errors if ccache is used.
|
||||||
# We work around the problem by disabling ccache upon pre-compiling the prefix header.
|
# We work around the problem by disabling ccache upon pre-compiling the prefix header.
|
||||||
set (ENV{CCACHE_DISABLE} "true")
|
set (ENV{CCACHE_DISABLE} "true")
|
||||||
@ -1890,7 +1995,7 @@ function (cotire_check_precompiled_header_support _language _target _msgVar)
|
|||||||
set (_unsupportedCompiler
|
set (_unsupportedCompiler
|
||||||
"Precompiled headers not supported for ${_language} compiler ${CMAKE_${_language}_COMPILER_ID}")
|
"Precompiled headers not supported for ${_language} compiler ${CMAKE_${_language}_COMPILER_ID}")
|
||||||
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC")
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC")
|
||||||
# supported since Visual Studio C++ 6.0
|
# PCH supported since Visual Studio C++ 6.0
|
||||||
# and CMake does not support an earlier version
|
# and CMake does not support an earlier version
|
||||||
set (${_msgVar} "" PARENT_SCOPE)
|
set (${_msgVar} "" PARENT_SCOPE)
|
||||||
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "GNU")
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "GNU")
|
||||||
@ -1901,8 +2006,16 @@ function (cotire_check_precompiled_header_support _language _target _msgVar)
|
|||||||
set (${_msgVar} "" PARENT_SCOPE)
|
set (${_msgVar} "" PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Clang")
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Clang")
|
||||||
# all Clang versions have PCH support
|
if (UNIX)
|
||||||
set (${_msgVar} "" PARENT_SCOPE)
|
# all Unix Clang versions have PCH support
|
||||||
|
set (${_msgVar} "" PARENT_SCOPE)
|
||||||
|
elseif (WIN32)
|
||||||
|
# only clang-cl is supported under Windows
|
||||||
|
get_filename_component(_compilerName "${CMAKE_${_language}_COMPILER}" NAME_WE)
|
||||||
|
if (NOT _compilerName MATCHES "cl$")
|
||||||
|
set (${_msgVar} "${_unsupportedCompiler} version ${CMAKE_${_language}_COMPILER_VERSION}. Use clang-cl instead." PARENT_SCOPE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Intel")
|
elseif (CMAKE_${_language}_COMPILER_ID MATCHES "Intel")
|
||||||
# Intel PCH support requires version >= 8.0.0
|
# Intel PCH support requires version >= 8.0.0
|
||||||
if ("${CMAKE_${_language}_COMPILER_VERSION}" VERSION_LESS "8.0.0")
|
if ("${CMAKE_${_language}_COMPILER_VERSION}" VERSION_LESS "8.0.0")
|
||||||
@ -1913,19 +2026,25 @@ function (cotire_check_precompiled_header_support _language _target _msgVar)
|
|||||||
else()
|
else()
|
||||||
set (${_msgVar} "${_unsupportedCompiler}." PARENT_SCOPE)
|
set (${_msgVar} "${_unsupportedCompiler}." PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
|
# check if ccache is used as a compiler launcher
|
||||||
get_target_property(_launcher ${_target} ${_language}_COMPILER_LAUNCHER)
|
get_target_property(_launcher ${_target} ${_language}_COMPILER_LAUNCHER)
|
||||||
if (CMAKE_${_language}_COMPILER MATCHES "ccache" OR _launcher MATCHES "ccache")
|
get_filename_component(_realCompilerExe "${CMAKE_${_language}_COMPILER}" REALPATH)
|
||||||
|
if (_realCompilerExe MATCHES "ccache" OR _launcher MATCHES "ccache")
|
||||||
|
# verify that ccache configuration is compatible with precompiled headers
|
||||||
|
# always check environment variable CCACHE_SLOPPINESS, because earlier versions of ccache
|
||||||
|
# do not report the "sloppiness" setting correctly upon printing ccache configuration
|
||||||
if (DEFINED ENV{CCACHE_SLOPPINESS})
|
if (DEFINED ENV{CCACHE_SLOPPINESS})
|
||||||
if (NOT "$ENV{CCACHE_SLOPPINESS}" MATCHES "pch_defines" OR NOT "$ENV{CCACHE_SLOPPINESS}" MATCHES "time_macros")
|
if (NOT "$ENV{CCACHE_SLOPPINESS}" MATCHES "pch_defines" OR
|
||||||
|
NOT "$ENV{CCACHE_SLOPPINESS}" MATCHES "time_macros")
|
||||||
set (${_msgVar}
|
set (${_msgVar}
|
||||||
"ccache requires the environment variable CCACHE_SLOPPINESS to be set to \"pch_defines,time_macros\"."
|
"ccache requires the environment variable CCACHE_SLOPPINESS to be set to \"pch_defines,time_macros\"."
|
||||||
PARENT_SCOPE)
|
PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
if (_launcher MATCHES "ccache")
|
if (_realCompilerExe MATCHES "ccache")
|
||||||
get_filename_component(_ccacheExe "${_launcher}" REALPATH)
|
set (_ccacheExe "${_realCompilerExe}")
|
||||||
else()
|
else()
|
||||||
get_filename_component(_ccacheExe "${CMAKE_${_language}_COMPILER}" REALPATH)
|
set (_ccacheExe "${_launcher}")
|
||||||
endif()
|
endif()
|
||||||
execute_process(
|
execute_process(
|
||||||
COMMAND "${_ccacheExe}" "--print-config"
|
COMMAND "${_ccacheExe}" "--print-config"
|
||||||
@ -1933,9 +2052,10 @@ function (cotire_check_precompiled_header_support _language _target _msgVar)
|
|||||||
RESULT_VARIABLE _result
|
RESULT_VARIABLE _result
|
||||||
OUTPUT_VARIABLE _ccacheConfig OUTPUT_STRIP_TRAILING_WHITESPACE
|
OUTPUT_VARIABLE _ccacheConfig OUTPUT_STRIP_TRAILING_WHITESPACE
|
||||||
ERROR_QUIET)
|
ERROR_QUIET)
|
||||||
if (_result OR NOT
|
if (_result)
|
||||||
_ccacheConfig MATCHES "sloppiness.*=.*time_macros" OR NOT
|
set (${_msgVar} "ccache configuration cannot be determined." PARENT_SCOPE)
|
||||||
_ccacheConfig MATCHES "sloppiness.*=.*pch_defines")
|
elseif (NOT _ccacheConfig MATCHES "sloppiness.*=.*time_macros" OR
|
||||||
|
NOT _ccacheConfig MATCHES "sloppiness.*=.*pch_defines")
|
||||||
set (${_msgVar}
|
set (${_msgVar}
|
||||||
"ccache requires configuration setting \"sloppiness\" to be set to \"pch_defines,time_macros\"."
|
"ccache requires configuration setting \"sloppiness\" to be set to \"pch_defines,time_macros\"."
|
||||||
PARENT_SCOPE)
|
PARENT_SCOPE)
|
||||||
@ -2261,8 +2381,9 @@ endfunction()
|
|||||||
|
|
||||||
function (cotire_setup_pch_file_compilation _language _target _targetScript _prefixFile _pchFile _hostFile)
|
function (cotire_setup_pch_file_compilation _language _target _targetScript _prefixFile _pchFile _hostFile)
|
||||||
set (_sourceFiles ${ARGN})
|
set (_sourceFiles ${ARGN})
|
||||||
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel" OR
|
||||||
# for Visual Studio and Intel, we attach the precompiled header compilation to the host file
|
(WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "Clang"))
|
||||||
|
# for MSVC, Intel and Clang-cl, we attach the precompiled header compilation to the host file
|
||||||
# the remaining files include the precompiled header, see cotire_setup_pch_file_inclusion
|
# the remaining files include the precompiled header, see cotire_setup_pch_file_inclusion
|
||||||
if (_sourceFiles)
|
if (_sourceFiles)
|
||||||
set (_flags "")
|
set (_flags "")
|
||||||
@ -2307,8 +2428,9 @@ function (cotire_setup_pch_file_compilation _language _target _targetScript _pre
|
|||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function (cotire_setup_pch_file_inclusion _language _target _wholeTarget _prefixFile _pchFile _hostFile)
|
function (cotire_setup_pch_file_inclusion _language _target _wholeTarget _prefixFile _pchFile _hostFile)
|
||||||
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
if (CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel" OR
|
||||||
# for Visual Studio and Intel, we include the precompiled header in all but the host file
|
(WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "Clang"))
|
||||||
|
# for MSVC, Intel and clang-cl, we include the precompiled header in all but the host file
|
||||||
# the host file does the precompiled header compilation, see cotire_setup_pch_file_compilation
|
# the host file does the precompiled header compilation, see cotire_setup_pch_file_compilation
|
||||||
set (_sourceFiles ${ARGN})
|
set (_sourceFiles ${ARGN})
|
||||||
list (LENGTH _sourceFiles _numberOfSourceFiles)
|
list (LENGTH _sourceFiles _numberOfSourceFiles)
|
||||||
@ -2454,9 +2576,10 @@ function (cotire_setup_target_pch_usage _languages _target _wholeTarget)
|
|||||||
# if this is a single-language target without any excluded files
|
# if this is a single-language target without any excluded files
|
||||||
if (_wholeTarget)
|
if (_wholeTarget)
|
||||||
set (_language "${_languages}")
|
set (_language "${_languages}")
|
||||||
# for Visual Studio and Intel, precompiled header inclusion is always done on the source file level
|
# for MSVC, Intel and clang-cl, precompiled header inclusion is always done on the source file level
|
||||||
# see cotire_setup_pch_file_inclusion
|
# see cotire_setup_pch_file_inclusion
|
||||||
if (NOT CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
if (NOT CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel" AND NOT
|
||||||
|
(WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "Clang"))
|
||||||
get_property(_prefixFile TARGET ${_target} PROPERTY COTIRE_${_language}_PREFIX_HEADER)
|
get_property(_prefixFile TARGET ${_target} PROPERTY COTIRE_${_language}_PREFIX_HEADER)
|
||||||
if (_prefixFile)
|
if (_prefixFile)
|
||||||
get_property(_pchFile TARGET ${_target} PROPERTY COTIRE_${_language}_PRECOMPILED_HEADER)
|
get_property(_pchFile TARGET ${_target} PROPERTY COTIRE_${_language}_PRECOMPILED_HEADER)
|
||||||
@ -2491,7 +2614,8 @@ function (cotire_setup_unity_generation_commands _language _target _targetScript
|
|||||||
set_property (SOURCE "${_unityFile}" PROPERTY OBJECT_DEPENDS ${_objectDependsPaths})
|
set_property (SOURCE "${_unityFile}" PROPERTY OBJECT_DEPENDS ${_objectDependsPaths})
|
||||||
endif()
|
endif()
|
||||||
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
if (WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
||||||
# unity file compilation results in potentially huge object file, thus use /bigobj by default unter MSVC and Windows Intel
|
# unity file compilation results in potentially huge object file,
|
||||||
|
# thus use /bigobj by default unter cl.exe and Windows Intel
|
||||||
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)
|
||||||
@ -2697,6 +2821,9 @@ function (cotire_make_target_message _target _languages _disableMsg _targetMsgVa
|
|||||||
else()
|
else()
|
||||||
set (_targetMsg "${_languagesStr} target ${_target} cotired without unity build.")
|
set (_targetMsg "${_languagesStr} target ${_target} cotired without unity build.")
|
||||||
endif()
|
endif()
|
||||||
|
if (_disableMsg)
|
||||||
|
set (_targetMsg "${_targetMsg} ${_disableMsg}")
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
if (_excludedStr)
|
if (_excludedStr)
|
||||||
set (_targetMsg "${_languagesStr} target ${_target} cotired ${_excludedStr}.")
|
set (_targetMsg "${_languagesStr} target ${_target} cotired ${_excludedStr}.")
|
||||||
@ -2786,6 +2913,20 @@ function (cotire_choose_target_languages _target _targetLanguagesVar _wholeTarge
|
|||||||
set (_targetUsePCH FALSE)
|
set (_targetUsePCH FALSE)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
if (_targetAddSCU)
|
||||||
|
# disable unity builds if automatic Qt processing is used
|
||||||
|
get_target_property(_targetAutoMoc ${_target} AUTOMOC)
|
||||||
|
get_target_property(_targetAutoUic ${_target} AUTOUIC)
|
||||||
|
get_target_property(_targetAutoRcc ${_target} AUTORCC)
|
||||||
|
if (_targetAutoMoc OR _targetAutoUic OR _targetAutoRcc)
|
||||||
|
if (_disableMsg)
|
||||||
|
set (_disableMsg "${_disableMsg} Target uses automatic CMake Qt processing.")
|
||||||
|
else()
|
||||||
|
set (_disableMsg "Target uses automatic CMake Qt processing.")
|
||||||
|
endif()
|
||||||
|
set (_targetAddSCU FALSE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
set_property(TARGET ${_target} PROPERTY COTIRE_ENABLE_PRECOMPILED_HEADER ${_targetUsePCH})
|
set_property(TARGET ${_target} PROPERTY COTIRE_ENABLE_PRECOMPILED_HEADER ${_targetUsePCH})
|
||||||
set_property(TARGET ${_target} PROPERTY COTIRE_ADD_UNITY_BUILD ${_targetAddSCU})
|
set_property(TARGET ${_target} PROPERTY COTIRE_ADD_UNITY_BUILD ${_targetAddSCU})
|
||||||
cotire_make_target_message(${_target} "${_targetLanguages}" "${_disableMsg}" _targetMsg ${_allExcludedSourceFiles})
|
cotire_make_target_message(${_target} "${_targetLanguages}" "${_disableMsg}" _targetMsg ${_allExcludedSourceFiles})
|
||||||
@ -2813,7 +2954,11 @@ function (cotire_compute_unity_max_number_of_includes _target _maxIncludesVar)
|
|||||||
set (_sourceFiles ${ARGN})
|
set (_sourceFiles ${ARGN})
|
||||||
get_target_property(_maxIncludes ${_target} COTIRE_UNITY_SOURCE_MAXIMUM_NUMBER_OF_INCLUDES)
|
get_target_property(_maxIncludes ${_target} COTIRE_UNITY_SOURCE_MAXIMUM_NUMBER_OF_INCLUDES)
|
||||||
if (_maxIncludes MATCHES "(-j|--parallel|--jobs) ?([0-9]*)")
|
if (_maxIncludes MATCHES "(-j|--parallel|--jobs) ?([0-9]*)")
|
||||||
set (_numberOfThreads "${CMAKE_MATCH_2}")
|
if (DEFINED CMAKE_MATCH_2)
|
||||||
|
set (_numberOfThreads "${CMAKE_MATCH_2}")
|
||||||
|
else()
|
||||||
|
set (_numberOfThreads "")
|
||||||
|
endif()
|
||||||
if (NOT _numberOfThreads)
|
if (NOT _numberOfThreads)
|
||||||
# use all available cores
|
# use all available cores
|
||||||
ProcessorCount(_numberOfThreads)
|
ProcessorCount(_numberOfThreads)
|
||||||
@ -2926,8 +3071,9 @@ function (cotire_setup_pch_target _languages _configurations _target)
|
|||||||
set (_dependsFiles "")
|
set (_dependsFiles "")
|
||||||
foreach (_language ${_languages})
|
foreach (_language ${_languages})
|
||||||
set (_props COTIRE_${_language}_PREFIX_HEADER COTIRE_${_language}_UNITY_SOURCE)
|
set (_props COTIRE_${_language}_PREFIX_HEADER COTIRE_${_language}_UNITY_SOURCE)
|
||||||
if (NOT CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel")
|
if (NOT CMAKE_${_language}_COMPILER_ID MATCHES "MSVC|Intel" AND NOT
|
||||||
# Visual Studio and Intel only create precompiled header as a side effect
|
(WIN32 AND CMAKE_${_language}_COMPILER_ID MATCHES "Clang"))
|
||||||
|
# MSVC, Intel and clang-cl only create precompiled header as a side effect
|
||||||
list (INSERT _props 0 COTIRE_${_language}_PRECOMPILED_HEADER)
|
list (INSERT _props 0 COTIRE_${_language}_PRECOMPILED_HEADER)
|
||||||
endif()
|
endif()
|
||||||
cotire_get_first_set_property_value(_dependsFile TARGET ${_target} ${_props})
|
cotire_get_first_set_property_value(_dependsFile TARGET ${_target} ${_props})
|
||||||
@ -2975,6 +3121,7 @@ function (cotire_collect_unity_target_sources _target _languages _unityTargetSou
|
|||||||
list (APPEND _unityTargetSources ${_unityFiles})
|
list (APPEND _unityTargetSources ${_unityFiles})
|
||||||
endif()
|
endif()
|
||||||
endforeach()
|
endforeach()
|
||||||
|
# handle object libraries which are part of the target's sources
|
||||||
get_target_property(_linkLibrariesStrategy ${_target} COTIRE_UNITY_LINK_LIBRARIES_INIT)
|
get_target_property(_linkLibrariesStrategy ${_target} COTIRE_UNITY_LINK_LIBRARIES_INIT)
|
||||||
if ("${_linkLibrariesStrategy}" MATCHES "^COPY_UNITY$")
|
if ("${_linkLibrariesStrategy}" MATCHES "^COPY_UNITY$")
|
||||||
cotire_filter_object_libraries(${_target} _objectLibraries ${_targetSourceFiles})
|
cotire_filter_object_libraries(${_target} _objectLibraries ${_targetSourceFiles})
|
||||||
@ -3019,21 +3166,6 @@ function (cotire_setup_unity_build_target _languages _configurations _target)
|
|||||||
# determine unity target sources
|
# determine unity target sources
|
||||||
set (_unityTargetSources "")
|
set (_unityTargetSources "")
|
||||||
cotire_collect_unity_target_sources(${_target} "${_languages}" _unityTargetSources)
|
cotire_collect_unity_target_sources(${_target} "${_languages}" _unityTargetSources)
|
||||||
# handle automatic Qt processing
|
|
||||||
get_target_property(_targetAutoMoc ${_target} AUTOMOC)
|
|
||||||
get_target_property(_targetAutoUic ${_target} AUTOUIC)
|
|
||||||
get_target_property(_targetAutoRcc ${_target} AUTORCC)
|
|
||||||
if (_targetAutoMoc OR _targetAutoUic OR _targetAutoRcc)
|
|
||||||
# if the original target sources are subject to CMake's automatic Qt processing,
|
|
||||||
# also include implicitly generated <targetname>_automoc.cpp file
|
|
||||||
if (CMAKE_VERSION VERSION_LESS "3.8.0")
|
|
||||||
list (APPEND _unityTargetSources "${_target}_automoc.cpp")
|
|
||||||
set_property (SOURCE "${_target}_automoc.cpp" PROPERTY GENERATED TRUE)
|
|
||||||
else()
|
|
||||||
list (APPEND _unityTargetSources "${_target}_autogen/moc_compilation.cpp")
|
|
||||||
set_property (SOURCE "${_target}_autogen/moc_compilation.cpp" PROPERTY GENERATED TRUE)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
# prevent AUTOMOC, AUTOUIC and AUTORCC properties from being set when the unity target is created
|
# prevent AUTOMOC, AUTOUIC and AUTORCC properties from being set when the unity target is created
|
||||||
set (CMAKE_AUTOMOC OFF)
|
set (CMAKE_AUTOMOC OFF)
|
||||||
set (CMAKE_AUTOUIC OFF)
|
set (CMAKE_AUTOUIC OFF)
|
||||||
@ -3047,21 +3179,6 @@ function (cotire_setup_unity_build_target _languages _configurations _target)
|
|||||||
else()
|
else()
|
||||||
add_library(${_unityTargetName} ${_unityTargetSubType} EXCLUDE_FROM_ALL ${_unityTargetSources})
|
add_library(${_unityTargetName} ${_unityTargetSubType} EXCLUDE_FROM_ALL ${_unityTargetSources})
|
||||||
endif()
|
endif()
|
||||||
if ("${CMAKE_GENERATOR}" MATCHES "Visual Studio")
|
|
||||||
# depend on original target's automoc target, if it exists
|
|
||||||
if (TARGET ${_target}_automoc)
|
|
||||||
add_dependencies(${_unityTargetName} ${_target}_automoc)
|
|
||||||
endif()
|
|
||||||
else()
|
|
||||||
if (_targetAutoMoc OR _targetAutoUic OR _targetAutoRcc)
|
|
||||||
# depend on the original target's implicity generated <targetname>_automoc target
|
|
||||||
if (CMAKE_VERSION VERSION_LESS "3.8.0")
|
|
||||||
add_dependencies(${_unityTargetName} ${_target}_automoc)
|
|
||||||
else()
|
|
||||||
add_dependencies(${_unityTargetName} ${_target}_autogen)
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
endif()
|
|
||||||
# copy output location properties
|
# copy output location properties
|
||||||
set (_outputDirProperties
|
set (_outputDirProperties
|
||||||
ARCHIVE_OUTPUT_DIRECTORY ARCHIVE_OUTPUT_DIRECTORY_<CONFIG>
|
ARCHIVE_OUTPUT_DIRECTORY ARCHIVE_OUTPUT_DIRECTORY_<CONFIG>
|
||||||
@ -3132,7 +3249,8 @@ function (cotire_setup_unity_build_target _languages _configurations _target)
|
|||||||
INTERFACE_AUTOUIC_OPTIONS NO_SYSTEM_FROM_IMPORTED)
|
INTERFACE_AUTOUIC_OPTIONS NO_SYSTEM_FROM_IMPORTED)
|
||||||
# copy link stuff
|
# copy link stuff
|
||||||
cotire_copy_set_properties("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
cotire_copy_set_properties("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
||||||
BUILD_WITH_INSTALL_RPATH INSTALL_RPATH INSTALL_RPATH_USE_LINK_PATH SKIP_BUILD_RPATH
|
BUILD_WITH_INSTALL_RPATH BUILD_WITH_INSTALL_NAME_DIR
|
||||||
|
INSTALL_RPATH INSTALL_RPATH_USE_LINK_PATH SKIP_BUILD_RPATH
|
||||||
LINKER_LANGUAGE LINK_DEPENDS LINK_DEPENDS_NO_SHARED
|
LINKER_LANGUAGE LINK_DEPENDS LINK_DEPENDS_NO_SHARED
|
||||||
LINK_FLAGS LINK_FLAGS_<CONFIG>
|
LINK_FLAGS LINK_FLAGS_<CONFIG>
|
||||||
LINK_INTERFACE_LIBRARIES LINK_INTERFACE_LIBRARIES_<CONFIG>
|
LINK_INTERFACE_LIBRARIES LINK_INTERFACE_LIBRARIES_<CONFIG>
|
||||||
@ -3174,6 +3292,10 @@ function (cotire_setup_unity_build_target _languages _configurations _target)
|
|||||||
ANDROID_NATIVE_LIB_DEPENDENCIES ANDROID_NATIVE_LIB_DIRECTORIES
|
ANDROID_NATIVE_LIB_DEPENDENCIES ANDROID_NATIVE_LIB_DIRECTORIES
|
||||||
ANDROID_PROCESS_MAX ANDROID_PROGUARD ANDROID_PROGUARD_CONFIG_PATH
|
ANDROID_PROCESS_MAX ANDROID_PROGUARD ANDROID_PROGUARD_CONFIG_PATH
|
||||||
ANDROID_SECURE_PROPS_PATH ANDROID_SKIP_ANT_STEP ANDROID_STL_TYPE)
|
ANDROID_SECURE_PROPS_PATH ANDROID_SKIP_ANT_STEP ANDROID_STL_TYPE)
|
||||||
|
# copy CUDA platform specific stuff
|
||||||
|
cotire_copy_set_properties("${_configurations}" TARGET ${_target} ${_unityTargetName}
|
||||||
|
CUDA_PTX_COMPILATION CUDA_SEPARABLE_COMPILATION CUDA_RESOLVE_DEVICE_SYMBOLS
|
||||||
|
CUDA_EXTENSIONS CUDA_STANDARD CUDA_STANDARD_REQUIRED)
|
||||||
# use output name from original target
|
# use output name from original target
|
||||||
get_target_property(_targetOutputName ${_unityTargetName} OUTPUT_NAME)
|
get_target_property(_targetOutputName ${_unityTargetName} OUTPUT_NAME)
|
||||||
if (NOT _targetOutputName)
|
if (NOT _targetOutputName)
|
||||||
@ -3187,6 +3309,13 @@ function (cotire_setup_unity_build_target _languages _configurations _target)
|
|||||||
set_property(TARGET ${_unityTargetName} PROPERTY ENABLE_EXPORTS TRUE)
|
set_property(TARGET ${_unityTargetName} PROPERTY ENABLE_EXPORTS TRUE)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
# enable parallel compilation for MSVC
|
||||||
|
if (MSVC AND "${CMAKE_GENERATOR}" MATCHES "Visual Studio")
|
||||||
|
list (LENGTH _unityTargetSources _numberOfUnityTargetSources)
|
||||||
|
if (_numberOfUnityTargetSources GREATER 1)
|
||||||
|
set_property(TARGET ${_unityTargetName} APPEND PROPERTY COMPILE_OPTIONS "/MP")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
cotire_init_target(${_unityTargetName})
|
cotire_init_target(${_unityTargetName})
|
||||||
cotire_add_to_unity_all_target(${_unityTargetName})
|
cotire_add_to_unity_all_target(${_unityTargetName})
|
||||||
set_property(TARGET ${_target} PROPERTY COTIRE_UNITY_TARGET_NAME "${_unityTargetName}")
|
set_property(TARGET ${_target} PROPERTY COTIRE_UNITY_TARGET_NAME "${_unityTargetName}")
|
||||||
@ -3345,6 +3474,13 @@ function (cotire_target_link_libraries _target)
|
|||||||
message (STATUS "unity target ${_unityTargetName} interface link libraries: ${_unityLinkInterfaceLibraries}")
|
message (STATUS "unity target ${_unityTargetName} interface link libraries: ${_unityLinkInterfaceLibraries}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
get_target_property(_manualDependencies ${_target} MANUALLY_ADDED_DEPENDENCIES)
|
||||||
|
if (_manualDependencies)
|
||||||
|
cotire_map_libraries("${_linkLibrariesStrategy}" _unityManualDependencies ${_manualDependencies})
|
||||||
|
if (_unityManualDependencies)
|
||||||
|
add_dependencies("${_unityTargetName}" ${_unityManualDependencies})
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
endfunction(cotire_target_link_libraries)
|
endfunction(cotire_target_link_libraries)
|
||||||
@ -3641,7 +3777,7 @@ else()
|
|||||||
set (COTIRE_UNITY_SOURCE_EXCLUDE_EXTENSIONS "m;mm" CACHE STRING
|
set (COTIRE_UNITY_SOURCE_EXCLUDE_EXTENSIONS "m;mm" CACHE STRING
|
||||||
"Ignore sources with the listed file extensions from the generated unity source.")
|
"Ignore sources with the listed file extensions from the generated unity source.")
|
||||||
|
|
||||||
set (COTIRE_MINIMUM_NUMBER_OF_TARGET_SOURCES "3" CACHE STRING
|
set (COTIRE_MINIMUM_NUMBER_OF_TARGET_SOURCES "2" CACHE STRING
|
||||||
"Minimum number of sources in target required to enable use of precompiled header.")
|
"Minimum number of sources in target required to enable use of precompiled header.")
|
||||||
|
|
||||||
if (NOT DEFINED COTIRE_MAXIMUM_NUMBER_OF_UNITY_INCLUDES_INIT)
|
if (NOT DEFINED COTIRE_MAXIMUM_NUMBER_OF_UNITY_INCLUDES_INIT)
|
||||||
@ -3740,7 +3876,7 @@ else()
|
|||||||
FULL_DOCS
|
FULL_DOCS
|
||||||
"The variable can be set to an integer > 0."
|
"The variable can be set to an integer > 0."
|
||||||
"If a target contains less than that number of source files, cotire will not enable the use of the precompiled header for the target."
|
"If a target contains less than that number of source files, cotire will not enable the use of the precompiled header for the target."
|
||||||
"If not defined, defaults to 3."
|
"If not defined, defaults to 2."
|
||||||
)
|
)
|
||||||
|
|
||||||
define_property(
|
define_property(
|
||||||
|
Loading…
Reference in New Issue
Block a user