summaryrefslogtreecommitdiffstats
path: root/cmake/QtBuildInternals
diff options
context:
space:
mode:
authorVolker Hilsheimer <volker.hilsheimer@qt.io>2020-11-18 00:36:44 +0100
committerVolker Hilsheimer <volker.hilsheimer@qt.io>2020-11-20 15:52:22 +0000
commit08f46bb40075778e89ba9aed3cef53d990852022 (patch)
treef4323849fb4609f97cf42691875873387996eaf1 /cmake/QtBuildInternals
parentaaed8f283ce242d04161093ef7a59274dd785587 (diff)
Toplevel builds: Add utility toplevel targets for each module
Add a target for each level-1 subdirectory in a module. Ninja already generates phony targets such as "qtbase/src/all", but those are not available in e.g. IDE integrations of CMake. With this addition, targets like qtbase, qtbase_src, and qtbase_tests are available in IDEs. Pick-to: 6.0 6.0.0 Change-Id: If1c3369e9413b3ce127e68c443d4d22949708d5e Reviewed-by: Alexandru Croitor <alexandru.croitor@qt.io>
Diffstat (limited to 'cmake/QtBuildInternals')
-rw-r--r--cmake/QtBuildInternals/QtBuildInternalsConfig.cmake47
1 files changed, 47 insertions, 0 deletions
diff --git a/cmake/QtBuildInternals/QtBuildInternalsConfig.cmake b/cmake/QtBuildInternals/QtBuildInternalsConfig.cmake
index 5e49a99f5d..f7f9f3ccbf 100644
--- a/cmake/QtBuildInternals/QtBuildInternalsConfig.cmake
+++ b/cmake/QtBuildInternals/QtBuildInternalsConfig.cmake
@@ -184,6 +184,50 @@ macro(qt_build_internals_set_up_private_api)
qt_check_if_tools_will_be_built()
endmacro()
+# find all targets defined in $subdir by recursing through all added subdirectories
+# populates $qt_repo_targets with a ;-list of non-UTILITY targets
+macro(qt_build_internals_get_repo_targets subdir)
+ get_directory_property(_directories DIRECTORY "${subdir}" SUBDIRECTORIES)
+ if (_directories)
+ foreach(_directory IN LISTS _directories)
+ get_directory_property(_targets DIRECTORY "${_directory}" BUILDSYSTEM_TARGETS)
+ if (_targets)
+ foreach(_target IN LISTS _targets)
+ get_target_property(_type ${_target} TYPE)
+ if (NOT (${_type} STREQUAL "UTILITY" OR ${_type} STREQUAL "INTERFACE"))
+ list(APPEND qt_repo_targets "${_target}")
+ endif()
+ endforeach()
+ endif()
+ qt_build_internals_get_repo_targets("${_directory}")
+ endforeach()
+ endif()
+endmacro()
+
+# add toplevel targets for each subdirectory, e.g. qtbase_src
+function(qt_build_internals_add_toplevel_targets)
+ set(qt_repo_target_all "")
+ get_directory_property(directories DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" SUBDIRECTORIES)
+ foreach(directory IN LISTS directories)
+ set(qt_repo_targets "")
+ get_filename_component(qt_repo_target_basename ${directory} NAME)
+ qt_build_internals_get_repo_targets("${directory}")
+ if (qt_repo_targets)
+ set(qt_repo_target_name "${qt_repo_targets_name}_${qt_repo_target_basename}")
+ message(DEBUG "${qt_repo_target_name} depends on ${qt_repo_targets}")
+ add_custom_target("${qt_repo_target_name}"
+ DEPENDS ${qt_repo_targets}
+ COMMENT "Building everything in ${qt_repo_targets_name}/${qt_repo_target_basename}")
+ list(APPEND qt_repo_target_all "${qt_repo_target_name}")
+ endif()
+ endforeach()
+ if (qt_repo_target_all)
+ add_custom_target("${qt_repo_targets_name}"
+ DEPENDS ${qt_repo_target_all}
+ COMMENT "Building everything in ${qt_repo_targets_name}")
+ endif()
+endfunction()
+
macro(qt_enable_cmake_languages)
include(CheckLanguage)
set(__qt_required_language_list C CXX)
@@ -254,6 +298,7 @@ macro(qt_build_repo_begin)
string(TOLOWER ${PROJECT_NAME} project_name_lower)
+ set(qt_repo_targets_name ${project_name_lower})
set(qt_docs_target_name docs_${project_name_lower})
set(qt_docs_prepare_target_name prepare_docs_${project_name_lower})
set(qt_docs_generate_target_name generate_docs_${project_name_lower})
@@ -316,6 +361,8 @@ macro(qt_build_repo_end)
if(NOT QT_SUPERBUILD)
qt_print_build_instructions()
+ else()
+ qt_build_internals_add_toplevel_targets()
endif()
endmacro()