mirror of
https://github.com/microsoft/vcpkg.git
synced 2025-01-04 22:17:49 +08:00
780 lines
28 KiB
Diff
780 lines
28 KiB
Diff
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
|
index 304f3fb..0b0fc1f 100644
|
|
--- a/CMakeLists.txt
|
|
+++ b/CMakeLists.txt
|
|
@@ -16,7 +16,7 @@
|
|
# under the License.
|
|
|
|
# Require cmake that supports BYPRODUCTS in add_custom_command, ExternalProject_Add [1].
|
|
-cmake_minimum_required(VERSION 3.2.0)
|
|
+cmake_minimum_required(VERSION 3.8)
|
|
|
|
file(READ "${CMAKE_CURRENT_SOURCE_DIR}/.parquetcppversion" PARQUET_VERSION)
|
|
string(REPLACE "\n" "" PARQUET_VERSION "${PARQUET_VERSION}")
|
|
@@ -25,6 +25,10 @@ if(NOT VERSION)
|
|
message(FATAL_ERROR "invalid .parquetcppversion")
|
|
endif()
|
|
|
|
+if(NOT DEFINED ARROW_LIB_SUFFIX)
|
|
+ set(ARROW_LIB_SUFFIX "")
|
|
+endif()
|
|
+
|
|
project(parquet-cpp VERSION ${VERSION})
|
|
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "C++ library to read and write the Apache Parquet columnar data format")
|
|
set(CPACK_PACKAGE_VERSION_MAJOR ${PROJECT_VERSION_MAJOR})
|
|
@@ -528,37 +532,25 @@ endif()
|
|
#############################################################
|
|
# Apache Arrow linkage
|
|
|
|
-if ("${PARQUET_ARROW_LINKAGE}" STREQUAL "shared")
|
|
+if ("${PARQUET_ARROW_LINKAGE}" STREQUAL "dynamic")
|
|
set(ARROW_LINK_LIBS
|
|
- arrow)
|
|
+ arrow_static)
|
|
else()
|
|
#############################################################
|
|
# Transitive Library Linkage
|
|
-
|
|
- if (NOT DEFINED ENV{BROTLI_STATIC_LIB_ENC} OR
|
|
- NOT DEFINED ENV{BROTLI_STATIC_LIB_DEC} OR
|
|
- NOT DEFINED ENV{BROTLI_STATIC_LIB_COMMON} OR
|
|
- NOT DEFINED ENV{SNAPPY_STATIC_LIB} OR
|
|
- NOT DEFINED ENV{ZLIB_STATIC_LIB} OR
|
|
- NOT DEFINED ENV{LZ4_STATIC_LIB} OR
|
|
- NOT DEFINED ENV{ZSTD_STATIC_LIB})
|
|
- message(FATAL_ERROR "Missing transitive dependencies for Arrow static linking")
|
|
- endif()
|
|
-
|
|
- set(BROTLI_STATIC_LIB_ENC "$ENV{BROTLI_STATIC_LIB_ENC}")
|
|
- set(BROTLI_STATIC_LIB_DEC "$ENV{BROTLI_STATIC_LIB_DEC}")
|
|
- set(BROTLI_STATIC_LIB_COMMON "$ENV{BROTLI_STATIC_LIB_COMMON}")
|
|
- set(SNAPPY_STATIC_LIB "$ENV{SNAPPY_STATIC_LIB}")
|
|
- set(ZLIB_STATIC_LIB "$ENV{ZLIB_STATIC_LIB}")
|
|
- set(LZ4_STATIC_LIB "$ENV{LZ4_STATIC_LIB}")
|
|
- set(ZSTD_STATIC_LIB "$ENV{ZSTD_STATIC_LIB}")
|
|
-
|
|
+
|
|
+ find_package(Brotli REQUIRED)
|
|
+ find_package(Snappy REQUIRED)
|
|
+ find_package(LZ4 REQUIRED)
|
|
+ find_package(ZLIB REQUIRED)
|
|
+ find_package(ZSTD REQUIRED)
|
|
+
|
|
add_library(brotli_enc STATIC IMPORTED)
|
|
- set_target_properties(brotli_enc PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIB_ENC})
|
|
+ set_target_properties(brotli_enc PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIBRARY_ENC})
|
|
add_library(brotli_dec STATIC IMPORTED)
|
|
- set_target_properties(brotli_dec PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIB_DEC})
|
|
+ set_target_properties(brotli_dec PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIBRARY_DEC})
|
|
add_library(brotli_common STATIC IMPORTED)
|
|
- set_target_properties(brotli_common PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIB_COMMON})
|
|
+ set_target_properties(brotli_common PROPERTIES IMPORTED_LOCATION ${BROTLI_STATIC_LIBRARY_COMMON})
|
|
add_library(snappy STATIC IMPORTED)
|
|
set_target_properties(snappy PROPERTIES IMPORTED_LOCATION ${SNAPPY_STATIC_LIB})
|
|
add_library(zlib STATIC IMPORTED)
|
|
@@ -588,9 +580,7 @@ endif()
|
|
#############################################################
|
|
# Test linking
|
|
|
|
-set(PARQUET_MIN_TEST_LIBS
|
|
- gtest
|
|
- gtest_main)
|
|
+set(PARQUET_MIN_TEST_LIBS GTest::GTest GTest::Main)
|
|
|
|
if (APPLE)
|
|
set(PARQUET_MIN_TEST_LIBS
|
|
diff --git a/cmake_modules/FindArrow.cmake b/cmake_modules/FindArrow.cmake
|
|
index b63b1af..3329c4a 100644
|
|
--- a/cmake_modules/FindArrow.cmake
|
|
+++ b/cmake_modules/FindArrow.cmake
|
|
@@ -22,76 +22,21 @@
|
|
# ARROW_SHARED_LIB, path to libarrow's shared library
|
|
# ARROW_FOUND, whether arrow has been found
|
|
|
|
-if (DEFINED ENV{ARROW_HOME})
|
|
- set(ARROW_HOME "$ENV{ARROW_HOME}")
|
|
-endif()
|
|
-
|
|
-if ("${ARROW_HOME}" STREQUAL "")
|
|
- # PARQUET-955. If the user has set $ARROW_HOME in the environment, we respect
|
|
- # this, otherwise try to locate the pkgconfig in the system environment
|
|
- pkg_check_modules(ARROW arrow)
|
|
- if (ARROW_FOUND)
|
|
- # We found the pkgconfig
|
|
- set(ARROW_INCLUDE_DIR ${ARROW_INCLUDE_DIRS})
|
|
-
|
|
- if (COMMAND pkg_get_variable)
|
|
- pkg_get_variable(ARROW_ABI_VERSION arrow abi_version)
|
|
- else()
|
|
- set(ARROW_ABI_VERSION "")
|
|
- endif()
|
|
- if (ARROW_ABI_VERSION STREQUAL "")
|
|
- set(ARROW_SHARED_LIB_SUFFIX "")
|
|
- else()
|
|
- set(ARROW_SHARED_LIB_SUFFIX ".${ARROW_ABI_VERSION}")
|
|
- endif()
|
|
-
|
|
- set(ARROW_LIB_NAME ${CMAKE_SHARED_LIBRARY_PREFIX}arrow)
|
|
-
|
|
- if (APPLE)
|
|
- set(ARROW_SHARED_LIB ${ARROW_LIBDIR}/${ARROW_LIB_NAME}${ARROW_SHARED_LIB_SUFFIX}${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
- else()
|
|
- set(ARROW_SHARED_LIB ${ARROW_LIBDIR}/${ARROW_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX}${ARROW_SHARED_LIB_SUFFIX})
|
|
- endif()
|
|
- set(ARROW_STATIC_LIB ${ARROW_LIBDIR}/${ARROW_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- endif()
|
|
-else()
|
|
- set(ARROW_HOME "${ARROW_HOME}")
|
|
+find_path(ARROW_INCLUDE_DIR arrow/array.h
|
|
+ PATH_SUFFIXES "include"
|
|
+ )
|
|
|
|
- if (MSVC AND NOT ARROW_MSVC_STATIC_LIB_SUFFIX)
|
|
- set(ARROW_MSVC_STATIC_LIB_SUFFIX _static)
|
|
- endif()
|
|
+find_library(ARROW_LIB_PATH NAMES arrow)
|
|
|
|
- set(ARROW_SEARCH_HEADER_PATHS
|
|
- ${ARROW_HOME}/include
|
|
- )
|
|
+if (ARROW_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR ARROW_LIB_PATH))
|
|
+ set(ARROW_FOUND TRUE)
|
|
+ set(ARROW_HEADER_NAME arrow/api.h)
|
|
+ set(ARROW_HEADER ${ARROW_INCLUDE_DIR}/${ARROW_HEADER_NAME})
|
|
+ set(ARROW_LIB_NAME arrow)
|
|
|
|
- set(ARROW_SEARCH_LIB_PATH
|
|
- ${ARROW_HOME}/lib
|
|
- )
|
|
-
|
|
- find_path(ARROW_INCLUDE_DIR arrow/array.h PATHS
|
|
- ${ARROW_SEARCH_HEADER_PATHS}
|
|
- # make sure we don't accidentally pick up a different version
|
|
- NO_DEFAULT_PATH
|
|
- )
|
|
-
|
|
- find_library(ARROW_LIB_PATH NAMES arrow arrow${ARROW_MSVC_STATIC_LIB_SUFFIX}
|
|
- PATHS
|
|
- ${ARROW_SEARCH_LIB_PATH}
|
|
- NO_DEFAULT_PATH)
|
|
-
|
|
- if (ARROW_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR ARROW_LIB_PATH))
|
|
- set(ARROW_FOUND TRUE)
|
|
- set(ARROW_HEADER_NAME arrow/api.h)
|
|
- set(ARROW_HEADER ${ARROW_INCLUDE_DIR}/${ARROW_HEADER_NAME})
|
|
- set(ARROW_LIB_NAME arrow)
|
|
-
|
|
- get_filename_component(ARROW_LIBS ${ARROW_LIB_PATH} DIRECTORY)
|
|
- set(ARROW_STATIC_LIB ${ARROW_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${ARROW_LIB_NAME}${ARROW_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(ARROW_SHARED_LIB ${ARROW_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${ARROW_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
- set(ARROW_SHARED_IMPLIB ${ARROW_LIBS}/${ARROW_LIB_NAME}.lib)
|
|
- endif ()
|
|
-endif()
|
|
+ set(ARROW_STATIC_LIB ${ARROW_LIB_PATH})
|
|
+ set(ARROW_SHARED_LIB ${ARROW_LIB_PATH})
|
|
+endif ()
|
|
|
|
if (ARROW_FOUND)
|
|
if (NOT Arrow_FIND_QUIETLY)
|
|
diff --git a/cmake_modules/FindBrotli.cmake b/cmake_modules/FindBrotli.cmake
|
|
index f2e714c..9561660 100644
|
|
--- a/cmake_modules/FindBrotli.cmake
|
|
+++ b/cmake_modules/FindBrotli.cmake
|
|
@@ -17,13 +17,6 @@
|
|
#
|
|
# find_package(Brotli)
|
|
#
|
|
-# Variables used by this module, they can change the default behaviour and need
|
|
-# to be set before calling find_package:
|
|
-#
|
|
-# Brotli_HOME - When set, this path is inspected instead of standard library
|
|
-# locations as the root of the Brotli installation.
|
|
-# The environment variable BROTLI_HOME overrides this veriable.
|
|
-#
|
|
# This module defines
|
|
# BROTLI_INCLUDE_DIR, directory containing headers
|
|
# BROTLI_LIBS, directory containing brotli libraries
|
|
@@ -31,80 +24,37 @@
|
|
# BROTLI_SHARED_LIB, path to libbrotli's shared library
|
|
# BROTLI_FOUND, whether brotli has been found
|
|
|
|
-if( NOT "${BROTLI_HOME}" STREQUAL "")
|
|
- file( TO_CMAKE_PATH "${BROTLI_HOME}" _native_path )
|
|
- list( APPEND _brotli_roots ${_native_path} )
|
|
-elseif ( Brotli_HOME )
|
|
- list( APPEND _brotli_roots ${Brotli_HOME} )
|
|
-endif()
|
|
-
|
|
find_path( BROTLI_INCLUDE_DIR NAMES brotli/decode.h
|
|
- PATHS ${_brotli_roots}
|
|
- NO_DEFAULT_PATH
|
|
PATH_SUFFIXES "include" )
|
|
-
|
|
-find_library( BROTLI_LIBRARY_ENC NAMES libbrotlienc.a brotlienc
|
|
- PATHS ${_brotli_roots}
|
|
- NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib/${CMAKE_LIBRARY_ARCHITECTURE}" "lib" )
|
|
-
|
|
-find_library( BROTLI_LIBRARY_DEC NAMES libbrotlidec.a brotlidec
|
|
- PATHS ${_brotli_roots}
|
|
- NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib/${CMAKE_LIBRARY_ARCHITECTURE}" "lib" )
|
|
-
|
|
-find_library( BROTLI_LIBRARY_COMMON NAMES libbrotlicommon.a brotlicommon
|
|
- PATHS ${_brotli_roots}
|
|
- NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib/${CMAKE_LIBRARY_ARCHITECTURE}" "lib" )
|
|
+
|
|
+find_library( BROTLI_LIBRARY_ENC NAMES libbrotlienc.a brotlienc brotlienc-static )
|
|
+find_library( BROTLI_LIBRARY_DEC NAMES libbrotlidec.a brotlidec brotlidec-static )
|
|
+find_library( BROTLI_LIBRARY_COMMON NAMES libbrotlicommon.a brotlicommon brotlicommon-static )
|
|
|
|
set(BROTLI_LIBRARIES ${BROTLI_LIBRARY_ENC} ${BROTLI_LIBRARY_DEC}
|
|
${BROTLI_LIBRARY_COMMON})
|
|
|
|
-if (BROTLI_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR BROTLI_LIBRARIES))
|
|
+if (BROTLI_INCLUDE_DIR)
|
|
set(BROTLI_FOUND TRUE)
|
|
- get_filename_component( BROTLI_LIBS ${BROTLI_LIBRARY_ENC} PATH )
|
|
- set(BROTLI_LIB_NAME brotli)
|
|
- if (MSVC AND NOT BROTLI_MSVC_STATIC_LIB_SUFFIX)
|
|
- set(BROTLI_MSVC_STATIC_LIB_SUFFIX _static)
|
|
- endif()
|
|
set(BROTLI_STATIC_LIB
|
|
- ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}enc${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX}
|
|
- ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}dec${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX}
|
|
- ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}common${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(BROTLI_STATIC_LIBRARY_ENC ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}enc${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(BROTLI_STATIC_LIBRARY_DEC ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}dec${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(BROTLI_STATIC_LIBRARY_COMMON ${BROTLI_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${BROTLI_LIB_NAME}common${BROTLI_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
+ ${BROTLI_LIBRARY_ENC}
|
|
+ ${BROTLI_LIBRARY_DEC}
|
|
+ ${BROTLI_LIBRARY_COMMON})
|
|
+ set(BROTLI_STATIC_LIBRARY_ENC ${BROTLI_LIBRARY_ENC})
|
|
+ set(BROTLI_STATIC_LIBRARY_DEC ${BROTLI_LIBRARY_DEC})
|
|
+ set(BROTLI_STATIC_LIBRARY_COMMON ${BROTLI_LIBRARY_COMMON})
|
|
set(BROTLI_SHARED_LIB
|
|
- ${BROTLI_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${BROTLI_LIB_NAME}enc${CMAKE_SHARED_LIBRARY_SUFFIX}
|
|
- ${BROTLI_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${BROTLI_LIB_NAME}dec${CMAKE_SHARED_LIBRARY_SUFFIX}
|
|
- ${BROTLI_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${BROTLI_LIB_NAME}common${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
+ ${BROTLI_LIBRARY_ENC}
|
|
+ ${BROTLI_LIBRARY_DEC}
|
|
+ ${BROTLI_LIBRARY_COMMON})
|
|
else ()
|
|
set(BROTLI_FOUND FALSE)
|
|
endif ()
|
|
|
|
if (BROTLI_FOUND)
|
|
- if (NOT Brotli_FIND_QUIETLY)
|
|
- if (PARQUET_MINIMAL_DEPENDENCY)
|
|
- message(STATUS "Found the Brotli headers: ${BROTLI_INCLUDE_DIR}")
|
|
- else ()
|
|
- message(STATUS "Found the Brotli library: ${BROTLI_LIBRARIES}")
|
|
- endif ()
|
|
- endif ()
|
|
+ message(STATUS "Found the Brotli library: ${BROTLI_LIBRARIES}")
|
|
else ()
|
|
- if (NOT Brotli_FIND_QUIETLY)
|
|
- set(BROTLI_ERR_MSG "Could not find the Brotli library. Looked in ")
|
|
- if ( _brotli_roots )
|
|
- set(BROTLI_ERR_MSG "${BROTLI_ERR_MSG} in ${_brotli_roots}.")
|
|
- else ()
|
|
- set(BROTLI_ERR_MSG "${BROTLI_ERR_MSG} system search paths.")
|
|
- endif ()
|
|
- if (Brotli_FIND_REQUIRED)
|
|
- message(FATAL_ERROR "${BROTLI_ERR_MSG}")
|
|
- else (Brotli_FIND_REQUIRED)
|
|
- message(STATUS "${BROTLI_ERR_MSG}")
|
|
- endif (Brotli_FIND_REQUIRED)
|
|
- endif ()
|
|
+ message(FATAL_ERROR "Could not find the Brotli library.")
|
|
endif ()
|
|
|
|
mark_as_advanced(
|
|
diff --git a/cmake_modules/FindGTest.cmake b/cmake_modules/FindGTest.cmake
|
|
deleted file mode 100644
|
|
index c6ea16b..0000000
|
|
--- a/cmake_modules/FindGTest.cmake
|
|
+++ /dev/null
|
|
@@ -1,94 +0,0 @@
|
|
-#
|
|
-# Licensed under the Apache License, Version 2.0 (the "License");
|
|
-# you may not use this file except in compliance with the License.
|
|
-# You may obtain a copy of the License at
|
|
-#
|
|
-# http://www.apache.org/licenses/LICENSE-2.0
|
|
-#
|
|
-# Unless required by applicable law or agreed to in writing, software
|
|
-# distributed under the License is distributed on an "AS IS" BASIS,
|
|
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
-# See the License for the specific language governing permissions and
|
|
-# limitations under the License.
|
|
-#
|
|
-# Tries to find GTest headers and libraries.
|
|
-#
|
|
-# Usage of this module as follows:
|
|
-#
|
|
-# find_package(GTest)
|
|
-#
|
|
-# Variables used by this module, they can change the default behaviour and need
|
|
-# to be set before calling find_package:
|
|
-#
|
|
-# GTest_HOME - When set, this path is inspected instead of standard library
|
|
-# locations as the root of the GTest installation.
|
|
-# The environment variable GTEST_HOME overrides this veriable.
|
|
-#
|
|
-# This module defines
|
|
-# GTEST_INCLUDE_DIR, directory containing headers
|
|
-# GTEST_LIBS, directory containing gtest libraries
|
|
-# GTEST_STATIC_LIB, path to libgtest.a
|
|
-# GTEST_MAIN_STATIC_LIB, path to libgtest_main.a
|
|
-# GTEST_SHARED_LIB, path to libgtest's shared library
|
|
-# GTEST_FOUND, whether gtest has been found
|
|
-
|
|
-if( NOT "$ENV{GTEST_HOME}" STREQUAL "")
|
|
- file( TO_CMAKE_PATH "$ENV{GTEST_HOME}" _native_path )
|
|
- list( APPEND _gtest_roots ${_native_path} )
|
|
-elseif ( GTest_HOME )
|
|
- list( APPEND _gtest_roots ${GTest_HOME} )
|
|
-endif()
|
|
-
|
|
-# Try the parameterized roots, if they exist
|
|
-if ( _gtest_roots )
|
|
- find_path( GTEST_INCLUDE_DIR NAMES gtest/gtest.h
|
|
- PATHS ${_gtest_roots} NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "include" )
|
|
- find_library( GTEST_LIBRARIES NAMES gtest gtest_main
|
|
- PATHS ${_gtest_roots} NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib" )
|
|
-else ()
|
|
- find_path( GTEST_INCLUDE_DIR NAMES gtest/gtest.h )
|
|
- find_library( GTEST_LIBRARIES NAMES gtest )
|
|
-endif ()
|
|
-
|
|
-
|
|
-if (GTEST_INCLUDE_DIR AND GTEST_LIBRARIES)
|
|
- set(GTEST_FOUND TRUE)
|
|
- get_filename_component( GTEST_LIBS ${GTEST_LIBRARIES} PATH )
|
|
- set(GTEST_LIB_NAME gtest)
|
|
- set(GTEST_STATIC_LIB ${GTEST_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${GTEST_LIB_NAME}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(GTEST_MAIN_STATIC_LIB ${GTEST_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${GTEST_LIB_NAME}_main${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(GTEST_SHARED_LIB ${GTEST_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${GTEST_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
-else ()
|
|
- set(GTEST_FOUND FALSE)
|
|
-endif ()
|
|
-
|
|
-if (GTEST_FOUND)
|
|
- if (NOT GTest_FIND_QUIETLY)
|
|
- message(STATUS "Found the GTest library: ${GTEST_LIBRARIES}")
|
|
- endif ()
|
|
-else ()
|
|
- if (NOT GTest_FIND_QUIETLY)
|
|
- set(GTEST_ERR_MSG "Could not find the GTest library. Looked in ")
|
|
- if ( _gtest_roots )
|
|
- set(GTEST_ERR_MSG "${GTEST_ERR_MSG} in ${_gtest_roots}.")
|
|
- else ()
|
|
- set(GTEST_ERR_MSG "${GTEST_ERR_MSG} system search paths.")
|
|
- endif ()
|
|
- if (GTest_FIND_REQUIRED)
|
|
- message(FATAL_ERROR "${GTEST_ERR_MSG}")
|
|
- else (GTest_FIND_REQUIRED)
|
|
- message(STATUS "${GTEST_ERR_MSG}")
|
|
- endif (GTest_FIND_REQUIRED)
|
|
- endif ()
|
|
-endif ()
|
|
-
|
|
-mark_as_advanced(
|
|
- GTEST_INCLUDE_DIR
|
|
- GTEST_LIBS
|
|
- GTEST_LIBRARIES
|
|
- GTEST_STATIC_LIB
|
|
- GTEST_MAIN_STATIC_LIB
|
|
- GTEST_SHARED_LIB
|
|
-)
|
|
diff --git a/cmake_modules/FindLZ4.cmake b/cmake_modules/FindLZ4.cmake
|
|
new file mode 100644
|
|
index 0000000..8458d7f
|
|
--- /dev/null
|
|
+++ b/cmake_modules/FindLZ4.cmake
|
|
@@ -0,0 +1,62 @@
|
|
+#
|
|
+# Licensed under the Apache License, Version 2.0 (the "License");
|
|
+# you may not use this file except in compliance with the License.
|
|
+# You may obtain a copy of the License at
|
|
+#
|
|
+# http://www.apache.org/licenses/LICENSE-2.0
|
|
+#
|
|
+# Unless required by applicable law or agreed to in writing, software
|
|
+# distributed under the License is distributed on an "AS IS" BASIS,
|
|
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
+# See the License for the specific language governing permissions and
|
|
+# limitations under the License.
|
|
+#
|
|
+# Tries to find LZ4 headers and libraries.
|
|
+#
|
|
+# Usage of this module as follows:
|
|
+#
|
|
+# find_package(Snappy)
|
|
+#
|
|
+# This module defines
|
|
+# LZ4_INCLUDE_DIR, directory containing headers
|
|
+# LZ4_LIBS, directory containing LZ4 libraries
|
|
+# LZ4_STATIC_LIB, path to lz4.a
|
|
+# LZ4_SHARED_LIB, path to lz4's shared library
|
|
+# LZ4_FOUND, whether LZ4 has been found
|
|
+
|
|
+find_path(LZ4_INCLUDE_DIR lz4.h
|
|
+ PATH_SUFFIXES "include")
|
|
+
|
|
+if(CMAKE_BUILD_TYPE STREQUAL "DEBUG")
|
|
+ set(LZ4_LIB_SUFFIX "d")
|
|
+else()
|
|
+ set(LZ4_LIB_SUFFIX "")
|
|
+endif()
|
|
+
|
|
+find_library( LZ4_LIBRARIES NAMES lz4${LZ4_LIB_SUFFIX}
|
|
+ PATH_SUFFIXES "lib")
|
|
+
|
|
+if (LZ4_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR LZ4_LIBRARIES))
|
|
+ set(LZ4_FOUND TRUE)
|
|
+ get_filename_component( LZ4_LIBS ${LZ4_LIBRARIES} PATH )
|
|
+ set(LZ4_HEADER_NAME lz4.h)
|
|
+ set(LZ4_HEADER ${LZ4_INCLUDE_DIR}/${LZ4_HEADER_NAME})
|
|
+ set(LZ4_STATIC_LIB ${LZ4_LIBRARIES})
|
|
+ set(LZ4_SHARED_LIB ${LZ4_LIBRARIES})
|
|
+else ()
|
|
+ set(LZ4_FOUND FALSE)
|
|
+endif ()
|
|
+
|
|
+if (LZ4_FOUND)
|
|
+ message(STATUS "Found the LZ4 library: ${LZ4_LIBRARIES}")
|
|
+else ()
|
|
+ message(FATAL_ERROR "Could not find the LZ4 library.")
|
|
+endif ()
|
|
+
|
|
+mark_as_advanced(
|
|
+ LZ4_INCLUDE_DIR
|
|
+ LZ4_LIBS
|
|
+ LZ4_LIBRARIES
|
|
+ LZ4_STATIC_LIB
|
|
+ LZ4_SHARED_LIB
|
|
+)
|
|
diff --git a/cmake_modules/FindSnappy.cmake b/cmake_modules/FindSnappy.cmake
|
|
index 867963c..cc68688 100644
|
|
--- a/cmake_modules/FindSnappy.cmake
|
|
+++ b/cmake_modules/FindSnappy.cmake
|
|
@@ -17,13 +17,6 @@
|
|
#
|
|
# find_package(Snappy)
|
|
#
|
|
-# Variables used by this module, they can change the default behaviour and need
|
|
-# to be set before calling find_package:
|
|
-#
|
|
-# Snappy_HOME - When set, this path is inspected instead of standard library
|
|
-# locations as the root of the Snappy installation.
|
|
-# The environment variable SNAPPY_HOME overrides this variable.
|
|
-#
|
|
# This module defines
|
|
# SNAPPY_INCLUDE_DIR, directory containing headers
|
|
# SNAPPY_LIBS, directory containing snappy libraries
|
|
@@ -31,22 +24,16 @@
|
|
# SNAPPY_SHARED_LIB, path to libsnappy's shared library
|
|
# SNAPPY_FOUND, whether snappy has been found
|
|
|
|
-if( NOT "${SNAPPY_HOME}" STREQUAL "")
|
|
- file( TO_CMAKE_PATH "${SNAPPY_HOME}" _native_path )
|
|
- list( APPEND _snappy_roots ${_native_path} )
|
|
-elseif ( Snappy_HOME )
|
|
- list( APPEND _snappy_roots ${Snappy_HOME} )
|
|
-endif()
|
|
-
|
|
-message(STATUS "SNAPPY_HOME: ${SNAPPY_HOME}")
|
|
-find_path(SNAPPY_INCLUDE_DIR snappy.h HINTS
|
|
- ${_snappy_roots}
|
|
- NO_DEFAULT_PATH
|
|
+find_path(SNAPPY_INCLUDE_DIR snappy.h
|
|
PATH_SUFFIXES "include")
|
|
+
|
|
+if(CMAKE_BUILD_TYPE STREQUAL "DEBUG")
|
|
+ set(SNAPPY_LIB_SUFFIX "d")
|
|
+else()
|
|
+ set(SNAPPY_LIB_SUFFIX "")
|
|
+endif()
|
|
|
|
-find_library( SNAPPY_LIBRARIES NAMES snappy PATHS
|
|
- ${_snappy_roots}
|
|
- NO_DEFAULT_PATH
|
|
+find_library( SNAPPY_LIBRARIES NAMES snappy${SNAPPY_LIB_SUFFIX}
|
|
PATH_SUFFIXES "lib")
|
|
|
|
if (SNAPPY_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR SNAPPY_LIBRARIES))
|
|
@@ -54,9 +41,8 @@ if (SNAPPY_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR SNAPPY_LIBRARIES))
|
|
get_filename_component( SNAPPY_LIBS ${SNAPPY_LIBRARIES} PATH )
|
|
set(SNAPPY_HEADER_NAME snappy.h)
|
|
set(SNAPPY_HEADER ${SNAPPY_INCLUDE_DIR}/${SNAPPY_HEADER_NAME})
|
|
- set(SNAPPY_LIB_NAME snappy)
|
|
- set(SNAPPY_STATIC_LIB ${SNAPPY_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${SNAPPY_LIB_NAME}${SNAPPY_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(SNAPPY_SHARED_LIB ${SNAPPY_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${SNAPPY_LIB_NAME}${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
+ set(SNAPPY_STATIC_LIB ${SNAPPY_LIBRARIES})
|
|
+ set(SNAPPY_SHARED_LIB ${SNAPPY_LIBRARIES})
|
|
else ()
|
|
set(SNAPPY_FOUND FALSE)
|
|
endif ()
|
|
diff --git a/cmake_modules/FindThrift.cmake b/cmake_modules/FindThrift.cmake
|
|
index 25f5082..f27857f 100644
|
|
--- a/cmake_modules/FindThrift.cmake
|
|
+++ b/cmake_modules/FindThrift.cmake
|
|
@@ -14,55 +14,28 @@
|
|
|
|
# - Find Thrift (a cross platform RPC lib/tool)
|
|
#
|
|
-# Variables used by this module, they can change the default behaviour and need
|
|
-# to be set before calling find_package:
|
|
-#
|
|
-# Thrift_HOME - When set, this path is inspected instead of standard library
|
|
-# locations as the root of the Thrift installation.
|
|
-# The environment variable THRIFT_HOME overrides this variable.
|
|
-#
|
|
# This module defines
|
|
# THRIFT_VERSION, version string of ant if found
|
|
# THRIFT_INCLUDE_DIR, where to find THRIFT headers
|
|
-# THRIFT_CONTRIB_DIR, where contrib thrift files (e.g. fb303.thrift) are installed
|
|
# THRIFT_STATIC_LIB, THRIFT static library
|
|
# THRIFT_FOUND, If false, do not try to use ant
|
|
|
|
-# prefer the thrift version supplied in THRIFT_HOME
|
|
-if( NOT "${THRIFT_HOME}" STREQUAL "")
|
|
- file( TO_CMAKE_PATH "${THRIFT_HOME}" _native_path )
|
|
- list( APPEND _thrift_roots ${_native_path} )
|
|
-elseif ( Thrift_HOME )
|
|
- list( APPEND _thrift_roots ${Thrift_HOME} )
|
|
-endif()
|
|
-
|
|
-message(STATUS "THRIFT_HOME: ${THRIFT_HOME}")
|
|
-find_path(THRIFT_INCLUDE_DIR thrift/Thrift.h HINTS
|
|
- ${_thrift_roots}
|
|
- NO_DEFAULT_PATH
|
|
+find_path(THRIFT_INCLUDE_DIR thrift/Thrift.h
|
|
PATH_SUFFIXES "include"
|
|
)
|
|
|
|
-find_path(THRIFT_CONTRIB_DIR share/fb303/if/fb303.thrift HINTS
|
|
- ${_thrift_roots}
|
|
- NO_DEFAULT_PATH
|
|
-)
|
|
-
|
|
-if (MSVC AND NOT THRIFT_MSVC_STATIC_LIB_SUFFIX)
|
|
- set(THRIFT_MSVC_STATIC_LIB_SUFFIX md)
|
|
+if(CMAKE_BUILD_TYPE STREQUAL "DEBUG")
|
|
+ set(THRIFT_LIB_SUFFIX mdd)
|
|
+else()
|
|
+ set(THRIFT_LIB_SUFFIX md)
|
|
endif()
|
|
|
|
find_library(THRIFT_STATIC_LIB NAMES
|
|
- ${CMAKE_STATIC_LIBRARY_PREFIX}thrift${THRIFT_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX}
|
|
- HINTS ${_thrift_roots}
|
|
- NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib/${CMAKE_LIBRARY_ARCHITECTURE}" "lib"
|
|
+ thrift${THRIFT_LIB_SUFFIX}
|
|
)
|
|
|
|
find_program(THRIFT_COMPILER thrift HINTS
|
|
- ${_thrift_roots}
|
|
- NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "bin"
|
|
+ PATH_SUFFIXES "tools"
|
|
)
|
|
|
|
if (THRIFT_STATIC_LIB)
|
|
@@ -94,7 +67,6 @@ else ()
|
|
endif ()
|
|
endif ()
|
|
|
|
-
|
|
mark_as_advanced(
|
|
THRIFT_STATIC_LIB
|
|
THRIFT_COMPILER
|
|
diff --git a/cmake_modules/FindZLIB.cmake b/cmake_modules/FindZLIB.cmake
|
|
index 78b84f2..1ef0305 100644
|
|
--- a/cmake_modules/FindZLIB.cmake
|
|
+++ b/cmake_modules/FindZLIB.cmake
|
|
@@ -32,27 +32,17 @@
|
|
# ZLIB_SHARED_LIB, path to libz's shared library
|
|
# ZLIB_FOUND, whether zlib has been found
|
|
|
|
-if( NOT "${ZLIB_HOME}" STREQUAL "")
|
|
- file( TO_CMAKE_PATH "${ZLIB_HOME}" _native_path )
|
|
- list( APPEND _zlib_roots ${_native_path} )
|
|
-elseif ( ZLIB_HOME )
|
|
- list( APPEND _zlib_roots ${ZLIB_HOME} )
|
|
+find_path( ZLIB_INCLUDE_DIR NAMES zlib.h
|
|
+ PATH_SUFFIXES "include" )
|
|
+
|
|
+if(CMAKE_BUILD_TYPE STREQUAL "DEBUG")
|
|
+ set(ZLIB_LIB_SUFFIX "d")
|
|
+else()
|
|
+ set(ZLIB_LIB_SUFFIX "")
|
|
endif()
|
|
-
|
|
-# Try the parameterized roots, if they exist
|
|
-if ( _zlib_roots )
|
|
- find_path( ZLIB_INCLUDE_DIR NAMES zlib.h
|
|
- PATHS ${_zlib_roots} NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "include" )
|
|
- find_library( ZLIB_LIBRARIES NAMES libz.a zlib
|
|
- PATHS ${_zlib_roots} NO_DEFAULT_PATH
|
|
- PATH_SUFFIXES "lib" )
|
|
-else ()
|
|
- find_path( ZLIB_INCLUDE_DIR NAMES zlib.h )
|
|
- # Only look for the static library
|
|
- find_library( ZLIB_LIBRARIES NAMES libz.a zlib )
|
|
-endif ()
|
|
-
|
|
+
|
|
+find_library( ZLIB_LIBRARIES NAMES libz.a zlib${ZLIB_LIB_SUFFIX}
|
|
+ PATH_SUFFIXES "lib" )
|
|
|
|
if (ZLIB_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR ZLIB_LIBRARIES))
|
|
set(ZLIB_FOUND TRUE)
|
|
@@ -66,8 +56,8 @@ if (ZLIB_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR ZLIB_LIBRARIES))
|
|
endif()
|
|
set(ZLIB_MSVC_SHARED_LIB_SUFFIX lib)
|
|
endif()
|
|
- set(ZLIB_STATIC_LIB ${ZLIB_LIBS}/${CMAKE_STATIC_LIBRARY_PREFIX}${ZLIB_LIB_NAME}${ZLIB_MSVC_STATIC_LIB_SUFFIX}${CMAKE_STATIC_LIBRARY_SUFFIX})
|
|
- set(ZLIB_SHARED_LIB ${ZLIB_LIBS}/${CMAKE_SHARED_LIBRARY_PREFIX}${ZLIB_LIB_NAME}${ZLIB_MSVC_SHARED_LIB_SUFFIX}${CMAKE_SHARED_LIBRARY_SUFFIX})
|
|
+ set(ZLIB_STATIC_LIB ${ZLIB_LIBRARIES})
|
|
+ set(ZLIB_SHARED_LIB ${ZLIB_LIBRARIES})
|
|
else ()
|
|
set(ZLIB_FOUND FALSE)
|
|
endif ()
|
|
diff --git a/cmake_modules/FindZSTD.cmake b/cmake_modules/FindZSTD.cmake
|
|
new file mode 100644
|
|
index 0000000..062cfa9
|
|
--- /dev/null
|
|
+++ b/cmake_modules/FindZSTD.cmake
|
|
@@ -0,0 +1,62 @@
|
|
+#
|
|
+# Licensed under the Apache License, Version 2.0 (the "License");
|
|
+# you may not use this file except in compliance with the License.
|
|
+# You may obtain a copy of the License at
|
|
+#
|
|
+# http://www.apache.org/licenses/LICENSE-2.0
|
|
+#
|
|
+# Unless required by applicable law or agreed to in writing, software
|
|
+# distributed under the License is distributed on an "AS IS" BASIS,
|
|
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
+# See the License for the specific language governing permissions and
|
|
+# limitations under the License.
|
|
+#
|
|
+# Tries to find ZSTD headers and libraries.
|
|
+#
|
|
+# Usage of this module as follows:
|
|
+#
|
|
+# find_package(Snappy)
|
|
+#
|
|
+# This module defines
|
|
+# ZSTD_INCLUDE_DIR, directory containing headers
|
|
+# ZSTD_LIBS, directory containing ZSTD libraries
|
|
+# ZSTD_STATIC_LIB, path to zstd.a
|
|
+# ZSTD_SHARED_LIB, path to ZSTD's shared library
|
|
+# ZSTD_FOUND, whether ZSTD has been found
|
|
+
|
|
+find_path(ZSTD_INCLUDE_DIR ZSTD.h
|
|
+ PATH_SUFFIXES "include")
|
|
+
|
|
+if(CMAKE_BUILD_TYPE STREQUAL "DEBUG")
|
|
+ set(ZSTD_LIB_SUFFIX "d")
|
|
+else()
|
|
+ set(ZSTD_LIB_SUFFIX "")
|
|
+endif()
|
|
+
|
|
+find_library( ZSTD_LIBRARIES NAMES zstd${ZSTD_LIB_SUFFIX} zstd_static${ZSTD_LIB_SUFFIX}
|
|
+ PATH_SUFFIXES "lib")
|
|
+
|
|
+if (ZSTD_INCLUDE_DIR AND (PARQUET_MINIMAL_DEPENDENCY OR ZSTD_LIBRARIES))
|
|
+ set(ZSTD_FOUND TRUE)
|
|
+ get_filename_component( ZSTD_LIBS ${ZSTD_LIBRARIES} PATH )
|
|
+ set(ZSTD_HEADER_NAME zstd.h)
|
|
+ set(ZSTD_HEADER ${ZSTD_INCLUDE_DIR}/${ZSTD_HEADER_NAME})
|
|
+ set(ZSTD_STATIC_LIB ${ZSTD_LIBRARIES})
|
|
+ set(ZSTD_SHARED_LIB ${ZSTD_LIBRARIES})
|
|
+else ()
|
|
+ set(ZSTD_FOUND FALSE)
|
|
+endif ()
|
|
+
|
|
+if (ZSTD_FOUND)
|
|
+ message(STATUS "Found the ZSTD library: ${ZSTD_LIBRARIES}")
|
|
+else ()
|
|
+ message(FATAL_ERROR "Could not find the ZSTD library.")
|
|
+endif ()
|
|
+
|
|
+mark_as_advanced(
|
|
+ ZSTD_INCLUDE_DIR
|
|
+ ZSTD_LIBS
|
|
+ ZSTD_LIBRARIES
|
|
+ ZSTD_STATIC_LIB
|
|
+ ZSTD_SHARED_LIB
|
|
+)
|
|
diff --git a/cmake_modules/ThirdpartyToolchain.cmake b/cmake_modules/ThirdpartyToolchain.cmake
|
|
index 690fd0b..d74bb3d 100644
|
|
--- a/cmake_modules/ThirdpartyToolchain.cmake
|
|
+++ b/cmake_modules/ThirdpartyToolchain.cmake
|
|
@@ -276,54 +276,11 @@ endif()
|
|
if(PARQUET_BUILD_TESTS AND NOT IGNORE_OPTIONAL_PACKAGES)
|
|
add_custom_target(unittest ctest -L unittest)
|
|
|
|
- if("$ENV{GTEST_HOME}" STREQUAL "")
|
|
- if(APPLE)
|
|
- set(GTEST_CMAKE_CXX_FLAGS "${EP_CXX_FLAGS} -DGTEST_USE_OWN_TR1_TUPLE=1 -Wno-unused-value -Wno-ignored-attributes")
|
|
- else()
|
|
- set(GTEST_CMAKE_CXX_FLAGS "${EP_CXX_FLAGS}")
|
|
- endif()
|
|
-
|
|
- set(GTEST_PREFIX "${CMAKE_CURRENT_BINARY_DIR}/googletest_ep-prefix/src/googletest_ep")
|
|
- set(GTEST_INCLUDE_DIR "${GTEST_PREFIX}/include")
|
|
- set(GTEST_STATIC_LIB
|
|
- "${GTEST_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}gtest${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
|
- set(GTEST_MAIN_STATIC_LIB
|
|
- "${GTEST_PREFIX}/lib/${CMAKE_STATIC_LIBRARY_PREFIX}gtest_main${CMAKE_STATIC_LIBRARY_SUFFIX}")
|
|
-
|
|
- set(GTEST_CMAKE_ARGS -DCMAKE_BUILD_TYPE=${CMAKE_BUILD_TYPE}
|
|
- -DCMAKE_INSTALL_PREFIX=${GTEST_PREFIX}
|
|
- -DCMAKE_CXX_FLAGS=${GTEST_CMAKE_CXX_FLAGS})
|
|
-
|
|
- if (MSVC AND NOT PARQUET_USE_STATIC_CRT)
|
|
- set(GTEST_CMAKE_ARGS ${GTEST_CMAKE_ARGS} -Dgtest_force_shared_crt=ON)
|
|
- endif()
|
|
-
|
|
- ExternalProject_Add(googletest_ep
|
|
- URL "https://github.com/google/googletest/archive/release-${GTEST_VERSION}.tar.gz"
|
|
- BUILD_BYPRODUCTS "${GTEST_STATIC_LIB}" "${GTEST_MAIN_STATIC_LIB}"
|
|
- CMAKE_ARGS ${GTEST_CMAKE_ARGS}
|
|
- ${EP_LOG_OPTIONS})
|
|
- set(GTEST_VENDORED 1)
|
|
- else()
|
|
- find_package(GTest REQUIRED)
|
|
- set(GTEST_VENDORED 0)
|
|
- endif()
|
|
+ find_package(GTest REQUIRED)
|
|
+ include_directories(SYSTEM ${GTEST_INCLUDE_DIR})
|
|
|
|
message(STATUS "GTest include dir: ${GTEST_INCLUDE_DIR}")
|
|
message(STATUS "GTest static library: ${GTEST_STATIC_LIB}")
|
|
- include_directories(SYSTEM ${GTEST_INCLUDE_DIR})
|
|
-
|
|
- add_library(gtest STATIC IMPORTED)
|
|
- set_target_properties(gtest PROPERTIES IMPORTED_LOCATION ${GTEST_STATIC_LIB})
|
|
-
|
|
- add_library(gtest_main STATIC IMPORTED)
|
|
- set_target_properties(gtest_main PROPERTIES IMPORTED_LOCATION
|
|
- ${GTEST_MAIN_STATIC_LIB})
|
|
-
|
|
- if(GTEST_VENDORED)
|
|
- add_dependencies(gtest googletest_ep)
|
|
- add_dependencies(gtest_main googletest_ep)
|
|
- endif()
|
|
endif()
|
|
|
|
## Google Benchmark
|