diff options
-rw-r--r-- | CMakeLists.txt | 29 | ||||
-rw-r--r-- | cmake/QtTopLevelHelpers.cmake | 42 |
2 files changed, 51 insertions, 20 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt index 547865a9..eb092c7d 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -49,20 +49,35 @@ qt_internal_sort_module_dependencies("${BUILD_SUBMODULES}" BUILD_SUBMODULES foreach(module IN LISTS BUILD_SUBMODULES) # Check for unmet dependencies if(NOT DEFINED BUILD_${module} OR BUILD_${module}) - message(NOTICE "Check dependencies of '${module}'") + message(NOTICE "Checking dependencies of '${module}'") + get_property(required_deps GLOBAL PROPERTY QT_REQUIRED_DEPS_FOR_${module}) foreach(dep IN LISTS "${qt_module_dependency_map_prefix}${module}") if (dep STREQUAL "qtbase") # Always available skip continue() endif() + + set(required FALSE) + if(dep IN_LIST required_deps) + set(required TRUE) + endif() + + set(error_reason "") if(NOT EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/${dep}/CMakeLists.txt") - message(FATAL_ERROR "Module '${module}' depends on '${dep}', but ${dep}'s \ - CMakeLists.txt couldn't be found.\nNote: Use '-skip ${module}' to exclude it \ - from build.\n") + set(error_reason "${dep}'s CMakeLists.txt couldn't be found") + elseif(DEFINED BUILD_${dep} AND NOT BUILD_${dep}) + set(error_reason "building '${dep}' was explicitly disabled") endif() - if(DEFINED BUILD_${dep} AND NOT BUILD_${dep}) - message(FATAL_ERROR "Module '${module}' depends on '${dep}', but '${dep}' \ - will not be built.\nNote: Use '-skip ${module}' to exclude it from build.\n") + + if(NOT error_reason STREQUAL "") + if(required) + message(FATAL_ERROR "Module '${module}' depends on '${dep}', " + "but ${error_reason}.\n" + "Note: Use '-skip ${module}' to exclude it from the build.") + else() + message(NOTICE "Skipping optional dependency '${dep}' of '${module}', " + "because ${error_reason}.") + endif() endif() endforeach() endif() diff --git a/cmake/QtTopLevelHelpers.cmake b/cmake/QtTopLevelHelpers.cmake index 6287d935..8643b850 100644 --- a/cmake/QtTopLevelHelpers.cmake +++ b/cmake/QtTopLevelHelpers.cmake @@ -17,24 +17,34 @@ endfunction() # Each entry will be in the format dependency/sha1 function(qt_internal_parse_dependencies depends_file out_dependencies) file(STRINGS "${depends_file}" lines) + set(eof_marker "---EOF---") + list(APPEND lines "${eof_marker}") + set(required_default TRUE) set(dependencies "") set(dependency "") + set(revision "") + set(required "${required_default}") foreach(line IN LISTS lines) - if(line STREQUAL "dependencies:") - set(found_dependencies 1) - elseif(found_dependencies) - if(line MATCHES "^ ref: (.*)$") - set(revision "${CMAKE_MATCH_1}") - list(APPEND dependencies ${dependency}/${revision}) - set(dependency "") - elseif (line MATCHES "^ (.*):$") - if(dependency) + if(line MATCHES "^ (.+):$" OR line STREQUAL "${eof_marker}") + # Found a repo entry or end of file. Add the last seen dependency. + if(NOT dependency STREQUAL "") + if(revision STREQUAL "") message(FATAL_ERROR "Format error in ${depends_file} - ${dependency} does not specify revision!") endif() + list(APPEND dependencies "${dependency}/${revision}/${required}") + endif() + # Remember the current dependency + if(NOT line STREQUAL "${eof_marker}") set(dependency "${CMAKE_MATCH_1}") + set(revision "") + set(required "${required_default}") # dependencies are specified with relative path to this module string(REPLACE "../" "" dependency ${dependency}) endif() + elseif(line MATCHES "^ ref: (.+)$") + set(revision "${CMAKE_MATCH_1}") + elseif(line MATCHES "^ required: (.+)$") + string(TOUPPER "${CMAKE_MATCH_1}" required) endif() endforeach() message(DEBUG "qt_internal_parse_dependencies for ${depends_file}: ${dependencies} ${revisions}") @@ -66,10 +76,16 @@ function(qt_internal_add_module_dependencies module ordered out_ordered out_has_ endif() set(modules_dependencies "") foreach(dependency IN LISTS dependencies) - string(FIND "${dependency}" "/" splitindex REVERSE) - string(SUBSTRING "${dependency}" ${splitindex} -1 revision) - string(SUBSTRING "${revision}" 1 -1 revision) - string(SUBSTRING "${dependency}" 0 ${splitindex} dependency) + if(dependency MATCHES "(.*)/([^/]+)/([^/]+)") + set(dependency "${CMAKE_MATCH_1}") + set(revision "${CMAKE_MATCH_2}") + set(required "${CMAKE_MATCH_3}") + if(required) + set_property(GLOBAL APPEND PROPERTY QT_REQUIRED_DEPS_FOR_${module} ${dependency}) + endif() + else() + message(FATAL_ERROR "Internal Error: wrong dependency format ${dependency}") + endif() list(APPEND modules_dependencies "${dependency}") list(FIND ordered "${dependency}" dindex) if (dindex EQUAL -1) |