diff --git a/CMakeLists.txt b/CMakeLists.txt index c7d21add..d7ebb6df 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -48,7 +48,11 @@ endif() if(BUILD_NANOMSG_TRANSPORT) find_package2(PRIVATE nanomsg VERSION 1.0.0 REQUIRED) - find_package2(PRIVATE msgpack VERSION 2.1.5 REQUIRED) + find_package2(PRIVATE msgpack VERSION 3.0.0) + set(PROJECT_msgpack_VERSION 2.1.5) + if(NOT msgpack_FOUND) + find_package2(PRIVATE msgpack VERSION 2.1.5 REQUIRED) + endif() set(msgpack_ROOT ${PACKAGE_PREFIX_DIR}) endif() diff --git a/cmake/FairMQLib.cmake b/cmake/FairMQLib.cmake index 2d49dd53..00232bd5 100644 --- a/cmake/FairMQLib.cmake +++ b/cmake/FairMQLib.cmake @@ -280,20 +280,22 @@ macro(find_package2 qualifier pkgname) set(CMAKE_PREFIX_PATH ${old_CPP}) unset(old_CPP) - if(${qualifier} STREQUAL PRIVATE) - set(PROJECT_${pkgname}_VERSION ${ARGS_VERSION}) - set(PROJECT_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) - set(PROJECT_PACKAGE_DEPENDENCIES ${PROJECT_PACKAGE_DEPENDENCIES} ${pkgname}) - elseif(${qualifier} STREQUAL PUBLIC) - set(PROJECT_${pkgname}_VERSION ${ARGS_VERSION}) - set(PROJECT_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) - set(PROJECT_PACKAGE_DEPENDENCIES ${PROJECT_PACKAGE_DEPENDENCIES} ${pkgname}) - set(PROJECT_INTERFACE_${pkgname}_VERSION ${ARGS_VERSION}) - set(PROJECT_INTERFACE_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) - set(PROJECT_INTERFACE_PACKAGE_DEPENDENCIES ${PROJECT_INTERFACE_PACKAGE_DEPENDENCIES} ${pkgname}) - elseif(${qualifier} STREQUAL INTERFACE) - set(PROJECT_INTERFACE_${pkgname}_VERSION ${ARGS_VERSION}) - set(PROJECT_INTERFACE_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) - set(PROJECT_INTERFACE_PACKAGE_DEPENDENCIES ${PROJECT_INTERFACE_PACKAGE_DEPENDENCIES} ${pkgname}) + if(${pkgname}_FOUND) + if(${qualifier} STREQUAL PRIVATE) + set(PROJECT_${pkgname}_VERSION ${ARGS_VERSION}) + set(PROJECT_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) + set(PROJECT_PACKAGE_DEPENDENCIES ${PROJECT_PACKAGE_DEPENDENCIES} ${pkgname}) + elseif(${qualifier} STREQUAL PUBLIC) + set(PROJECT_${pkgname}_VERSION ${ARGS_VERSION}) + set(PROJECT_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) + set(PROJECT_PACKAGE_DEPENDENCIES ${PROJECT_PACKAGE_DEPENDENCIES} ${pkgname}) + set(PROJECT_INTERFACE_${pkgname}_VERSION ${ARGS_VERSION}) + set(PROJECT_INTERFACE_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) + set(PROJECT_INTERFACE_PACKAGE_DEPENDENCIES ${PROJECT_INTERFACE_PACKAGE_DEPENDENCIES} ${pkgname}) + elseif(${qualifier} STREQUAL INTERFACE) + set(PROJECT_INTERFACE_${pkgname}_VERSION ${ARGS_VERSION}) + set(PROJECT_INTERFACE_${pkgname}_COMPONENTS ${ARGS_COMPONENTS}) + set(PROJECT_INTERFACE_PACKAGE_DEPENDENCIES ${PROJECT_INTERFACE_PACKAGE_DEPENDENCIES} ${pkgname}) + endif() endif() endmacro()