From d6c578a44c3461ad1510cb02e96107b62ea4f0d9 Mon Sep 17 00:00:00 2001 From: Sutou Kouhei Date: Fri, 12 Aug 2022 11:12:38 +0900 Subject: [PATCH] ARROW-17394: [C++][Parquet] Fix parquet_static dependencies parquet_static needs Thrift because cpp/src/parquet/thrift_internal.h uses Thrift. See also: https://github.com/microsoft/vcpkg/issues/22552#issuecomment-1211341648 We can test this by the following command lines: $ cd cpp/examples/parquet/parquet_arrow $ export Arrow_DIR=${ARROW_INSTALL_PREFIX}/lib/cmake/arrow $ export Parquet_DIR=${ARROW_INSTALL_PREFIX}/lib/cmake/arrow $ cmake -S . -B build -DPARQUET_LINK_SHARED=OFF $ cmake --build build --verbose I also noticed that OpenTelemetry related dependencies are also missed because I usually use -DARROW_WITH_OPENTELEMETRY=ON option for Apache Arrow development. The problem is also fixed in this. --- cpp/CMakeLists.txt | 11 +++++++++++ cpp/cmake_modules/ThirdpartyToolchain.cmake | 3 ++- cpp/examples/parquet/parquet_arrow/CMakeLists.txt | 8 ++++++-- cpp/src/parquet/CMakeLists.txt | 13 ++++++++++--- 4 files changed, 29 insertions(+), 6 deletions(-) diff --git a/cpp/CMakeLists.txt b/cpp/CMakeLists.txt index 9e732db80afb9..f0c3f30ef3d8d 100644 --- a/cpp/CMakeLists.txt +++ b/cpp/CMakeLists.txt @@ -822,6 +822,17 @@ if(ARROW_WITH_OPENTELEMETRY) opentelemetry-cpp::trace opentelemetry-cpp::ostream_span_exporter opentelemetry-cpp::otlp_http_exporter) + if(opentelemetry_SOURCE STREQUAL "SYSTEM") + list(APPEND + ARROW_STATIC_INSTALL_INTERFACE_LIBS + opentelemetry-cpp::trace + opentelemetry-cpp::ostream_span_exporter + opentelemetry-cpp::otlp_http_exporter) + endif() + if(Protobuf_SOURCE STREQUAL "SYSTEM") + list(APPEND ARROW_STATIC_INSTALL_INTERFACE_LIBS ${ARROW_PROTOBUF_LIBPROTOBUF}) + endif() + list(APPEND ARROW_STATIC_INSTALL_INTERFACE_LIBS CURL::libcurl) endif() if(ARROW_WITH_UTF8PROC) diff --git a/cpp/cmake_modules/ThirdpartyToolchain.cmake b/cpp/cmake_modules/ThirdpartyToolchain.cmake index ad8351f9cc6e3..5c1dd9d34d120 100644 --- a/cpp/cmake_modules/ThirdpartyToolchain.cmake +++ b/cpp/cmake_modules/ThirdpartyToolchain.cmake @@ -1083,6 +1083,7 @@ endif() macro(find_curl) if(NOT TARGET CURL::libcurl) find_package(CURL REQUIRED) + list(APPEND ARROW_SYSTEM_DEPENDENCIES CURL) if(NOT TARGET CURL::libcurl) # For CMake 3.11 or older add_library(CURL::libcurl UNKNOWN IMPORTED) @@ -4540,11 +4541,11 @@ macro(build_opentelemetry) foreach(_OPENTELEMETRY_LIB ${_OPENTELEMETRY_LIBS}) add_dependencies(opentelemetry-cpp::${_OPENTELEMETRY_LIB} opentelemetry_ep) + list(APPEND ARROW_BUNDLED_STATIC_LIBS opentelemetry-cpp::${_OPENTELEMETRY_LIB}) endforeach() # Work around https://gitlab.kitware.com/cmake/cmake/issues/15052 file(MAKE_DIRECTORY ${OPENTELEMETRY_INCLUDE_DIR}) - endmacro() if(ARROW_WITH_OPENTELEMETRY) diff --git a/cpp/examples/parquet/parquet_arrow/CMakeLists.txt b/cpp/examples/parquet/parquet_arrow/CMakeLists.txt index 32f980060c95a..c89751731575f 100644 --- a/cpp/examples/parquet/parquet_arrow/CMakeLists.txt +++ b/cpp/examples/parquet/parquet_arrow/CMakeLists.txt @@ -24,7 +24,7 @@ include(ExternalProject) include(FindPkgConfig) include(GNUInstallDirs) -set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_SOURCE_DIR}/cmake_modules") +option(PARQUET_LINK_SHARED "Link to the Parquet shared library" ON) # This ensures that things like gnu++11 get passed correctly if(NOT DEFINED CMAKE_CXX_STANDARD) @@ -39,4 +39,8 @@ find_package(Arrow REQUIRED) find_package(Parquet REQUIRED) add_executable(parquet-arrow-example reader_writer.cc) -target_link_libraries(parquet-arrow-example parquet_shared arrow_shared) +if(PARQUET_LINK_SHARED) + target_link_libraries(parquet-arrow-example parquet_shared) +else() + target_link_libraries(parquet-arrow-example parquet_static) +endif() diff --git a/cpp/src/parquet/CMakeLists.txt b/cpp/src/parquet/CMakeLists.txt index 542fa5bc083bc..caed261734280 100644 --- a/cpp/src/parquet/CMakeLists.txt +++ b/cpp/src/parquet/CMakeLists.txt @@ -106,9 +106,11 @@ endfunction() if(ARROW_BUILD_STATIC) set(PARQUET_STATIC_LINK_LIBS arrow_static ${ARROW_STATIC_LINK_LIBS}) + set(PARQUET_STATIC_INTERFACE_INSTALL_LIBS arrow_static) set(ARROW_LIBRARIES_FOR_STATIC_TESTS arrow_testing_static arrow_static ${ARROW_STATIC_LINK_LIBS}) else() + set(PARQUET_STATIC_INTERFACE_INSTALL_LIBS) set(ARROW_LIBRARIES_FOR_STATIC_TESTS arrow_testing_shared arrow_shared) endif() @@ -218,8 +220,9 @@ if(NOT PARQUET_MINIMAL_DEPENDENCY) # Link publicly with parquet_static (because internal users need to # transitively link all dependencies) - set(PARQUET_STATIC_LINK_LIBS ${PARQUET_STATIC_LINK_LIBS} thrift::thrift) -endif(NOT PARQUET_MINIMAL_DEPENDENCY) + list(APPEND PARQUET_STATIC_LINK_LIBS thrift::thrift) + list(APPEND PARQUET_STATIC_INTERFACE_INSTALL_LIBS thrift::thrift) +endif() if(CXX_LINKER_SUPPORTS_VERSION_SCRIPT) set(PARQUET_SHARED_LINK_FLAGS @@ -243,8 +246,12 @@ add_arrow_lib(parquet ${PARQUET_SHARED_LINK_LIBS} SHARED_PRIVATE_LINK_LIBS ${PARQUET_SHARED_PRIVATE_LINK_LIBS} + SHARED_INSTALL_INTERFACE_LIBS + arrow_shared STATIC_LINK_LIBS - ${PARQUET_STATIC_LINK_LIBS}) + ${PARQUET_STATIC_LINK_LIBS} + STATIC_INSTALL_INTERFACE_LIBS + ${PARQUET_STATIC_INTERFACE_INSTALL_LIBS}) if(WIN32 AND NOT (ARROW_TEST_LINKAGE STREQUAL "static")) add_library(parquet_test_support STATIC