From: Angus Gratton Date: Tue, 19 Mar 2019 23:42:29 +0000 (+1100) Subject: cmake: Set COMPONENT_PATH during early expansion of dependencies X-Git-Tag: v4.0-beta1~471^2 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=abdc9f50d84aee6ca84407d86e410b6ce13809ad;p=esp-idf cmake: Set COMPONENT_PATH during early expansion of dependencies Works around bug where components/soc/CMakeLists.txt was testing "EXISTS ${COMPONENT_PATH}/${SOC_NAME}" and this test could pass during early expansion if COMPONENT_PATH was empty and a directory /esp32 exists on Windows. Closes https://github.com/espressif/esp-idf/issues/3195 --- diff --git a/tools/cmake/scripts/expand_requirements.cmake b/tools/cmake/scripts/expand_requirements.cmake index 5886e63201..26234853dd 100644 --- a/tools/cmake/scripts/expand_requirements.cmake +++ b/tools/cmake/scripts/expand_requirements.cmake @@ -92,9 +92,9 @@ function(expand_component_requirements component) endif() set_property(GLOBAL APPEND PROPERTY SEEN_COMPONENTS ${component}) - find_component_path("${component}" "${ALL_COMPONENTS}" "${ALL_COMPONENT_PATHS}" component_path) - debug("Expanding dependencies of ${component} @ ${component_path}") - if(NOT component_path) + find_component_path("${component}" "${ALL_COMPONENTS}" "${ALL_COMPONENT_PATHS}" COMPONENT_PATH) + debug("Expanding dependencies of ${component} @ ${COMPONENT_PATH}") + if(NOT COMPONENT_PATH) set_property(GLOBAL APPEND PROPERTY COMPONENTS_NOT_FOUND ${component}) return() endif() @@ -104,7 +104,7 @@ function(expand_component_requirements component) unset(COMPONENT_REQUIRES) unset(COMPONENT_PRIV_REQUIRES) set(COMPONENT ${component}) - include(${component_path}/CMakeLists.txt) + include(${COMPONENT_PATH}/CMakeLists.txt) get_property(requires GLOBAL PROPERTY "${component}_REQUIRES") get_property(requires_priv GLOBAL PROPERTY "${component}_PRIV_REQUIRES") @@ -124,7 +124,7 @@ function(expand_component_requirements component) endif() # Now append this component to the full list (after its dependencies) - set_property(GLOBAL APPEND PROPERTY BUILD_COMPONENT_PATHS ${component_path}) + set_property(GLOBAL APPEND PROPERTY BUILD_COMPONENT_PATHS ${COMPONENT_PATH}) set_property(GLOBAL APPEND PROPERTY BUILD_COMPONENTS ${component}) endfunction()