mirror of https://github.com/ByConity/ByConity
457 lines
13 KiB
CMake
457 lines
13 KiB
CMake
# Put all targets defined here and in added subfolders under "contrib/" folder in GUI-based IDEs by default.
|
|
# Some of third-party projects may override CMAKE_FOLDER or FOLDER property of their targets, so they will
|
|
# appear not in "contrib/" as originally planned here.
|
|
get_filename_component (_current_dir_name "${CMAKE_CURRENT_LIST_DIR}" NAME)
|
|
if (CMAKE_FOLDER)
|
|
set (CMAKE_FOLDER "${CMAKE_FOLDER}/${_current_dir_name}")
|
|
else ()
|
|
set (CMAKE_FOLDER "${_current_dir_name}")
|
|
endif ()
|
|
unset (_current_dir_name)
|
|
|
|
# Third-party libraries may have substandard code.
|
|
# Also remove a possible source of nondeterminism.
|
|
set (CMAKE_C_FLAGS "-w -Wno-implicit-function-declaration ${CMAKE_C_FLAGS} -D__DATE__= -D__TIME__= -D__TIMESTAMP__=")
|
|
set (CMAKE_CXX_FLAGS "-w -Wno-implicit-function-declaration ${CMAKE_CXX_FLAGS} -D__DATE__= -D__TIME__= -D__TIMESTAMP__=")
|
|
|
|
# add_contrib cmake_folder[ base_folder1[, ...base_folderN]]
|
|
function(add_contrib cmake_folder)
|
|
if (ARGN)
|
|
set(base_folders ${ARGN})
|
|
else()
|
|
set(base_folders ${cmake_folder})
|
|
endif()
|
|
|
|
foreach (base_folder ${base_folders})
|
|
# some typos in the code
|
|
if (NOT IS_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/${base_folder}")
|
|
message(FATAL_ERROR "No such base folder '${base_folder}' (for '${cmake_folder}' cmake folder). Typo in the base folder name?")
|
|
endif()
|
|
|
|
file(GLOB contrib_files "${base_folder}/*")
|
|
if (NOT contrib_files)
|
|
# Checking out *all* submodules takes > 5 min. Therefore, the smoke build ("FastTest") in CI initializes only the set of
|
|
# submodules minimally needed for a build and we cannot assume here that all submodules are populated.
|
|
message(STATUS "submodule ${base_folder} is missing or empty. to fix try run:")
|
|
message(STATUS " git submodule update --init")
|
|
return()
|
|
endif()
|
|
endforeach()
|
|
|
|
message(STATUS "Adding contrib module ${base_folders} (configuring with ${cmake_folder})")
|
|
add_subdirectory (${cmake_folder})
|
|
endfunction()
|
|
|
|
if (WITH_COVERAGE)
|
|
set (WITHOUT_COVERAGE_LIST ${WITHOUT_COVERAGE})
|
|
separate_arguments(WITHOUT_COVERAGE_LIST)
|
|
# disable coverage for contib files and build with optimisations
|
|
if (COMPILER_CLANG)
|
|
add_compile_options(-O3 -DNDEBUG -finline-functions -finline-hint-functions ${WITHOUT_COVERAGE_LIST})
|
|
else()
|
|
add_compile_options(-O3 -DNDEBUG -finline-functions ${WITHOUT_COVERAGE_LIST})
|
|
endif()
|
|
endif()
|
|
|
|
if (SANITIZE STREQUAL "undefined")
|
|
# 3rd-party libraries usually not intended to work with UBSan.
|
|
add_compile_options(-fno-sanitize=undefined)
|
|
endif()
|
|
|
|
set_property(DIRECTORY PROPERTY EXCLUDE_FROM_ALL 1)
|
|
|
|
add_subdirectory (abseil-cpp-cmake)
|
|
add_subdirectory (magic-enum-cmake)
|
|
add_subdirectory (boost-cmake)
|
|
add_subdirectory (cctz-cmake)
|
|
add_subdirectory (consistent-hashing)
|
|
add_subdirectory (dragonbox-cmake)
|
|
add_subdirectory (hyperscan-cmake)
|
|
add_subdirectory (jemalloc-cmake)
|
|
add_subdirectory (libcpuid-cmake)
|
|
add_subdirectory (libdivide)
|
|
add_subdirectory (libmetrohash)
|
|
add_subdirectory (lz4-cmake)
|
|
add_subdirectory (murmurhash)
|
|
add_subdirectory (replxx-cmake)
|
|
add_subdirectory (unixodbc-cmake)
|
|
add_subdirectory (nanodbc-cmake)
|
|
add_subdirectory (jsonc-cmake)
|
|
add_subdirectory (ipdb-cmake)
|
|
add_subdirectory (maxminddb-cmake)
|
|
add_subdirectory (liburing-cmake)
|
|
add_subdirectory (libevent-cmake)
|
|
add_subdirectory (glog-cmake)
|
|
add_subdirectory (folly-cmake)
|
|
|
|
if (USE_LIBDEFLATE)
|
|
add_subdirectory (libdeflate-cmake)
|
|
endif()
|
|
|
|
if (USE_YAML_CPP)
|
|
add_subdirectory (yaml-cpp-cmake)
|
|
endif()
|
|
|
|
if (USE_INTERNAL_XZ_LIBRARY)
|
|
add_subdirectory (xz)
|
|
endif()
|
|
|
|
add_subdirectory (poco-cmake)
|
|
add_subdirectory (croaring-cmake)
|
|
|
|
# TODO: refactor the contrib libraries below this comment.
|
|
|
|
if (USE_INTERNAL_ZSTD_LIBRARY)
|
|
add_subdirectory (zstd-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_RE2_LIBRARY)
|
|
set(RE2_BUILD_TESTING 0 CACHE INTERNAL "")
|
|
add_subdirectory (re2-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_DOUBLE_CONVERSION_LIBRARY)
|
|
add_subdirectory (double-conversion-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_CITYHASH_LIBRARY)
|
|
add_subdirectory (cityhash102)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_FARMHASH_LIBRARY)
|
|
add_subdirectory (libfarmhash)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_ZLIB_LIBRARY)
|
|
set (ZLIB_ENABLE_TESTS 0 CACHE INTERNAL "")
|
|
set (SKIP_INSTALL_ALL 1 CACHE INTERNAL "")
|
|
set (ZLIB_COMPAT 1 CACHE INTERNAL "") # also enables WITH_GZFILEOP
|
|
set (WITH_NATIVE_INSTRUCTIONS ${ARCH_NATIVE} CACHE INTERNAL "")
|
|
if (OS_FREEBSD OR ARCH_I386)
|
|
set (WITH_OPTIM 0 CACHE INTERNAL "") # Bug in assembler
|
|
endif ()
|
|
if (ARCH_AARCH64)
|
|
set(WITH_NEON 1 CACHE INTERNAL "")
|
|
set(WITH_ACLE 1 CACHE INTERNAL "")
|
|
endif ()
|
|
|
|
add_subdirectory (${INTERNAL_ZLIB_NAME})
|
|
# We should use same defines when including zlib.h as used when zlib compiled
|
|
target_compile_definitions (zlib PUBLIC ZLIB_COMPAT WITH_GZFILEOP)
|
|
if (ARCH_AMD64 OR ARCH_AARCH64)
|
|
target_compile_definitions (zlib PUBLIC X86_64 UNALIGNED_OK)
|
|
endif ()
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_H3_LIBRARY)
|
|
add_subdirectory(h3-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_SSL_LIBRARY)
|
|
add_subdirectory (boringssl-cmake)
|
|
|
|
add_library(OpenSSL::Crypto ALIAS crypto)
|
|
add_library(OpenSSL::SSL ALIAS ssl)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_LDAP_LIBRARY)
|
|
add_subdirectory (openldap-cmake)
|
|
endif ()
|
|
|
|
function(mysql_support)
|
|
set(CLIENT_PLUGIN_CACHING_SHA2_PASSWORD STATIC)
|
|
set(CLIENT_PLUGIN_SHA256_PASSWORD STATIC)
|
|
set(CLIENT_PLUGIN_REMOTE_IO OFF)
|
|
set(CLIENT_PLUGIN_DIALOG OFF)
|
|
set(CLIENT_PLUGIN_AUTH_GSSAPI_CLIENT OFF)
|
|
set(CLIENT_PLUGIN_CLIENT_ED25519 OFF)
|
|
set(CLIENT_PLUGIN_MYSQL_CLEAR_PASSWORD OFF)
|
|
set(SKIP_TESTS 1)
|
|
if (GLIBC_COMPATIBILITY)
|
|
set(LIBM glibc-compatibility)
|
|
endif()
|
|
if (USE_INTERNAL_ZLIB_LIBRARY)
|
|
set(ZLIB_FOUND ON)
|
|
set(ZLIB_LIBRARY ${ZLIB_LIBRARIES})
|
|
set(WITH_EXTERNAL_ZLIB ON)
|
|
endif()
|
|
set(WITH_CURL OFF)
|
|
add_subdirectory (mariadb-connector-c)
|
|
endfunction()
|
|
if (ENABLE_MYSQL AND USE_INTERNAL_MYSQL_LIBRARY)
|
|
mysql_support()
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_MINIZIP_LIBRARY)
|
|
add_subdirectory(minizip)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_UDNS_LIBRARY)
|
|
add_subdirectory(udns-cmake)
|
|
endif ()
|
|
|
|
|
|
add_subdirectory (librdkafka-cmake)
|
|
target_include_directories(rdkafka BEFORE PRIVATE ${ZLIB_INCLUDE_DIR})
|
|
if(OPENSSL_INCLUDE_DIR)
|
|
target_include_directories(rdkafka BEFORE PRIVATE ${OPENSSL_INCLUDE_DIR})
|
|
endif()
|
|
|
|
if (USE_RDKAFKA)
|
|
add_subdirectory (cppkafka-cmake)
|
|
endif()
|
|
|
|
if (ENABLE_ICU AND USE_INTERNAL_ICU_LIBRARY)
|
|
add_subdirectory (icu-cmake)
|
|
endif ()
|
|
|
|
if(USE_INTERNAL_SNAPPY_LIBRARY)
|
|
set(SNAPPY_BUILD_TESTS 0 CACHE INTERNAL "")
|
|
|
|
add_subdirectory(snappy)
|
|
|
|
set (SNAPPY_INCLUDE_DIR "${ClickHouse_SOURCE_DIR}/contrib/snappy")
|
|
endif()
|
|
|
|
if (USE_INTERNAL_PARQUET_LIBRARY)
|
|
# We dont use arrow's cmakefiles because they uses too many depends and download some libs in compile time
|
|
# But you can update auto-generated parquet files manually:
|
|
# cd {BUILD_DIR}/contrib/arrow/cpp/src/parquet && mkdir -p build && cd build
|
|
# cmake .. -DARROW_COMPUTE=ON -DARROW_PARQUET=ON -DARROW_SIMD_LEVEL=NONE -DARROW_VERBOSE_THIRDPARTY_BUILD=ON
|
|
# -DARROW_BUILD_SHARED=1 -DARROW_BUILD_UTILITIES=OFF -DARROW_BUILD_INTEGRATION=OFF
|
|
# -DBoost_FOUND=1 -DARROW_TEST_LINKAGE="shared"
|
|
# make -j8
|
|
# copy {BUILD_DIR}/contrib/arrow/cpp/src/parquet/*.cpp,*.h -> {BUILD_DIR}/contrib/arrow-cmake/cpp/src/parquet/
|
|
|
|
# Also useful parquet reader:
|
|
# cd {BUILD_DIR}/contrib/arrow/cpp && mkdir -p build && cd build
|
|
# cmake .. -DARROW_PARQUET=1 -DARROW_WITH_SNAPPY=1 -DPARQUET_BUILD_EXECUTABLES=1
|
|
# make -j8
|
|
# {BUILD_DIR}/contrib/arrow/cpp/build/release/parquet-reader some_file.parquet
|
|
|
|
add_subdirectory(arrow-cmake)
|
|
|
|
# The library is large - avoid bloat.
|
|
if( NOT (CMAKE_BUILD_TYPE STREQUAL "Debug"))
|
|
target_compile_options (${ARROW_LIBRARY} PRIVATE -g0)
|
|
target_compile_options (${THRIFT_LIBRARY} PRIVATE -g0)
|
|
target_compile_options (${PARQUET_LIBRARY} PRIVATE -g0)
|
|
endif()
|
|
endif()
|
|
|
|
if (USE_INTERNAL_AVRO_LIBRARY)
|
|
add_subdirectory(avro-cmake)
|
|
endif()
|
|
|
|
if(USE_INTERNAL_GTEST_LIBRARY)
|
|
set(GOOGLETEST_VERSION 1.10.0) # master
|
|
# Google Test from sources
|
|
add_subdirectory(${ClickHouse_SOURCE_DIR}/contrib/googletest ${CMAKE_CURRENT_BINARY_DIR}/googletest)
|
|
# avoid problems with <regexp.h>
|
|
target_compile_definitions (gtest INTERFACE GTEST_HAS_POSIX_RE=0)
|
|
target_compile_definitions (gmock INTERFACE)
|
|
elseif(GTEST_SRC_DIR)
|
|
add_subdirectory(${GTEST_SRC_DIR} ${CMAKE_CURRENT_BINARY_DIR}/googletest)
|
|
target_compile_definitions(gtest INTERFACE GTEST_HAS_POSIX_RE=0)
|
|
target_compile_definitions(gmock INTERFACE)
|
|
endif()
|
|
|
|
if (USE_EMBEDDED_COMPILER)
|
|
# ld: unknown option: --color-diagnostics
|
|
if (APPLE)
|
|
set (LINKER_SUPPORTS_COLOR_DIAGNOSTICS 0 CACHE INTERNAL "")
|
|
endif ()
|
|
|
|
set (LLVM_ENABLE_EH 1 CACHE INTERNAL "")
|
|
set (LLVM_ENABLE_RTTI 1 CACHE INTERNAL "")
|
|
set (LLVM_ENABLE_PIC 0 CACHE INTERNAL "")
|
|
set (LLVM_TARGETS_TO_BUILD "X86;AArch64" CACHE STRING "")
|
|
|
|
# Need to use C++17 since the compilation is not possible with C++20 currently, due to ambiguous operator != etc.
|
|
# LLVM project will set its default value for the -std=... but our global setting from CMake will override it.
|
|
set (CMAKE_CXX_STANDARD_bak ${CMAKE_CXX_STANDARD})
|
|
set (CMAKE_CXX_STANDARD 17)
|
|
|
|
add_subdirectory (llvm/llvm)
|
|
|
|
set (CMAKE_CXX_STANDARD ${CMAKE_CXX_STANDARD_bak})
|
|
unset (CMAKE_CXX_STANDARD_bak)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_LIBGSASL_LIBRARY)
|
|
add_subdirectory(libgsasl)
|
|
endif()
|
|
|
|
if (USE_INTERNAL_LIBXML2_LIBRARY)
|
|
add_subdirectory(libxml2-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_BROTLI_LIBRARY)
|
|
add_subdirectory(brotli-cmake)
|
|
target_compile_definitions(brotli PRIVATE BROTLI_BUILD_PORTABLE=1)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_PROTOBUF_LIBRARY)
|
|
set(HAVE_ZLIB 1)
|
|
add_subdirectory(protobuf-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_HDFS3_LIBRARY)
|
|
add_subdirectory(libhdfs3-open-cmake)
|
|
endif ()
|
|
|
|
if (USE_INTERNAL_GRPC_LIBRARY)
|
|
add_subdirectory(grpc-cmake)
|
|
endif ()
|
|
|
|
if (ENABLE_MSGPACK)
|
|
add_library(_msgpack INTERFACE)
|
|
target_include_directories(_msgpack SYSTEM BEFORE INTERFACE "${ClickHouse_SOURCE_DIR}/contrib/msgpack-c/include")
|
|
add_library(ch_contrib::msgpack ALIAS _msgpack)
|
|
endif()
|
|
|
|
add_contrib (aws-cmake
|
|
aws
|
|
aws-c-auth
|
|
aws-c-cal
|
|
aws-c-common
|
|
aws-c-compression
|
|
aws-c-event-stream
|
|
aws-c-http
|
|
aws-c-io
|
|
aws-c-mqtt
|
|
aws-c-s3
|
|
aws-c-sdkutils
|
|
aws-s2n-tls
|
|
aws-checksums
|
|
aws-crt-cpp
|
|
aws-cmake
|
|
)
|
|
|
|
add_subdirectory(corrosion-cmake)
|
|
|
|
if (USE_BASE64)
|
|
add_subdirectory (base64-cmake)
|
|
endif()
|
|
|
|
if (USE_SIMDJSON)
|
|
add_subdirectory (simdjson-cmake)
|
|
endif()
|
|
|
|
if (USE_RAPIDJSON)
|
|
add_subdirectory (rapidjson-cmake)
|
|
endif()
|
|
|
|
if (USE_BREAKPAD)
|
|
add_subdirectory(breakpad-cmake)
|
|
endif()
|
|
|
|
if (USE_FASTOPS)
|
|
add_subdirectory (fastops-cmake)
|
|
endif()
|
|
|
|
if (USE_AMQPCPP OR USE_CASSANDRA)
|
|
add_subdirectory (libuv)
|
|
endif()
|
|
if (USE_AMQPCPP)
|
|
add_subdirectory (amqpcpp-cmake)
|
|
endif()
|
|
if (USE_CASSANDRA)
|
|
# Need to use C++17 since the compilation is not possible with C++20 currently.
|
|
set (CMAKE_CXX_STANDARD_bak ${CMAKE_CXX_STANDARD})
|
|
set (CMAKE_CXX_STANDARD 17)
|
|
|
|
add_subdirectory (cassandra)
|
|
|
|
set (CMAKE_CXX_STANDARD ${CMAKE_CXX_STANDARD_bak})
|
|
unset (CMAKE_CXX_STANDARD_bak)
|
|
endif()
|
|
|
|
# Should go before:
|
|
# - sentry-native
|
|
add_subdirectory (curl-cmake)
|
|
|
|
if (USE_SENTRY)
|
|
add_subdirectory (sentry-native)
|
|
endif()
|
|
|
|
add_subdirectory (fmtlib-cmake)
|
|
|
|
if (USE_STATS)
|
|
add_subdirectory (stats-cmake)
|
|
add_subdirectory (gcem)
|
|
endif()
|
|
|
|
if (USE_KRB5)
|
|
add_subdirectory (krb5-cmake)
|
|
if (USE_CYRUS_SASL)
|
|
add_subdirectory (cyrus-sasl-cmake)
|
|
endif()
|
|
endif()
|
|
|
|
if (USE_INTERNAL_ROCKSDB_LIBRARY)
|
|
add_subdirectory(rocksdb-cmake)
|
|
endif()
|
|
|
|
if (USE_LIBPQXX)
|
|
add_subdirectory (libpq-cmake)
|
|
add_subdirectory (libpqxx-cmake)
|
|
endif()
|
|
|
|
if (USE_NURAFT)
|
|
add_subdirectory(nuraft-cmake)
|
|
endif()
|
|
|
|
if (USE_INTERNAL_GFLAGS_LIBRARY)
|
|
add_subdirectory (gflags)
|
|
endif ()
|
|
|
|
add_subdirectory(fast_float)
|
|
|
|
|
|
# Check Clang version and add -Wno-unused-but-set-variable if Clang version is 15 or higher
|
|
if(${CMAKE_CXX_COMPILER_VERSION} VERSION_GREATER_EQUAL 15)
|
|
add_compile_options(-Wno-unused-but-set-variable)
|
|
endif()
|
|
add_subdirectory(incubator-brpc)
|
|
if(OPENSSL_INCLUDE_DIR)
|
|
target_include_directories(brpc-static BEFORE PRIVATE ${OPENSSL_INCLUDE_DIR})
|
|
endif()
|
|
add_subdirectory(hashidsxx-cmake)
|
|
|
|
add_subdirectory(morton-nd-cmake)
|
|
|
|
add_subdirectory(xxHash-cmake)
|
|
|
|
if (ENABLE_BENCHMARK)
|
|
add_subdirectory(benchmark)
|
|
endif()
|
|
|
|
add_subdirectory(ulid-c-cmake)
|
|
add_subdirectory(hivemetastore-cmake)
|
|
add_subdirectory(wyhash-cmake)
|
|
if (USE_NLP)
|
|
add_subdirectory(libstemmer-c-cmake)
|
|
add_subdirectory(wordnet-blast-cmake)
|
|
add_subdirectory(lemmagen-c-cmake)
|
|
add_subdirectory (nlp-data-cmake)
|
|
add_subdirectory (cld2-cmake)
|
|
endif()
|
|
|
|
set(BUILD_SHARED_LIBS_BEFORE_MSGPACK ${BUILD_SHARED_LIBS})
|
|
unset (BUILD_SHARED_LIBS)
|
|
add_subdirectory(msgpack-c)
|
|
set(BUILD_SHARED_LIBS ${BUILD_SHARED_LIBS_BEFORE_MSGPACK})
|
|
unset(BUILD_SHARED_LIBS_BEFORE_MSGPACK)
|
|
if (USE_CPP_JIEBA)
|
|
add_subdirectory(cppjieba-cmake)
|
|
endif()
|
|
|
|
if (USE_TSQUERY)
|
|
add_subdirectory(TSQuery-cmake)
|
|
endif()
|
|
|
|
if (ENABLE_HUALLOC)
|
|
add_subdirectory (hualloc-cmake)
|
|
endif()
|