CMake: Exclude dSYM INSTALL commands for already excluded tools in debug
Debug tools are excluded from the ALL target for debug_and_release builds. However, when using the -separate-debug-info option, the same exclusion wasn't being applied for their dSYM INSTALL commands, resulting in a CMake install error. Pass any additional install args like EXCLUDE_FROM_ALL COMPONENT "ExcludedExecutables" to the installation rules of qt_enable_separate_debug_info and install dSYMs for executables per-config in a multi-config build. All the non-main config executable install rules are optional because the non-main config executables are excluded from ALL. Amends 5b136abd21803988f96b9b66c992822efbef97ec Fixes: QTBUG-93999 Change-Id: I95c3ce28215c3ee535551e4b7a5fa9731f8f1c28 Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io> Reviewed-by: Joerg Bornemann <joerg.bornemann@qt.io> (cherry picked from commit 3c148323c08cff1487211c18beda90ae2c6ef508) Reviewed-by: Qt Cherry-pick Bot <cherrypick_bot@qt-project.org>
This commit is contained in:
parent
e4c90e81fe
commit
5fa7adc234
@ -167,7 +167,14 @@ function(qt_internal_add_executable name)
|
||||
${install_targets_default_args})
|
||||
endforeach()
|
||||
|
||||
qt_enable_separate_debug_info(${name} "${arg_INSTALL_DIRECTORY}")
|
||||
if(NOT exclude_from_all AND arg_QT_APP AND QT_FEATURE_debug_and_release)
|
||||
set(separate_debug_info_executable_arg "QT_EXECUTABLE")
|
||||
else()
|
||||
unset(separate_debug_info_executable_arg)
|
||||
endif()
|
||||
qt_enable_separate_debug_info(${name} "${arg_INSTALL_DIRECTORY}"
|
||||
${separate_debug_info_executable_arg}
|
||||
ADDITIONAL_INSTALL_ARGS ${additional_install_args})
|
||||
qt_internal_install_pdb_files(${name} "${arg_INSTALL_DIRECTORY}")
|
||||
endif()
|
||||
|
||||
|
@ -6,6 +6,11 @@ endif()
|
||||
|
||||
# Enable separate debug information for the given target
|
||||
function(qt_enable_separate_debug_info target installDestination)
|
||||
set(flags QT_EXECUTABLE)
|
||||
set(options)
|
||||
set(multiopts ADDITIONAL_INSTALL_ARGS)
|
||||
cmake_parse_arguments(arg "${flags}" "${options}" "${multiopts}" ${ARGN})
|
||||
|
||||
if (NOT QT_FEATURE_separate_debug_info)
|
||||
return()
|
||||
endif()
|
||||
@ -66,7 +71,27 @@ function(qt_enable_separate_debug_info target installDestination)
|
||||
COMMAND ${CMAKE_COMMAND} -E copy "Info.dSYM.plist" "${debug_info_contents_dir}/Info.plist"
|
||||
)
|
||||
set(debug_info_target "${debug_info_target_dir}/$<TARGET_FILE_BASE_NAME:${target}>")
|
||||
qt_install(DIRECTORY ${debug_info_bundle_dir} DESTINATION ${installDestination})
|
||||
|
||||
if(arg_QT_EXECUTABLE AND QT_FEATURE_debug_and_release)
|
||||
qt_get_cmake_configurations(cmake_configs)
|
||||
foreach(cmake_config ${cmake_configs})
|
||||
# Make installation optional for targets that are not built by default in this config
|
||||
if(NOT (cmake_config STREQUAL QT_MULTI_CONFIG_FIRST_CONFIG))
|
||||
set(install_optional_arg OPTIONAL)
|
||||
else()
|
||||
unset(install_optional_arg)
|
||||
endif()
|
||||
qt_install(DIRECTORY ${debug_info_bundle_dir}
|
||||
${arg_ADDITIONAL_INSTALL_ARGS}
|
||||
${install_optional_arg}
|
||||
CONFIGURATIONS ${cmake_config}
|
||||
DESTINATION ${installDestination})
|
||||
endforeach()
|
||||
else()
|
||||
qt_install(DIRECTORY ${debug_info_bundle_dir}
|
||||
${arg_ADDITIONAL_INSTALL_ARGS}
|
||||
DESTINATION ${installDestination})
|
||||
endif()
|
||||
else()
|
||||
set(debug_info_target "$<TARGET_FILE_DIR:${target}>/$<TARGET_FILE_BASE_NAME:${target}>.${debug_info_suffix}")
|
||||
qt_install(FILES ${debug_info_target} DESTINATION ${installDestination})
|
||||
|
@ -257,7 +257,7 @@ function(qt_internal_add_tool target_name)
|
||||
|
||||
endif()
|
||||
|
||||
qt_enable_separate_debug_info(${target_name} "${install_dir}")
|
||||
qt_enable_separate_debug_info(${target_name} "${install_dir}" QT_EXECUTABLE)
|
||||
qt_internal_install_pdb_files(${target_name} "${install_dir}")
|
||||
endfunction()
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user