QtEntryPoint: Fix linking Release against RelWithDebInfo with MSVC
To be able to link a Release user project against a RelWithDebInfo Qt we set several IMPORTED_*_RELEASE properties in the *AdditionalTargetInfo.cmake file of each Qt module. The EntryPoint module however is a bit special as it is an INTERFACE_LIBRARY linking publicly against a static library (EntryPointimplementation). Its *AdditionalTargetInfo.cmake file was almost empty, because qt_internal_export_additional_targets_file was called before EntryPointImplementation was set up. Also, qt_internal_add_module, which calls qt_internal_export_additional_targets_file, does not know that we want to export the EntryPointImplementation target. We fix this by telling qt_internal_add_module(EntryPoint) to not generate the *AdditionalTargetInfo.cmake file and call qt_internal_export_additional_targets_file later to take the targets EntryPoint and EntryPointImplementation into consideration. qt_internal_add_module learned the option NO_ADDITIONAL_TARGET_INFO to turn off the generation of *AdditionalTargetInfo.cmake files. Pick-to: 6.0 Fixes: QTBUG-90039 Change-Id: I68ec7125b538a57567035e7adb8dac3b213f95e6 Reviewed-by: Tor Arne Vestbø <tor.arne.vestbo@qt.io>
This commit is contained in:
parent
9f7088fd7f
commit
b0add5bf2f
@ -8,12 +8,18 @@
|
|||||||
# this module are imported into the scope of the calling feature.
|
# this module are imported into the scope of the calling feature.
|
||||||
#
|
#
|
||||||
# Target is without leading "Qt". So e.g. the "QtCore" module has the target "Core".
|
# Target is without leading "Qt". So e.g. the "QtCore" module has the target "Core".
|
||||||
|
#
|
||||||
|
# Options:
|
||||||
|
# NO_ADDITIONAL_TARGET_INFO
|
||||||
|
# Don't generate a Qt6*AdditionalTargetInfo.cmake file.
|
||||||
|
# The caller is responsible for creating one.
|
||||||
|
#
|
||||||
function(qt_internal_add_module target)
|
function(qt_internal_add_module target)
|
||||||
qt_internal_module_info(module "${target}")
|
qt_internal_module_info(module "${target}")
|
||||||
|
|
||||||
# Process arguments:
|
# Process arguments:
|
||||||
qt_parse_all_arguments(arg "qt_add_module"
|
qt_parse_all_arguments(arg "qt_add_module"
|
||||||
"NO_MODULE_HEADERS;STATIC;DISABLE_TOOLS_EXPORT;EXCEPTIONS;INTERNAL_MODULE;NO_SYNC_QT;NO_PRIVATE_MODULE;HEADER_MODULE;GENERATE_METATYPES;NO_CONFIG_HEADER_FILE;SKIP_DEPENDS_INCLUDE"
|
"NO_MODULE_HEADERS;STATIC;DISABLE_TOOLS_EXPORT;EXCEPTIONS;INTERNAL_MODULE;NO_SYNC_QT;NO_PRIVATE_MODULE;HEADER_MODULE;GENERATE_METATYPES;NO_CONFIG_HEADER_FILE;SKIP_DEPENDS_INCLUDE;NO_ADDITIONAL_TARGET_INFO"
|
||||||
"MODULE_INCLUDE_NAME;CONFIG_MODULE_NAME;PRECOMPILED_HEADER;CONFIGURE_FILE_PATH;${__default_target_info_args}"
|
"MODULE_INCLUDE_NAME;CONFIG_MODULE_NAME;PRECOMPILED_HEADER;CONFIGURE_FILE_PATH;${__default_target_info_args}"
|
||||||
"${__default_private_args};${__default_public_args};${__default_private_module_args};QMAKE_MODULE_CONFIG;EXTRA_CMAKE_FILES;EXTRA_CMAKE_INCLUDES;NO_PCH_SOURCES" ${ARGN})
|
"${__default_private_args};${__default_public_args};${__default_private_module_args};QMAKE_MODULE_CONFIG;EXTRA_CMAKE_FILES;EXTRA_CMAKE_INCLUDES;NO_PCH_SOURCES" ${ARGN})
|
||||||
|
|
||||||
@ -565,10 +571,12 @@ set(QT_CMAKE_EXPORT_NAMESPACE ${QT_CMAKE_EXPORT_NAMESPACE})")
|
|||||||
NAMESPACE ${QT_CMAKE_EXPORT_NAMESPACE}::
|
NAMESPACE ${QT_CMAKE_EXPORT_NAMESPACE}::
|
||||||
DESTINATION ${config_install_dir})
|
DESTINATION ${config_install_dir})
|
||||||
|
|
||||||
|
if(NOT arg_NO_ADDITIONAL_TARGET_INFO)
|
||||||
qt_internal_export_additional_targets_file(
|
qt_internal_export_additional_targets_file(
|
||||||
TARGETS ${exported_targets}
|
TARGETS ${exported_targets}
|
||||||
EXPORT_NAME_PREFIX ${INSTALL_CMAKE_NAMESPACE}${target}
|
EXPORT_NAME_PREFIX ${INSTALL_CMAKE_NAMESPACE}${target}
|
||||||
CONFIG_INSTALL_DIR "${config_install_dir}")
|
CONFIG_INSTALL_DIR "${config_install_dir}")
|
||||||
|
endif()
|
||||||
|
|
||||||
qt_internal_export_modern_cmake_config_targets_file(
|
qt_internal_export_modern_cmake_config_targets_file(
|
||||||
TARGETS ${exported_targets}
|
TARGETS ${exported_targets}
|
||||||
|
@ -17,6 +17,7 @@ qt_internal_add_module(EntryPoint
|
|||||||
NO_SYNC_QT
|
NO_SYNC_QT
|
||||||
NO_MODULE_HEADERS
|
NO_MODULE_HEADERS
|
||||||
NO_PRIVATE_MODULE
|
NO_PRIVATE_MODULE
|
||||||
|
NO_ADDITIONAL_TARGET_INFO
|
||||||
)
|
)
|
||||||
|
|
||||||
# We don't need any include paths or default module defines
|
# We don't need any include paths or default module defines
|
||||||
@ -101,6 +102,13 @@ QT.entrypoint_implementation.module_config = staticlib v2 internal_module
|
|||||||
set(export_name "${INSTALL_CMAKE_NAMESPACE}EntryPointTargets")
|
set(export_name "${INSTALL_CMAKE_NAMESPACE}EntryPointTargets")
|
||||||
qt_install(TARGETS EntryPointImplementation EXPORT ${export_name})
|
qt_install(TARGETS EntryPointImplementation EXPORT ${export_name})
|
||||||
qt_generate_prl_file(EntryPointImplementation "${INSTALL_LIBDIR}")
|
qt_generate_prl_file(EntryPointImplementation "${INSTALL_LIBDIR}")
|
||||||
|
|
||||||
|
set(export_name_prefix "${INSTALL_CMAKE_NAMESPACE}EntryPoint")
|
||||||
|
qt_path_join(config_install_dir ${QT_CONFIG_INSTALL_DIR} ${export_name_prefix})
|
||||||
|
qt_internal_export_additional_targets_file(
|
||||||
|
TARGETS EntryPoint EntryPointImplementation
|
||||||
|
EXPORT_NAME_PREFIX ${export_name_prefix}
|
||||||
|
CONFIG_INSTALL_DIR "${config_install_dir}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# special case end
|
# special case end
|
||||||
|
Loading…
Reference in New Issue
Block a user