From 4ec651c864792a87793f5c6cfb5a14ed0cafbbb7 Mon Sep 17 00:00:00 2001 From: memsharded Date: Fri, 4 Oct 2024 23:40:24 +0200 Subject: [PATCH] proposal for loading conan_cmakedeps_paths.cmake --- conan_provider.cmake | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/conan_provider.cmake b/conan_provider.cmake index 0d2be00..b06285c 100644 --- a/conan_provider.cmake +++ b/conan_provider.cmake @@ -488,7 +488,6 @@ function(conan_install) # TODO: this can be made more robust if Conan can provide this in the json output string(JSON conan_generators_folder GET "${conan_stdout}" graph nodes 0 generators_folder) cmake_path(CONVERT ${conan_generators_folder} TO_CMAKE_PATH_LIST conan_generators_folder) - message(STATUS "CMake-Conan: CONAN_GENERATORS_FOLDER=${conan_generators_folder}") set_property(GLOBAL PROPERTY CONAN_GENERATORS_FOLDER "${conan_generators_folder}") # reconfigure on conanfile changes @@ -594,6 +593,9 @@ macro(conan_provide_dependency method package_name) conan_install(${_host_profile_flags} ${_build_profile_flags} -s build_type=Release ${CONAN_INSTALL_ARGS} ${generator}) conan_install(${_host_profile_flags} ${_build_profile_flags} -s build_type=Debug ${CONAN_INSTALL_ARGS} ${generator}) endif() + get_property(_conan_generators_folder GLOBAL PROPERTY CONAN_GENERATORS_FOLDER) + message(STATUS "CMake-Conan: Loading conan_cmakedeps_paths.cmake file") + include(${_conan_generators_folder}/conan_cmakedeps_paths.cmake) unset(_host_profile_flags) unset(_build_profile_flags) unset(_multiconfig_generator) @@ -604,7 +606,6 @@ macro(conan_provide_dependency method package_name) endif() get_property(_conan_generators_folder GLOBAL PROPERTY CONAN_GENERATORS_FOLDER) - # Ensure that we consider Conan-provided packages ahead of any other, # irrespective of other settings that modify the search order or search paths # This follows the guidelines from the find_package documentation @@ -616,7 +617,7 @@ macro(conan_provide_dependency method package_name) set(_find_args_${package_name} "${ARGN}") list(REMOVE_ITEM _find_args_${package_name} "REQUIRED") if(NOT "MODULE" IN_LIST _find_args_${package_name}) - find_package(${package_name} ${_find_args_${package_name}} BYPASS_PROVIDER PATHS "${_conan_generators_folder}" NO_DEFAULT_PATH NO_CMAKE_FIND_ROOT_PATH) + find_package(${package_name} ${_find_args_${package_name}} BYPASS_PROVIDER) unset(_find_args_${package_name}) endif()