forked from qt-creator/qt-creator
CMakePM: Update conan.cmake to version 0.18.1
This is the latest released version at this moment in time. It has support for Visual C++ 2022 detection. Fixes: QTCREATORBUG-27814 Change-Id: Ib4fa288ced1271e1964b2ae0f7d6a6c5e403cf53 Reviewed-by: <github-actions-qt-creator@cristianadam.eu> Reviewed-by: Eike Ziller <eike.ziller@qt.io>
This commit is contained in:
433
src/share/3rdparty/package-manager/conan.cmake
vendored
433
src/share/3rdparty/package-manager/conan.cmake
vendored
@@ -33,7 +33,7 @@
|
|||||||
# but it is only necessary on the end-user side. It is not necessary to create conan
|
# but it is only necessary on the end-user side. It is not necessary to create conan
|
||||||
# packages, in fact it shouldn't be use for that. Check the project documentation.
|
# packages, in fact it shouldn't be use for that. Check the project documentation.
|
||||||
|
|
||||||
# version: 0.16.0-dev
|
# version: 0.18.1
|
||||||
|
|
||||||
include(CMakeParseArguments)
|
include(CMakeParseArguments)
|
||||||
|
|
||||||
@@ -55,23 +55,14 @@ function(_get_msvc_ide_version result)
|
|||||||
set(${result} 15 PARENT_SCOPE)
|
set(${result} 15 PARENT_SCOPE)
|
||||||
elseif(NOT MSVC_VERSION VERSION_LESS 1920 AND MSVC_VERSION VERSION_LESS 1930)
|
elseif(NOT MSVC_VERSION VERSION_LESS 1920 AND MSVC_VERSION VERSION_LESS 1930)
|
||||||
set(${result} 16 PARENT_SCOPE)
|
set(${result} 16 PARENT_SCOPE)
|
||||||
|
elseif(NOT MSVC_VERSION VERSION_LESS 1930 AND MSVC_VERSION VERSION_LESS 1940)
|
||||||
|
set(${result} 17 PARENT_SCOPE)
|
||||||
else()
|
else()
|
||||||
message(FATAL_ERROR "Conan: Unknown MSVC compiler version [${MSVC_VERSION}]")
|
message(FATAL_ERROR "Conan: Unknown MSVC compiler version [${MSVC_VERSION}]")
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(conan_cmake_settings result)
|
macro(_conan_detect_build_type)
|
||||||
#message(STATUS "COMPILER " ${CMAKE_CXX_COMPILER})
|
|
||||||
#message(STATUS "COMPILER " ${CMAKE_CXX_COMPILER_ID})
|
|
||||||
#message(STATUS "VERSION " ${CMAKE_CXX_COMPILER_VERSION})
|
|
||||||
#message(STATUS "FLAGS " ${CMAKE_LANG_FLAGS})
|
|
||||||
#message(STATUS "LIB ARCH " ${CMAKE_CXX_LIBRARY_ARCHITECTURE})
|
|
||||||
#message(STATUS "BUILD TYPE " ${CMAKE_BUILD_TYPE})
|
|
||||||
#message(STATUS "GENERATOR " ${CMAKE_GENERATOR})
|
|
||||||
#message(STATUS "GENERATOR WIN64 " ${CMAKE_CL_64})
|
|
||||||
|
|
||||||
message(STATUS "Conan: Automatic detection of conan settings from cmake")
|
|
||||||
|
|
||||||
conan_parse_arguments(${ARGV})
|
conan_parse_arguments(${ARGV})
|
||||||
|
|
||||||
if(ARGUMENTS_BUILD_TYPE)
|
if(ARGUMENTS_BUILD_TYPE)
|
||||||
@@ -92,10 +83,9 @@ function(conan_cmake_settings result)
|
|||||||
elseif(_CONAN_SETTING_BUILD_TYPE_UPPER STREQUAL "MINSIZEREL")
|
elseif(_CONAN_SETTING_BUILD_TYPE_UPPER STREQUAL "MINSIZEREL")
|
||||||
set(_CONAN_SETTING_BUILD_TYPE "MinSizeRel")
|
set(_CONAN_SETTING_BUILD_TYPE "MinSizeRel")
|
||||||
endif()
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
if(ARGUMENTS_ARCH)
|
macro(_conan_check_system_name)
|
||||||
set(_CONAN_SETTING_ARCH ${ARGUMENTS_ARCH})
|
|
||||||
endif()
|
|
||||||
#handle -s os setting
|
#handle -s os setting
|
||||||
if(CMAKE_SYSTEM_NAME AND NOT CMAKE_SYSTEM_NAME STREQUAL "Generic")
|
if(CMAKE_SYSTEM_NAME AND NOT CMAKE_SYSTEM_NAME STREQUAL "Generic")
|
||||||
#use default conan os setting if CMAKE_SYSTEM_NAME is not defined
|
#use default conan os setting if CMAKE_SYSTEM_NAME is not defined
|
||||||
@@ -115,7 +105,9 @@ function(conan_cmake_settings result)
|
|||||||
message(FATAL_ERROR "cmake system ${CONAN_SYSTEM_NAME} is not supported by conan. Use one of ${CONAN_SUPPORTED_PLATFORMS}")
|
message(FATAL_ERROR "cmake system ${CONAN_SYSTEM_NAME} is not supported by conan. Use one of ${CONAN_SUPPORTED_PLATFORMS}")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(_conan_check_language)
|
||||||
get_property(_languages GLOBAL PROPERTY ENABLED_LANGUAGES)
|
get_property(_languages GLOBAL PROPERTY ENABLED_LANGUAGES)
|
||||||
if (";${_languages};" MATCHES ";CXX;")
|
if (";${_languages};" MATCHES ";CXX;")
|
||||||
set(LANGUAGE CXX)
|
set(LANGUAGE CXX)
|
||||||
@@ -126,6 +118,19 @@ function(conan_cmake_settings result)
|
|||||||
else ()
|
else ()
|
||||||
message(FATAL_ERROR "Conan: Neither C or C++ was detected as a language for the project. Unabled to detect compiler version.")
|
message(FATAL_ERROR "Conan: Neither C or C++ was detected as a language for the project. Unabled to detect compiler version.")
|
||||||
endif()
|
endif()
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
macro(_conan_detect_compiler)
|
||||||
|
|
||||||
|
conan_parse_arguments(${ARGV})
|
||||||
|
|
||||||
|
if(ARGUMENTS_ARCH)
|
||||||
|
set(_CONAN_SETTING_ARCH ${ARGUMENTS_ARCH})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(USING_CXX)
|
||||||
|
set(_CONAN_SETTING_COMPILER_CPPSTD ${CMAKE_CXX_STANDARD})
|
||||||
|
endif()
|
||||||
|
|
||||||
if (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL GNU)
|
if (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL GNU)
|
||||||
# using GCC
|
# using GCC
|
||||||
@@ -143,6 +148,17 @@ function(conan_cmake_settings result)
|
|||||||
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
||||||
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
||||||
endif ()
|
endif ()
|
||||||
|
elseif (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL Intel)
|
||||||
|
string(REPLACE "." ";" VERSION_LIST ${CMAKE_${LANGUAGE}_COMPILER_VERSION})
|
||||||
|
list(GET VERSION_LIST 0 MAJOR)
|
||||||
|
list(GET VERSION_LIST 1 MINOR)
|
||||||
|
set(COMPILER_VERSION ${MAJOR}.${MINOR})
|
||||||
|
set(_CONAN_SETTING_COMPILER intel)
|
||||||
|
set(_CONAN_SETTING_COMPILER_VERSION ${COMPILER_VERSION})
|
||||||
|
if (USING_CXX)
|
||||||
|
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
||||||
|
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
||||||
|
endif ()
|
||||||
elseif (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL AppleClang)
|
elseif (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL AppleClang)
|
||||||
# using AppleClang
|
# using AppleClang
|
||||||
string(REPLACE "." ";" VERSION_LIST ${CMAKE_${LANGUAGE}_COMPILER_VERSION})
|
string(REPLACE "." ";" VERSION_LIST ${CMAKE_${LANGUAGE}_COMPILER_VERSION})
|
||||||
@@ -154,7 +170,10 @@ function(conan_cmake_settings result)
|
|||||||
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
||||||
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
||||||
endif ()
|
endif ()
|
||||||
elseif (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL Clang)
|
elseif (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL Clang
|
||||||
|
AND NOT "${CMAKE_${LANGUAGE}_COMPILER_FRONTEND_VARIANT}" STREQUAL "MSVC"
|
||||||
|
AND NOT "${CMAKE_${LANGUAGE}_SIMULATE_ID}" STREQUAL "MSVC")
|
||||||
|
|
||||||
string(REPLACE "." ";" VERSION_LIST ${CMAKE_${LANGUAGE}_COMPILER_VERSION})
|
string(REPLACE "." ";" VERSION_LIST ${CMAKE_${LANGUAGE}_COMPILER_VERSION})
|
||||||
list(GET VERSION_LIST 0 MAJOR)
|
list(GET VERSION_LIST 0 MAJOR)
|
||||||
list(GET VERSION_LIST 1 MINOR)
|
list(GET VERSION_LIST 1 MINOR)
|
||||||
@@ -174,7 +193,11 @@ function(conan_cmake_settings result)
|
|||||||
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
conan_cmake_detect_unix_libcxx(_LIBCXX)
|
||||||
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
set(_CONAN_SETTING_COMPILER_LIBCXX ${_LIBCXX})
|
||||||
endif ()
|
endif ()
|
||||||
elseif(${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL MSVC)
|
elseif(${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL MSVC
|
||||||
|
OR (${CMAKE_${LANGUAGE}_COMPILER_ID} STREQUAL Clang
|
||||||
|
AND "${CMAKE_${LANGUAGE}_COMPILER_FRONTEND_VARIANT}" STREQUAL "MSVC"
|
||||||
|
AND "${CMAKE_${LANGUAGE}_SIMULATE_ID}" STREQUAL "MSVC"))
|
||||||
|
|
||||||
set(_VISUAL "Visual Studio")
|
set(_VISUAL "Visual Studio")
|
||||||
_get_msvc_ide_version(_VISUAL_VERSION)
|
_get_msvc_ide_version(_VISUAL_VERSION)
|
||||||
if("${_VISUAL_VERSION}" STREQUAL "")
|
if("${_VISUAL_VERSION}" STREQUAL "")
|
||||||
@@ -197,7 +220,7 @@ function(conan_cmake_settings result)
|
|||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
conan_cmake_detect_vs_runtime(_vs_runtime)
|
conan_cmake_detect_vs_runtime(_vs_runtime ${ARGV})
|
||||||
message(STATUS "Conan: Detected VS runtime: ${_vs_runtime}")
|
message(STATUS "Conan: Detected VS runtime: ${_vs_runtime}")
|
||||||
set(_CONAN_SETTING_COMPILER_RUNTIME ${_vs_runtime})
|
set(_CONAN_SETTING_COMPILER_RUNTIME ${_vs_runtime})
|
||||||
|
|
||||||
@@ -210,6 +233,30 @@ function(conan_cmake_settings result)
|
|||||||
message(FATAL_ERROR "Conan: compiler setup not recognized")
|
message(FATAL_ERROR "Conan: compiler setup not recognized")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
function(conan_cmake_settings result)
|
||||||
|
#message(STATUS "COMPILER " ${CMAKE_CXX_COMPILER})
|
||||||
|
#message(STATUS "COMPILER " ${CMAKE_CXX_COMPILER_ID})
|
||||||
|
#message(STATUS "VERSION " ${CMAKE_CXX_COMPILER_VERSION})
|
||||||
|
#message(STATUS "FLAGS " ${CMAKE_LANG_FLAGS})
|
||||||
|
#message(STATUS "LIB ARCH " ${CMAKE_CXX_LIBRARY_ARCHITECTURE})
|
||||||
|
#message(STATUS "BUILD TYPE " ${CMAKE_BUILD_TYPE})
|
||||||
|
#message(STATUS "GENERATOR " ${CMAKE_GENERATOR})
|
||||||
|
#message(STATUS "GENERATOR WIN64 " ${CMAKE_CL_64})
|
||||||
|
|
||||||
|
message(STATUS "Conan: Automatic detection of conan settings from cmake")
|
||||||
|
|
||||||
|
conan_parse_arguments(${ARGV})
|
||||||
|
|
||||||
|
_conan_detect_build_type(${ARGV})
|
||||||
|
|
||||||
|
_conan_check_system_name()
|
||||||
|
|
||||||
|
_conan_check_language()
|
||||||
|
|
||||||
|
_conan_detect_compiler(${ARGV})
|
||||||
|
|
||||||
# If profile is defined it is used
|
# If profile is defined it is used
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Debug" AND ARGUMENTS_DEBUG_PROFILE)
|
if(CMAKE_BUILD_TYPE STREQUAL "Debug" AND ARGUMENTS_DEBUG_PROFILE)
|
||||||
set(_APPLIED_PROFILES ${ARGUMENTS_DEBUG_PROFILE})
|
set(_APPLIED_PROFILES ${ARGUMENTS_DEBUG_PROFILE})
|
||||||
@@ -346,7 +393,19 @@ function(conan_cmake_detect_unix_libcxx result)
|
|||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(conan_cmake_detect_vs_runtime result)
|
function(conan_cmake_detect_vs_runtime result)
|
||||||
string(TOUPPER "${CMAKE_BUILD_TYPE}" build_type)
|
|
||||||
|
conan_parse_arguments(${ARGV})
|
||||||
|
if(ARGUMENTS_BUILD_TYPE)
|
||||||
|
set(build_type "${ARGUMENTS_BUILD_TYPE}")
|
||||||
|
elseif(CMAKE_BUILD_TYPE)
|
||||||
|
set(build_type "${CMAKE_BUILD_TYPE}")
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "Please specify in command line CMAKE_BUILD_TYPE (-DCMAKE_BUILD_TYPE=Release)")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(build_type)
|
||||||
|
string(TOUPPER "${build_type}" build_type)
|
||||||
|
endif()
|
||||||
set(variables CMAKE_CXX_FLAGS_${build_type} CMAKE_C_FLAGS_${build_type} CMAKE_CXX_FLAGS CMAKE_C_FLAGS)
|
set(variables CMAKE_CXX_FLAGS_${build_type} CMAKE_C_FLAGS_${build_type} CMAKE_CXX_FLAGS CMAKE_C_FLAGS)
|
||||||
foreach(variable ${variables})
|
foreach(variable ${variables})
|
||||||
if(NOT "${${variable}}" STREQUAL "")
|
if(NOT "${${variable}}" STREQUAL "")
|
||||||
@@ -367,17 +426,39 @@ function(conan_cmake_detect_vs_runtime result)
|
|||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
function(_collect_settings result)
|
||||||
|
set(ARGUMENTS_PROFILE_AUTO arch build_type compiler compiler.version
|
||||||
|
compiler.runtime compiler.libcxx compiler.toolset
|
||||||
|
compiler.cppstd)
|
||||||
|
foreach(ARG ${ARGUMENTS_PROFILE_AUTO})
|
||||||
|
string(TOUPPER ${ARG} _arg_name)
|
||||||
|
string(REPLACE "." "_" _arg_name ${_arg_name})
|
||||||
|
if(_CONAN_SETTING_${_arg_name})
|
||||||
|
set(detected_setings ${detected_setings} ${ARG}=${_CONAN_SETTING_${_arg_name}})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
set(${result} ${detected_setings} PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(conan_cmake_autodetect detected_settings)
|
||||||
|
_conan_detect_build_type(${ARGV})
|
||||||
|
_conan_check_system_name()
|
||||||
|
_conan_check_language()
|
||||||
|
_conan_detect_compiler(${ARGV})
|
||||||
|
_collect_settings(collected_settings)
|
||||||
|
set(${detected_settings} ${collected_settings} PARENT_SCOPE)
|
||||||
|
endfunction()
|
||||||
|
|
||||||
macro(conan_parse_arguments)
|
macro(conan_parse_arguments)
|
||||||
set(options BASIC_SETUP CMAKE_TARGETS UPDATE KEEP_RPATHS NO_LOAD NO_OUTPUT_DIRS OUTPUT_QUIET NO_IMPORTS SKIP_STD)
|
set(options BASIC_SETUP CMAKE_TARGETS UPDATE KEEP_RPATHS NO_LOAD NO_OUTPUT_DIRS OUTPUT_QUIET NO_IMPORTS SKIP_STD)
|
||||||
set(oneValueArgs CONANFILE ARCH BUILD_TYPE INSTALL_FOLDER CONAN_COMMAND)
|
set(oneValueArgs CONANFILE ARCH BUILD_TYPE INSTALL_FOLDER OUTPUT_FOLDER CONAN_COMMAND)
|
||||||
set(multiValueArgs DEBUG_PROFILE RELEASE_PROFILE RELWITHDEBINFO_PROFILE MINSIZEREL_PROFILE
|
set(multiValueArgs DEBUG_PROFILE RELEASE_PROFILE RELWITHDEBINFO_PROFILE MINSIZEREL_PROFILE
|
||||||
PROFILE REQUIRES OPTIONS IMPORTS SETTINGS BUILD ENV GENERATORS PROFILE_AUTO
|
PROFILE REQUIRES OPTIONS IMPORTS SETTINGS BUILD ENV GENERATORS PROFILE_AUTO
|
||||||
INSTALL_ARGS CONFIGURATION_TYPES PROFILE_BUILD)
|
INSTALL_ARGS CONFIGURATION_TYPES PROFILE_BUILD BUILD_REQUIRES)
|
||||||
cmake_parse_arguments(ARGUMENTS "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
cmake_parse_arguments(ARGUMENTS "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
function(conan_cmake_install)
|
function(old_conan_cmake_install)
|
||||||
# Calls "conan install"
|
# Calls "conan install"
|
||||||
# Argument BUILD is equivalant to --build={missing, PkgName,...} or
|
# Argument BUILD is equivalant to --build={missing, PkgName,...} or
|
||||||
# --build when argument is 'BUILD all' (which builds all packages from source)
|
# --build when argument is 'BUILD all' (which builds all packages from source)
|
||||||
@@ -428,6 +509,10 @@ function(conan_cmake_install)
|
|||||||
if(ARGUMENTS_INSTALL_FOLDER)
|
if(ARGUMENTS_INSTALL_FOLDER)
|
||||||
set(CONAN_INSTALL_FOLDER -if=${ARGUMENTS_INSTALL_FOLDER})
|
set(CONAN_INSTALL_FOLDER -if=${ARGUMENTS_INSTALL_FOLDER})
|
||||||
endif()
|
endif()
|
||||||
|
set(CONAN_OUTPUT_FOLDER "")
|
||||||
|
if(ARGUMENTS_OUTPUT_FOLDER)
|
||||||
|
set(CONAN_OUTPUT_FOLDER -of=${ARGUMENTS_OUTPUT_FOLDER})
|
||||||
|
endif()
|
||||||
foreach(ARG ${ARGUMENTS_GENERATORS})
|
foreach(ARG ${ARGUMENTS_GENERATORS})
|
||||||
set(CONAN_GENERATORS ${CONAN_GENERATORS} -g=${ARG})
|
set(CONAN_GENERATORS ${CONAN_GENERATORS} -g=${ARG})
|
||||||
endforeach()
|
endforeach()
|
||||||
@@ -457,6 +542,220 @@ function(conan_cmake_install)
|
|||||||
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
function(conan_cmake_install)
|
||||||
|
if(DEFINED CONAN_COMMAND)
|
||||||
|
set(CONAN_CMD ${CONAN_COMMAND})
|
||||||
|
else()
|
||||||
|
conan_check(REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(installOptions UPDATE NO_IMPORTS OUTPUT_QUIET ERROR_QUIET)
|
||||||
|
set(installOneValueArgs PATH_OR_REFERENCE REFERENCE REMOTE LOCKFILE LOCKFILE_OUT LOCKFILE_NODE_ID INSTALL_FOLDER OUTPUT_FOLDER)
|
||||||
|
set(installMultiValueArgs GENERATOR BUILD ENV ENV_HOST ENV_BUILD OPTIONS_HOST OPTIONS OPTIONS_BUILD PROFILE
|
||||||
|
PROFILE_HOST PROFILE_BUILD SETTINGS SETTINGS_HOST SETTINGS_BUILD)
|
||||||
|
cmake_parse_arguments(ARGS "${installOptions}" "${installOneValueArgs}" "${installMultiValueArgs}" ${ARGN})
|
||||||
|
foreach(arg ${installOptions})
|
||||||
|
if(ARGS_${arg})
|
||||||
|
set(${arg} ${${arg}} ${ARGS_${arg}})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
foreach(arg ${installOneValueArgs})
|
||||||
|
if(DEFINED ARGS_${arg})
|
||||||
|
if("${arg}" STREQUAL "REMOTE")
|
||||||
|
set(flag "--remote")
|
||||||
|
elseif("${arg}" STREQUAL "LOCKFILE")
|
||||||
|
set(flag "--lockfile")
|
||||||
|
elseif("${arg}" STREQUAL "LOCKFILE_OUT")
|
||||||
|
set(flag "--lockfile-out")
|
||||||
|
elseif("${arg}" STREQUAL "LOCKFILE_NODE_ID")
|
||||||
|
set(flag "--lockfile-node-id")
|
||||||
|
elseif("${arg}" STREQUAL "INSTALL_FOLDER")
|
||||||
|
set(flag "--install-folder")
|
||||||
|
elseif("${arg}" STREQUAL "OUTPUT_FOLDER")
|
||||||
|
set(flag "--output-folder")
|
||||||
|
endif()
|
||||||
|
set(${arg} ${${arg}} ${flag} ${ARGS_${arg}})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
foreach(arg ${installMultiValueArgs})
|
||||||
|
if(DEFINED ARGS_${arg})
|
||||||
|
if("${arg}" STREQUAL "GENERATOR")
|
||||||
|
set(flag "--generator")
|
||||||
|
elseif("${arg}" STREQUAL "BUILD")
|
||||||
|
set(flag "--build")
|
||||||
|
elseif("${arg}" STREQUAL "ENV")
|
||||||
|
set(flag "--env")
|
||||||
|
elseif("${arg}" STREQUAL "ENV_HOST")
|
||||||
|
set(flag "--env:host")
|
||||||
|
elseif("${arg}" STREQUAL "ENV_BUILD")
|
||||||
|
set(flag "--env:build")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS")
|
||||||
|
set(flag "--options")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS_HOST")
|
||||||
|
set(flag "--options:host")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS_BUILD")
|
||||||
|
set(flag "--options:build")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE")
|
||||||
|
set(flag "--profile")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE_HOST")
|
||||||
|
set(flag "--profile:host")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE_BUILD")
|
||||||
|
set(flag "--profile:build")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS")
|
||||||
|
set(flag "--settings")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS_HOST")
|
||||||
|
set(flag "--settings:host")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS_BUILD")
|
||||||
|
set(flag "--settings:build")
|
||||||
|
endif()
|
||||||
|
list(LENGTH ARGS_${arg} numargs)
|
||||||
|
foreach(item ${ARGS_${arg}})
|
||||||
|
if(${item} STREQUAL "all" AND ${arg} STREQUAL "BUILD")
|
||||||
|
set(${arg} "--build")
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
set(${arg} ${${arg}} ${flag} ${item})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
if(DEFINED UPDATE)
|
||||||
|
set(UPDATE --update)
|
||||||
|
endif()
|
||||||
|
if(DEFINED NO_IMPORTS)
|
||||||
|
set(NO_IMPORTS --no-imports)
|
||||||
|
endif()
|
||||||
|
set(install_args install ${PATH_OR_REFERENCE} ${REFERENCE} ${UPDATE} ${NO_IMPORTS} ${REMOTE} ${LOCKFILE} ${LOCKFILE_OUT} ${LOCKFILE_NODE_ID} ${INSTALL_FOLDER} ${OUTPUT_FOLDER}
|
||||||
|
${GENERATOR} ${BUILD} ${ENV} ${ENV_HOST} ${ENV_BUILD} ${OPTIONS} ${OPTIONS_HOST} ${OPTIONS_BUILD}
|
||||||
|
${PROFILE} ${PROFILE_HOST} ${PROFILE_BUILD} ${SETTINGS} ${SETTINGS_HOST} ${SETTINGS_BUILD})
|
||||||
|
|
||||||
|
string(REPLACE ";" " " _install_args "${install_args}")
|
||||||
|
message(STATUS "Conan executing: ${CONAN_CMD} ${_install_args}")
|
||||||
|
|
||||||
|
if(ARGS_OUTPUT_QUIET)
|
||||||
|
set(OUTPUT_OPT OUTPUT_QUIET)
|
||||||
|
endif()
|
||||||
|
if(ARGS_ERROR_QUIET)
|
||||||
|
set(ERROR_OPT ERROR_QUIET)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
execute_process(COMMAND ${CONAN_CMD} ${install_args}
|
||||||
|
RESULT_VARIABLE return_code
|
||||||
|
${OUTPUT_OPT}
|
||||||
|
${ERROR_OPT}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
|
if(NOT "${return_code}" STREQUAL "0")
|
||||||
|
if (ARGS_ERROR_QUIET)
|
||||||
|
message(WARNING "Conan install failed='${return_code}'")
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "Conan install failed='${return_code}'")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
endfunction()
|
||||||
|
|
||||||
|
function(conan_cmake_lock_create)
|
||||||
|
if(DEFINED CONAN_COMMAND)
|
||||||
|
set(CONAN_CMD ${CONAN_COMMAND})
|
||||||
|
else()
|
||||||
|
conan_check(REQUIRED)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(lockCreateOptions UPDATE BASE OUTPUT_QUIET ERROR_QUIET)
|
||||||
|
set(lockCreateOneValueArgs PATH REFERENCE REMOTE LOCKFILE LOCKFILE_OUT)
|
||||||
|
set(lockCreateMultiValueArgs BUILD ENV ENV_HOST ENV_BUILD OPTIONS_HOST OPTIONS OPTIONS_BUILD PROFILE
|
||||||
|
PROFILE_HOST PROFILE_BUILD SETTINGS SETTINGS_HOST SETTINGS_BUILD)
|
||||||
|
cmake_parse_arguments(ARGS "${lockCreateOptions}" "${lockCreateOneValueArgs}" "${lockCreateMultiValueArgs}" ${ARGN})
|
||||||
|
foreach(arg ${lockCreateOptions})
|
||||||
|
if(ARGS_${arg})
|
||||||
|
set(${arg} ${${arg}} ${ARGS_${arg}})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
foreach(arg ${lockCreateOneValueArgs})
|
||||||
|
if(DEFINED ARGS_${arg})
|
||||||
|
if("${arg}" STREQUAL "REMOTE")
|
||||||
|
set(flag "--remote")
|
||||||
|
elseif("${arg}" STREQUAL "LOCKFILE")
|
||||||
|
set(flag "--lockfile")
|
||||||
|
elseif("${arg}" STREQUAL "LOCKFILE_OUT")
|
||||||
|
set(flag "--lockfile-out")
|
||||||
|
endif()
|
||||||
|
set(${arg} ${${arg}} ${flag} ${ARGS_${arg}})
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
foreach(arg ${lockCreateMultiValueArgs})
|
||||||
|
if(DEFINED ARGS_${arg})
|
||||||
|
if("${arg}" STREQUAL "BUILD")
|
||||||
|
set(flag "--build")
|
||||||
|
elseif("${arg}" STREQUAL "ENV")
|
||||||
|
set(flag "--env")
|
||||||
|
elseif("${arg}" STREQUAL "ENV_HOST")
|
||||||
|
set(flag "--env:host")
|
||||||
|
elseif("${arg}" STREQUAL "ENV_BUILD")
|
||||||
|
set(flag "--env:build")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS")
|
||||||
|
set(flag "--options")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS_HOST")
|
||||||
|
set(flag "--options:host")
|
||||||
|
elseif("${arg}" STREQUAL "OPTIONS_BUILD")
|
||||||
|
set(flag "--options:build")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE")
|
||||||
|
set(flag "--profile")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE_HOST")
|
||||||
|
set(flag "--profile:host")
|
||||||
|
elseif("${arg}" STREQUAL "PROFILE_BUILD")
|
||||||
|
set(flag "--profile:build")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS")
|
||||||
|
set(flag "--settings")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS_HOST")
|
||||||
|
set(flag "--settings:host")
|
||||||
|
elseif("${arg}" STREQUAL "SETTINGS_BUILD")
|
||||||
|
set(flag "--settings:build")
|
||||||
|
endif()
|
||||||
|
list(LENGTH ARGS_${arg} numargs)
|
||||||
|
foreach(item ${ARGS_${arg}})
|
||||||
|
if(${item} STREQUAL "all" AND ${arg} STREQUAL "BUILD")
|
||||||
|
set(${arg} "--build")
|
||||||
|
break()
|
||||||
|
endif()
|
||||||
|
set(${arg} ${${arg}} ${flag} ${item})
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
endforeach()
|
||||||
|
if(DEFINED UPDATE)
|
||||||
|
set(UPDATE --update)
|
||||||
|
endif()
|
||||||
|
if(DEFINED BASE)
|
||||||
|
set(BASE --base)
|
||||||
|
endif()
|
||||||
|
set(lock_create_Args lock create ${PATH} ${REFERENCE} ${UPDATE} ${BASE} ${REMOTE} ${LOCKFILE} ${LOCKFILE_OUT} ${LOCKFILE_NODE_ID} ${INSTALL_FOLDER}
|
||||||
|
${GENERATOR} ${BUILD} ${ENV} ${ENV_HOST} ${ENV_BUILD} ${OPTIONS} ${OPTIONS_HOST} ${OPTIONS_BUILD}
|
||||||
|
${PROFILE} ${PROFILE_HOST} ${PROFILE_BUILD} ${SETTINGS} ${SETTINGS_HOST} ${SETTINGS_BUILD})
|
||||||
|
|
||||||
|
string(REPLACE ";" " " _lock_create_Args "${lock_create_Args}")
|
||||||
|
message(STATUS "Conan executing: ${CONAN_CMD} ${_lock_create_Args}")
|
||||||
|
|
||||||
|
if(ARGS_OUTPUT_QUIET)
|
||||||
|
set(OUTPUT_OPT OUTPUT_QUIET)
|
||||||
|
endif()
|
||||||
|
if(ARGS_ERROR_QUIET)
|
||||||
|
set(ERROR_OPT ERROR_QUIET)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
execute_process(COMMAND ${CONAN_CMD} ${lock_create_Args}
|
||||||
|
RESULT_VARIABLE return_code
|
||||||
|
${OUTPUT_OPT}
|
||||||
|
${ERROR_OPT}
|
||||||
|
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
|
if(NOT "${return_code}" STREQUAL "0")
|
||||||
|
if (ARGS_ERROR_QUIET)
|
||||||
|
message(WARNING "Conan lock create failed='${return_code}'")
|
||||||
|
else()
|
||||||
|
message(FATAL_ERROR "Conan lock create failed='${return_code}'")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
endfunction()
|
||||||
|
|
||||||
function(conan_cmake_setup_conanfile)
|
function(conan_cmake_setup_conanfile)
|
||||||
conan_parse_arguments(${ARGV})
|
conan_parse_arguments(${ARGV})
|
||||||
@@ -466,26 +765,64 @@ function(conan_cmake_setup_conanfile)
|
|||||||
configure_file(${ARGUMENTS_CONANFILE} ${CMAKE_CURRENT_BINARY_DIR}/${_CONANFILE_NAME}.junk COPYONLY)
|
configure_file(${ARGUMENTS_CONANFILE} ${CMAKE_CURRENT_BINARY_DIR}/${_CONANFILE_NAME}.junk COPYONLY)
|
||||||
file(REMOVE ${CMAKE_CURRENT_BINARY_DIR}/${_CONANFILE_NAME}.junk)
|
file(REMOVE ${CMAKE_CURRENT_BINARY_DIR}/${_CONANFILE_NAME}.junk)
|
||||||
else()
|
else()
|
||||||
conan_cmake_generate_conanfile(${ARGV})
|
conan_cmake_generate_conanfile(ON ${ARGV})
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
function(conan_cmake_generate_conanfile)
|
function(conan_cmake_configure)
|
||||||
|
conan_cmake_generate_conanfile(OFF ${ARGV})
|
||||||
|
endfunction()
|
||||||
|
|
||||||
# Generate, writing in disk a conanfile.txt with the requires, options, and imports
|
# Generate, writing in disk a conanfile.txt with the requires, options, and imports
|
||||||
# specified as arguments
|
# specified as arguments
|
||||||
# This will be considered as temporary file, generated in CMAKE_CURRENT_BINARY_DIR)
|
# This will be considered as temporary file, generated in CMAKE_CURRENT_BINARY_DIR)
|
||||||
|
function(conan_cmake_generate_conanfile DEFAULT_GENERATOR)
|
||||||
|
|
||||||
conan_parse_arguments(${ARGV})
|
conan_parse_arguments(${ARGV})
|
||||||
|
|
||||||
set(_FN "${CMAKE_CURRENT_BINARY_DIR}/conanfile.txt")
|
set(_FN "${CMAKE_CURRENT_BINARY_DIR}/conanfile.txt")
|
||||||
|
file(WRITE ${_FN} "")
|
||||||
|
|
||||||
file(WRITE ${_FN} "[generators]\ncmake\n\n[requires]\n")
|
if(DEFINED ARGUMENTS_REQUIRES)
|
||||||
foreach(ARG ${ARGUMENTS_REQUIRES})
|
file(APPEND ${_FN} "[requires]\n")
|
||||||
file(APPEND ${_FN} ${ARG} "\n")
|
foreach(REQUIRE ${ARGUMENTS_REQUIRES})
|
||||||
|
file(APPEND ${_FN} ${REQUIRE} "\n")
|
||||||
endforeach()
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
file(APPEND ${_FN} ${ARG} "\n[imports]\n")
|
if (DEFAULT_GENERATOR OR DEFINED ARGUMENTS_GENERATORS)
|
||||||
foreach(ARG ${ARGUMENTS_IMPORTS})
|
file(APPEND ${_FN} "[generators]\n")
|
||||||
file(APPEND ${_FN} ${ARG} "\n")
|
if (DEFAULT_GENERATOR)
|
||||||
|
file(APPEND ${_FN} "cmake\n")
|
||||||
|
endif()
|
||||||
|
if (DEFINED ARGUMENTS_GENERATORS)
|
||||||
|
foreach(GENERATOR ${ARGUMENTS_GENERATORS})
|
||||||
|
file(APPEND ${_FN} ${GENERATOR} "\n")
|
||||||
endforeach()
|
endforeach()
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(DEFINED ARGUMENTS_BUILD_REQUIRES)
|
||||||
|
file(APPEND ${_FN} "[build_requires]\n")
|
||||||
|
foreach(BUILD_REQUIRE ${ARGUMENTS_BUILD_REQUIRES})
|
||||||
|
file(APPEND ${_FN} ${BUILD_REQUIRE} "\n")
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(DEFINED ARGUMENTS_IMPORTS)
|
||||||
|
file(APPEND ${_FN} "[imports]\n")
|
||||||
|
foreach(IMPORTS ${ARGUMENTS_IMPORTS})
|
||||||
|
file(APPEND ${_FN} ${IMPORTS} "\n")
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(DEFINED ARGUMENTS_OPTIONS)
|
||||||
|
file(APPEND ${_FN} "[options]\n")
|
||||||
|
foreach(OPTION ${ARGUMENTS_OPTIONS})
|
||||||
|
file(APPEND ${_FN} ${OPTION} "\n")
|
||||||
|
endforeach()
|
||||||
|
endif()
|
||||||
|
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
|
||||||
@@ -537,12 +874,12 @@ macro(conan_cmake_run)
|
|||||||
foreach(CMAKE_BUILD_TYPE ${ARGUMENTS_CONFIGURATION_TYPES})
|
foreach(CMAKE_BUILD_TYPE ${ARGUMENTS_CONFIGURATION_TYPES})
|
||||||
set(ENV{CONAN_IMPORT_PATH} ${CMAKE_BUILD_TYPE})
|
set(ENV{CONAN_IMPORT_PATH} ${CMAKE_BUILD_TYPE})
|
||||||
conan_cmake_settings(settings ${ARGV})
|
conan_cmake_settings(settings ${ARGV})
|
||||||
conan_cmake_install(SETTINGS ${settings} ${ARGV})
|
old_conan_cmake_install(SETTINGS ${settings} ${ARGV})
|
||||||
endforeach()
|
endforeach()
|
||||||
set(CMAKE_BUILD_TYPE)
|
set(CMAKE_BUILD_TYPE)
|
||||||
else()
|
else()
|
||||||
conan_cmake_settings(settings ${ARGV})
|
conan_cmake_settings(settings ${ARGV})
|
||||||
conan_cmake_install(SETTINGS ${settings} ${ARGV})
|
old_conan_cmake_install(SETTINGS ${settings} ${ARGV})
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@@ -584,10 +921,17 @@ macro(conan_check)
|
|||||||
message(STATUS "Conan: Found program ${CONAN_CMD}")
|
message(STATUS "Conan: Found program ${CONAN_CMD}")
|
||||||
endif()
|
endif()
|
||||||
execute_process(COMMAND ${CONAN_CMD} --version
|
execute_process(COMMAND ${CONAN_CMD} --version
|
||||||
|
RESULT_VARIABLE return_code
|
||||||
OUTPUT_VARIABLE CONAN_VERSION_OUTPUT
|
OUTPUT_VARIABLE CONAN_VERSION_OUTPUT
|
||||||
ERROR_VARIABLE CONAN_VERSION_OUTPUT)
|
ERROR_VARIABLE CONAN_VERSION_OUTPUT)
|
||||||
|
|
||||||
|
if(NOT "${return_code}" STREQUAL "0")
|
||||||
|
message(FATAL_ERROR "Conan --version failed='${return_code}'")
|
||||||
|
endif()
|
||||||
|
|
||||||
if(NOT CONAN_DETECT_QUIET)
|
if(NOT CONAN_DETECT_QUIET)
|
||||||
message(STATUS "Conan: Version found ${CONAN_VERSION_OUTPUT}")
|
string(STRIP "${CONAN_VERSION_OUTPUT}" _CONAN_VERSION_OUTPUT)
|
||||||
|
message(STATUS "Conan: Version found ${_CONAN_VERSION_OUTPUT}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(DEFINED CONAN_VERSION)
|
if(DEFINED CONAN_VERSION)
|
||||||
@@ -617,14 +961,18 @@ function(conan_add_remote)
|
|||||||
if(DEFINED CONAN_COMMAND)
|
if(DEFINED CONAN_COMMAND)
|
||||||
set(CONAN_CMD ${CONAN_COMMAND})
|
set(CONAN_CMD ${CONAN_COMMAND})
|
||||||
else()
|
else()
|
||||||
conan_check(REQUIRED)
|
conan_check(REQUIRED DETECT_QUIET)
|
||||||
endif()
|
endif()
|
||||||
set(CONAN_VERIFY_SSL_ARG "True")
|
set(CONAN_VERIFY_SSL_ARG "True")
|
||||||
if(DEFINED CONAN_VERIFY_SSL)
|
if(DEFINED CONAN_VERIFY_SSL)
|
||||||
set(CONAN_VERIFY_SSL_ARG ${CONAN_VERIFY_SSL})
|
set(CONAN_VERIFY_SSL_ARG ${CONAN_VERIFY_SSL})
|
||||||
endif()
|
endif()
|
||||||
message(STATUS "Conan: Adding ${CONAN_NAME} remote repository (${CONAN_URL}) verify ssl (${CONAN_VERIFY_SSL_ARG})")
|
message(STATUS "Conan: Adding ${CONAN_NAME} remote repository (${CONAN_URL}) verify ssl (${CONAN_VERIFY_SSL_ARG})")
|
||||||
execute_process(COMMAND ${CONAN_CMD} remote add ${CONAN_NAME} ${CONAN_INDEX_ARG} -f ${CONAN_URL} ${CONAN_VERIFY_SSL_ARG})
|
execute_process(COMMAND ${CONAN_CMD} remote add ${CONAN_NAME} ${CONAN_INDEX_ARG} -f ${CONAN_URL} ${CONAN_VERIFY_SSL_ARG}
|
||||||
|
RESULT_VARIABLE return_code)
|
||||||
|
if(NOT "${return_code}" STREQUAL "0")
|
||||||
|
message(FATAL_ERROR "Conan remote failed='${return_code}'")
|
||||||
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
macro(conan_config_install)
|
macro(conan_config_install)
|
||||||
@@ -637,9 +985,10 @@ macro(conan_config_install)
|
|||||||
set(multiValueArgs ARGS)
|
set(multiValueArgs ARGS)
|
||||||
cmake_parse_arguments(CONAN "" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
cmake_parse_arguments(CONAN "" "${oneValueArgs}" "${multiValueArgs}" ${ARGN})
|
||||||
|
|
||||||
find_program(CONAN_CMD conan)
|
if(DEFINED CONAN_COMMAND)
|
||||||
if(NOT CONAN_CMD AND CONAN_REQUIRED)
|
set(CONAN_CMD ${CONAN_COMMAND})
|
||||||
message(FATAL_ERROR "Conan executable not found!")
|
else()
|
||||||
|
conan_check(REQUIRED)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(DEFINED CONAN_VERIFY_SSL)
|
if(DEFINED CONAN_VERIFY_SSL)
|
||||||
@@ -669,5 +1018,9 @@ macro(conan_config_install)
|
|||||||
${CONAN_TARGET_ARGS})
|
${CONAN_TARGET_ARGS})
|
||||||
|
|
||||||
message(STATUS "Conan: Installing config from ${CONAN_ITEM}")
|
message(STATUS "Conan: Installing config from ${CONAN_ITEM}")
|
||||||
execute_process(COMMAND ${CONAN_CMD} config install ${CONAN_ITEM} ${CONAN_CONFIG_INSTALL_ARGS})
|
execute_process(COMMAND ${CONAN_CMD} config install ${CONAN_ITEM} ${CONAN_CONFIG_INSTALL_ARGS}
|
||||||
|
RESULT_VARIABLE return_code)
|
||||||
|
if(NOT "${return_code}" STREQUAL "0")
|
||||||
|
message(FATAL_ERROR "Conan config failed='${return_code}'")
|
||||||
|
endif()
|
||||||
endmacro()
|
endmacro()
|
||||||
|
Reference in New Issue
Block a user