From 520b6fb854dee8e4504ac7f92ab14ad0f3eace35 Mon Sep 17 00:00:00 2001 From: Tao He Date: Mon, 13 Feb 2023 18:21:48 +0800 Subject: [PATCH] Address issues in handling yaml-cpp correctly when requires GraphAr in external projects Signed-off-by: Tao He --- CMakeLists.txt | 35 +++++++++++++++++++++++++---------- 1 file changed, 25 insertions(+), 10 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index cfebbf280..9da5a44fa 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,5 +1,9 @@ cmake_minimum_required(VERSION 2.8) +if(POLICY CMP0026) + cmake_policy(SET CMP0026 OLD) +endif() + if(POLICY CMP0048) cmake_policy(SET CMP0048 NEW) endif() @@ -113,7 +117,8 @@ endmacro() macro(find_yaml_cpp) set(MESSAGE_QUIET ON) set(CMAKE_WARN_DEPRECATED OFF CACHE BOOL "" FORCE) - add_subdirectory_static(thirdparty/yaml-cpp) + set(YAML_CPP_BUILD_TOOLS OFF CACHE BOOL "" FORCE) + add_subdirectory_static(thirdparty/yaml-cpp EXCLUDE_FROM_ALL) unset(MESSAGE_QUIET) set(CMAKE_WARN_DEPRECATED ON CACHE BOOL "" FORCE) endmacro() @@ -155,6 +160,17 @@ build_arrow() include_directories(BEFORE SYSTEM ${ARROW_INCLUDE_DIR}) +macro(get_target_location var target) + if(TARGET ${target}) + foreach(prop LOCATION LOCATION_NOCONFIG LOCATION_DEBUG LOCATION_RELEASE) + get_target_property(${var} ${target} ${prop}) + if(NOT ("${${var}}" STREQUAL "${var}-NOTFOUND")) + break () + endif() + endforeach() + endif() +endmacro() + # ------------------------------------------------------------------------------ # generate gar library # ------------------------------------------------------------------------------ @@ -163,23 +179,22 @@ macro(build_gar) add_library(gar SHARED ${CORE_SRC_FILES}) install_gar_target(gar) target_compile_features(gar PRIVATE cxx_std_17) - target_include_directories( - gar - PRIVATE - ${PROJECT_SOURCE_DIR}/include - $ - $ - $ + target_include_directories(gar PUBLIC $ + $ + $ ) target_link_libraries(gar PRIVATE Threads::Threads ${CMAKE_DL_LIBS}) + # make sure `libyaml-cpp.a` built first + add_dependencies(gar yaml-cpp) + get_target_location(YAML_CPP_LIBRARY_LOCATION yaml-cpp) if(APPLE) target_link_libraries(gar PRIVATE -Wl,-force_load arrow_static - "${PROJECT_BINARY_DIR}/thirdparty/yaml-cpp/libyaml-cpp.a" + "${YAML_CPP_LIBRARY_LOCATION}" "${PARQUET_STATIC_LIB}" "${ARROW_BUNDLED_DEPS_STATIC_LIB}") else() target_link_libraries(gar PRIVATE -Wl,--exclude-libs,ALL -Wl,--whole-archive arrow_static - "${PROJECT_BINARY_DIR}/thirdparty/yaml-cpp/libyaml-cpp.a" + "${YAML_CPP_LIBRARY_LOCATION}" "${PARQUET_STATIC_LIB}" "${ARROW_BUNDLED_DEPS_STATIC_LIB}" -Wl,--no-whole-archive) endif()