summaryrefslogtreecommitdiffstats
path: root/cmake/QtTargetHelpers.cmake
diff options
context:
space:
mode:
authorAlexey Edelev <alexey.edelev@qt.io>2021-08-24 13:30:51 +0200
committerQt Cherry-pick Bot <cherrypick_bot@qt-project.org>2021-08-24 19:37:47 +0000
commit1ea4dfe2f8d173799ddffdac65546cbe4bd83cc2 (patch)
tree9412bb9b16cc3bb749ecee04476a6e408a8e4553 /cmake/QtTargetHelpers.cmake
parent6dacd901deb042ea8cbbaaf3ee3c34097e56e54e (diff)
Add missing PRIVATE_MODULE_INTERFACEs to INTERNAL_MODULEs
To detect the internal module ouside the qt_internal_add_module function need to mark it with the property. This adds _qt_is_internal_module property to the Qt internal modules. Since PRIVATE_MODULE_INTERFACE only was applicable to pure Private modules, INTERNAL_MODULEs is missing those dependencies if they were specified. Add extra condition to qt_internal_extend_target to link PRIVATE_MODULE_INTERFACE libraries to internal modules as well. Change-Id: I9c32fa5bad3aff365f5d7663349e5365d5f1d72d Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io> (cherry picked from commit abb19da5727c63783c64caefa11562a9086b4707) Reviewed-by: Qt Cherry-pick Bot <cherrypick_bot@qt-project.org>
Diffstat (limited to 'cmake/QtTargetHelpers.cmake')
-rw-r--r--cmake/QtTargetHelpers.cmake6
1 files changed, 6 insertions, 0 deletions
diff --git a/cmake/QtTargetHelpers.cmake b/cmake/QtTargetHelpers.cmake
index f497d55924..cc7481aec1 100644
--- a/cmake/QtTargetHelpers.cmake
+++ b/cmake/QtTargetHelpers.cmake
@@ -101,6 +101,12 @@ function(qt_internal_extend_target target)
endforeach()
set(target_private "${target}Private")
+ get_target_property(is_internal_module ${target} _qt_is_internal_module)
+ # Internal modules don't have Private targets but we still need to
+ # propagate their private dependencies.
+ if(is_internal_module)
+ set(target_private "${target}")
+ endif()
if(TARGET "${target_private}")
target_link_libraries("${target_private}"
INTERFACE ${arg_PRIVATE_MODULE_INTERFACE})