From: Alexander Turenko <alexander.turenko@tarantool.org>
To: Georgy Kirichenko <georgy@tarantool.org>
Cc: tarantool-patches@freelists.org
Subject: [tarantool-patches] Re: [PATCH v4] Tarantool static build ability
Date: Wed, 29 Aug 2018 14:19:46 +0300 [thread overview]
Message-ID: <20180829111941.d4sy6wm5hav647oh@tkn_work_nb> (raw)
In-Reply-To: <61ed63cef516d36d6a18b02d476bdd680e8cf516.1535522175.git.georgy@tarantool.org>
Pushed the commit with minor fixes on top of the branch.
Checked build with libcurl.a dependent on libnghttp2.a, now it works.
Checked docker build + run again after cleaning up the repository and
all images and containers, still get the error.
WBR, Alexander Turenko.
On Wed, Aug 29, 2018 at 09:08:07AM +0300, Georgy Kirichenko wrote:
> A possibility to build tarantool with included library dependencies.
> Use the flag -DBUILD_STATIC=ON to build statically against curl, readline,
> ncurses, icu and z.
> Use the flag -DOPENSSL_USE_STATIC_LIBS=ON to build with static
> openssl
>
> Changes:
> * Add FindOpenSSL.cmake because some distributions do not support the use of
> openssl static libraries.
> * Find libssl before curl because of build dependency.
> * Catch all bundled libraries API and export then it in case of static
> build.
> * Rename crc32 internal functions to avoid a name clash with linked libraries.
>
> Notes:
> * Bundled libyaml is not properly exported, use the system one.
> * Dockerfile to build static with docker is included
>
> Fixes #3445
> ---
> Changes in v4:
> - Add Z library to an openssl libraries list because of dependencies
> - Update FinxOpenSSL module
> - Minor fixes as per review by Alexander Turenko
>
> Changes in v3:
> - Fixed comments as per review by Alexander Turenko
>
> Changes in v2:
> - Fixed comments as per review by Alexander Turenko
>
> CMakeLists.txt | 60 ++---
> Dockerfile.staticbuild | 99 ++++++++
> cmake/BuildMisc.cmake | 10 +
> cmake/FindCURL.cmake | 18 +-
> cmake/FindICU.cmake | 22 +-
> cmake/FindLibYAML.cmake | 8 +-
> cmake/FindOpenSSL.cmake | 492 +++++++++++++++++++++++++++++++++++++++
> cmake/FindReadline.cmake | 23 +-
> cmake/FindTermcap.cmake | 8 +-
> cmake/FindZSTD.cmake | 7 +-
> cmake/compiler.cmake | 42 ++--
> extra/mkexports | 14 +-
> src/CMakeLists.txt | 49 +++-
> third_party/crc32.c | 6 +-
> third_party/crc32.h | 6 +-
> 15 files changed, 798 insertions(+), 66 deletions(-)
> create mode 100644 Dockerfile.staticbuild
> create mode 100644 cmake/FindOpenSSL.cmake
>
> diff --git a/CMakeLists.txt b/CMakeLists.txt
> index cea4a7d3e..71c395eb2 100644
> --- a/CMakeLists.txt
> +++ b/CMakeLists.txt
> @@ -286,6 +286,40 @@ find_package_message(MODULE_LIBPATH "Lua package.cpath: ${MODULE_LIBPATH}"
>
> add_custom_target(build_bundled_libs)
>
> +# Debian: missing zstd_static.h in libzstd-dev
> +# Fedora: not found
> +# => use bundled version by default
> +
> +option(ENABLE_BUNDLED_ZSTD "Enable building of the bundled zstd" ON)
> +if (ENABLE_BUNDLED_ZSTD)
> + include(BuildZSTD)
> + zstd_build()
> + add_dependencies(build_bundled_libs zstd)
> +else()
> + set(ZSTD_FIND_REQUIRED ON)
> + find_package(ZSTD)
> +endif()
> +
> +#
> +# OpenSSL
> +#
> +find_package(OpenSSL)
> +if (OPENSSL_FOUND)
> + message(STATUS "OpenSSL ${OPENSSL_VERSION} found")
> + include_directories(${OPENSSL_INCLUDE_DIR})
> +else()
> + message(FATAL_ERROR "Could NOT find OpenSSL development files (libssl-dev/openssl-devel package)")
> +endif()
> +
> +#
> +# OpenSSL requires Z library, so add it to libraries list
> +#
> +if(BUILD_STATIC)
> + find_library(Z_LIBRARY libz.a)
> +else()
> + find_library(Z_LIBRARY z)
> +endif()
> +set(OPENSSL_LIBRARIES ${OPENSSL_LIBRARIES} ${Z_LIBRARY})
> #
> # Curl
> #
> @@ -404,32 +438,6 @@ endif()
> # zstd
> #
>
> -# Debian: missing zstd_static.h in libzstd-dev
> -# Fedora: not found
> -# => use bundled version by default
> -
> -option(ENABLE_BUNDLED_ZSTD "Enable building of the bundled zstd" ON)
> -if (ENABLE_BUNDLED_ZSTD)
> - include(BuildZSTD)
> - zstd_build()
> - add_dependencies(build_bundled_libs zstd)
> -else()
> - set(ZSTD_FIND_REQUIRED ON)
> - find_package(ZSTD)
> -endif()
> -
> -#
> -# OpenSSL
> -#
> -
> -find_package(OpenSSL)
> -if (OPENSSL_FOUND)
> - message(STATUS "OpenSSL ${OPENSSL_VERSION} found")
> - include_directories(${OPENSSL_INCLUDE_DIR})
> -else()
> - message(FATAL_ERROR "Could NOT find OpenSSL development files (libssl-dev/openssl-devel package)")
> -endif()
> -
> #
> # Third-Party misc
> #
> diff --git a/Dockerfile.staticbuild b/Dockerfile.staticbuild
> new file mode 100644
> index 000000000..3e814c8f8
> --- /dev/null
> +++ b/Dockerfile.staticbuild
> @@ -0,0 +1,99 @@
> +FROM centos:7
> +
> +RUN yum install -y epel-release
> +RUN yum install -y yum install https://centos7.iuscommunity.org/ius-release.rpm
> +
> +RUN set -x \
> + && yum -y install \
> + libstdc++ \
> + libstdc++-static \
> + readline \
> + openssl \
> + lz4 \
> + binutils \
> + ncurses \
> + libgomp \
> + lua \
> + curl \
> + tar \
> + zip \
> + unzip \
> + libunwind \
> + libcurl \
> + && yum -y install \
> + perl \
> + gcc-c++ \
> + cmake \
> + lz4-devel \
> + binutils-devel \
> + lua-devel \
> + make \
> + git \
> + autoconf \
> + automake \
> + libtool \
> + wget
> +
> +RUN yum -y install ncurses-static readline-static zlib-static pcre-static glibc-static
> +
> +RUN set -x && \
> + cd / && \
> + curl -O -L https://www.openssl.org/source/openssl-1.1.0h.tar.gz && \
> + tar -xvf openssl-1.1.0h.tar.gz && \
> + cd openssl-1.1.0h && \
> + ./config no-shared && \
> + make && make install
> +
> +RUN set -x && \
> + cd / && \
> + git clone https://github.com/curl/curl.git && \
> + cd curl && \
> + git checkout curl-7_59_0 && \
> + ./buildconf && \
> + LIBS=" -lssl -lcrypto -ldl" ./configure --enable-static --enable-shared --with-ssl && \
> + make -j && make install
> +
> +RUN set -x && \
> + cd / && \
> + wget http://download.icu-project.org/files/icu4c/62.1/icu4c-62_1-src.tgz && \
> + tar -xvf icu4c-62_1-src.tgz && \
> + cd icu/source && \
> + ./configure --with-data-packaging=static --enable-static --enable-shared && \
> + make && make install
> +
> +RUN set -x && \
> + cd / && \
> + curl -O -L http://download.savannah.nongnu.org/releases/libunwind/libunwind-1.3-rc1.tar.gz && \
> + tar -xvf libunwind-1.3-rc1.tar.gz && \
> + cd libunwind-1.3-rc1 && \
> + ./configure --enable-static --disable-shared && \
> + make && make install
> +
> +RUN set -x && \
> + cd / && \
> + wget http://pyyaml.org/download/libyaml/yaml-0.2.1.tar.gz && \
> + tar -xvf yaml-0.2.1.tar.gz && \
> + cd /yaml-0.2.1 && \
> + ./configure --enable-static --enable-shared && \
> + make -j && make install
> +
> +COPY . /tarantool
> +
> +RUN set -x && \
> + cd tarantool && \
> + git submodule init && \
> + git submodule update
> +
> +RUN set -x \
> + && (cd /tarantool; \
> + cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo \
> + -DENABLE_BUNDLED_LIBYAML:BOOL=OFF \
> + -DENABLE_DIST:BOOL=ON \
> + -DBUILD_STATIC=ON \
> + -DOPENSSL_USE_STATIC_LIBS=ON \
> + .) \
> + && make -C /tarantool -j
> +
> +RUN cd /tarantool && make install
> +
> +ENTRYPOINT /bin/bash
> diff --git a/cmake/BuildMisc.cmake b/cmake/BuildMisc.cmake
> index 20ecb4f63..dc33198e4 100644
> --- a/cmake/BuildMisc.cmake
> +++ b/cmake/BuildMisc.cmake
> @@ -33,5 +33,15 @@ macro(libmisc_build)
>
> add_library(misc STATIC ${misc_src})
>
> + if (HAVE_OPENMP)
> + target_compile_options(misc PRIVATE "-fopenmp")
> + if(BUILD_STATIC)
> + set(GOMP_LIBRARY libgomp.a)
> + else()
> + set(GOMP_LIBRARY gomp)
> + endif()
> + target_link_libraries(misc ${GOMP_LIBRARY} pthread)
> + endif()
> +
> unset(misc_src)
> endmacro(libmisc_build)
> diff --git a/cmake/FindCURL.cmake b/cmake/FindCURL.cmake
> index dc7dc0735..1f57258df 100644
> --- a/cmake/FindCURL.cmake
> +++ b/cmake/FindCURL.cmake
> @@ -16,6 +16,14 @@
> # CURL_FOUND - True if curl found.
> # CURL_VERSION_STRING - the version of curl found (since CMake 2.8.8)
>
> +if(BUILD_STATIC)
> + set(CURL_LIB_NAME libcurl.a)
> + # Curl may require nghttp library, search for it and add to dependicies if found
> + find_library(NGHTTP_LIBRARY2 NAMES libgnhttp2.a)
> +else()
> + set(CURL_LIB_NAME curl)
> +endif()
> +
> if(DEFINED CURL_ROOT)
> set(CURL_FIND_OPTS NO_CMAKE NO_CMAKE_SYSTEM_PATH)
> set(CURL_FIND_LIBRARY_HINTS "${CURL_ROOT}/lib")
> @@ -36,7 +44,7 @@ mark_as_advanced(CURL_INCLUDE_DIR)
>
> # Look for the library (sorted from most current/relevant entry to least).
> find_library(CURL_LIBRARY NAMES
> - curl
> + ${CURL_LIB_NAME}
> # Windows MSVC prebuilts:
> curllib
> libcurl_imp
> @@ -67,8 +75,14 @@ FIND_PACKAGE_HANDLE_STANDARD_ARGS(CURL
>
> if(CURL_FOUND)
> set(CURL_LIBRARIES ${CURL_LIBRARY})
> + if(BUILD_STATIC)
> + #in case of a static build we have to add curl dependencies
> + if(NGHTTP2_LIBRARY)
> + set(CURL_LIBRARIES ${CURL_LIBRARIES} ${NGHTTP2_LIBRARY})
> + endif()
> + endif()
> set(CURL_INCLUDE_DIRS ${CURL_INCLUDE_DIR})
> - set(CMAKE_REQUIRED_LIBRARIES ${CURL_LIBRARIES})
> + set(CMAKE_REQUIRED_LIBRARIES ${CURL_LIBRARIES} ${OPENSSL_LIBRARIES} pthread dl)
> set(CMAKE_REQUIRED_INCLUDES ${CURL_INCLUDE_DIRS})
> check_c_source_runs("
> #include <curl/curl.h>
> diff --git a/cmake/FindICU.cmake b/cmake/FindICU.cmake
> index ad8ce600d..26f0683f3 100644
> --- a/cmake/FindICU.cmake
> +++ b/cmake/FindICU.cmake
> @@ -21,11 +21,27 @@ find_path(ICU_INCLUDE_DIR
> HINTS ${ICU_FIND_PATH_HINTS}
> ${ICU_FIND_OPTS}
> )
> -find_library(ICU_LIBRARY_I18N NAMES icui18n
> +
> +if(BUILD_STATIC)
> + set(ICU_I18N_LIB_NAME libicui18n.a)
> + set(ICU_UC_LIB_NAME libicuuc.a)
> + set(ICU_DATA_LIB_NAME libicudata.a)
> +else()
> + set(ICU_I18N_LIB_NAME icui18n)
> + set(ICU_UC_LIB_NAME icuuc)
> + set(ICU_DATA_LIB_NAME icudata)
> +endif()
> +
> +find_library(ICU_LIBRARY_I18N NAMES ${ICU_I18N_LIB_NAME}
> HINTS ${ICU_FIND_LIBRARY_HINTS}
> ${ICU_FIND_OPTS}
> )
> -find_library(ICU_LIBRARY_UC NAMES icuuc
> +find_library(ICU_LIBRARY_UC NAMES ${ICU_UC_LIB_NAME}
> + HINTS ${ICU_FIND_LIBRARY_HINTS}
> + ${ICU_FIND_OPTS}
> +)
> +
> +find_library(ICU_LIBRARY_DATA NAMES ${ICU_DATA_LIB_NAME}
> HINTS ${ICU_FIND_LIBRARY_HINTS}
> ${ICU_FIND_OPTS}
> )
> @@ -34,7 +50,7 @@ include(FindPackageHandleStandardArgs)
> find_package_handle_standard_args(ICU
> REQUIRED_VARS ICU_INCLUDE_DIR ICU_LIBRARY_I18N ICU_LIBRARY_UC)
> set(ICU_INCLUDE_DIRS ${ICU_INCLUDE_DIR})
> -set(ICU_LIBRARIES ${ICU_LIBRARY_I18N} ${ICU_LIBRARY_UC})
> +set(ICU_LIBRARIES ${ICU_LIBRARY_I18N} ${ICU_LIBRARY_UC} ${ICU_LIBRARY_DATA})
> mark_as_advanced(ICU_INCLUDE_DIR ICU_INCLUDE_DIRS
> ICU_LIBRARY_I18N ICU_LIBRARY_UC ICU_LIBRARIES)
>
> diff --git a/cmake/FindLibYAML.cmake b/cmake/FindLibYAML.cmake
> index 8abe5f9f0..ade06e292 100644
> --- a/cmake/FindLibYAML.cmake
> +++ b/cmake/FindLibYAML.cmake
> @@ -2,8 +2,14 @@ find_path(LIBYAML_INCLUDE_DIR
> NAMES yaml.h
> )
>
> +if(BUILD_STATIC)
> + set(YAML_LIB_NAME libyaml.a)
> +else()
> + set(YAML_LIB_NAME yaml)
> +endif()
> +
> find_library(LIBYAML_LIBRARY
> - NAMES yaml
> + NAMES ${YAML_LIB_NAME}
> )
>
> set(LIBYAML_INCLUDE_DIRS "${LIBYAML_INCLUDE_DIR}")
> diff --git a/cmake/FindOpenSSL.cmake b/cmake/FindOpenSSL.cmake
> new file mode 100644
> index 000000000..5d97f8a52
> --- /dev/null
> +++ b/cmake/FindOpenSSL.cmake
> @@ -0,0 +1,492 @@
> +# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
> +# file Copyright.txt or https://cmake.org/licensing for details.
> +
> +#.rst:
> +# FindOpenSSL
> +# -----------
> +#
> +# Find the OpenSSL encryption library.
> +#
> +# Optional COMPONENTS
> +# ^^^^^^^^^^^^^^^^^^^
> +#
> +# This module supports two optional COMPONENTS: ``Crypto`` and ``SSL``. Both
> +# components have associated imported targets, as described below.
> +#
> +# Imported Targets
> +# ^^^^^^^^^^^^^^^^
> +#
> +# This module defines the following :prop_tgt:`IMPORTED` targets:
> +#
> +# ``OpenSSL::SSL``
> +# The OpenSSL ``ssl`` library, if found.
> +# ``OpenSSL::Crypto``
> +# The OpenSSL ``crypto`` library, if found.
> +#
> +# Result Variables
> +# ^^^^^^^^^^^^^^^^
> +#
> +# This module will set the following variables in your project:
> +#
> +# ``OPENSSL_FOUND``
> +# System has the OpenSSL library. If no components are requested it only
> +# requires the crypto library.
> +# ``OPENSSL_INCLUDE_DIR``
> +# The OpenSSL include directory.
> +# ``OPENSSL_CRYPTO_LIBRARY``
> +# The OpenSSL crypto library.
> +# ``OPENSSL_SSL_LIBRARY``
> +# The OpenSSL SSL library.
> +# ``OPENSSL_LIBRARIES``
> +# All OpenSSL libraries.
> +# ``OPENSSL_VERSION``
> +# This is set to ``$major.$minor.$revision$patch`` (e.g. ``0.9.8s``).
> +#
> +# Hints
> +# ^^^^^
> +#
> +# Set ``OPENSSL_ROOT_DIR`` to the root directory of an OpenSSL installation.
> +# Set ``OPENSSL_USE_STATIC_LIBS`` to ``TRUE`` to look for static libraries.
> +# Set ``OPENSSL_MSVC_STATIC_RT`` set ``TRUE`` to choose the MT version of the lib.
> +
> +if (UNIX)
> + find_package(PkgConfig QUIET)
> + pkg_check_modules(_OPENSSL QUIET openssl)
> +endif ()
> +
> +# Support preference of static libs by adjusting CMAKE_FIND_LIBRARY_SUFFIXES
> +if(OPENSSL_USE_STATIC_LIBS)
> + set(_openssl_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES})
> + if(WIN32)
> + set(CMAKE_FIND_LIBRARY_SUFFIXES .lib .a ${CMAKE_FIND_LIBRARY_SUFFIXES})
> + else()
> + set(CMAKE_FIND_LIBRARY_SUFFIXES .a )
> + endif()
> +endif()
> +
> +if (WIN32)
> + # http://www.slproweb.com/products/Win32OpenSSL.html
> + set(_OPENSSL_ROOT_HINTS
> + ${OPENSSL_ROOT_DIR}
> + "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (32-bit)_is1;Inno Setup: App Path]"
> + "[HKEY_LOCAL_MACHINE\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Uninstall\\OpenSSL (64-bit)_is1;Inno Setup: App Path]"
> + ENV OPENSSL_ROOT_DIR
> + )
> + file(TO_CMAKE_PATH "$ENV{PROGRAMFILES}" _programfiles)
> + set(_OPENSSL_ROOT_PATHS
> + "${_programfiles}/OpenSSL"
> + "${_programfiles}/OpenSSL-Win32"
> + "${_programfiles}/OpenSSL-Win64"
> + "C:/OpenSSL/"
> + "C:/OpenSSL-Win32/"
> + "C:/OpenSSL-Win64/"
> + )
> + unset(_programfiles)
> +else ()
> + set(_OPENSSL_ROOT_HINTS
> + ${OPENSSL_ROOT_DIR}
> + ENV OPENSSL_ROOT_DIR
> + )
> +endif ()
> +
> +set(_OPENSSL_ROOT_HINTS_AND_PATHS
> + HINTS ${_OPENSSL_ROOT_HINTS}
> + PATHS ${_OPENSSL_ROOT_PATHS}
> + )
> +
> +find_path(OPENSSL_INCLUDE_DIR
> + NAMES
> + openssl/ssl.h
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + HINTS
> + ${_OPENSSL_INCLUDEDIR}
> + PATH_SUFFIXES
> + include
> +)
> +
> +if(WIN32 AND NOT CYGWIN)
> + if(MSVC)
> + # /MD and /MDd are the standard values - if someone wants to use
> + # others, the libnames have to change here too
> + # use also ssl and ssleay32 in debug as fallback for openssl < 0.9.8b
> + # enable OPENSSL_MSVC_STATIC_RT to get the libs build /MT (Multithreaded no-DLL)
> + # In Visual C++ naming convention each of these four kinds of Windows libraries has it's standard suffix:
> + # * MD for dynamic-release
> + # * MDd for dynamic-debug
> + # * MT for static-release
> + # * MTd for static-debug
> +
> + # Implementation details:
> + # We are using the libraries located in the VC subdir instead of the parent directory even though :
> + # libeay32MD.lib is identical to ../libeay32.lib, and
> + # ssleay32MD.lib is identical to ../ssleay32.lib
> + # enable OPENSSL_USE_STATIC_LIBS to use the static libs located in lib/VC/static
> +
> + if (OPENSSL_MSVC_STATIC_RT)
> + set(_OPENSSL_MSVC_RT_MODE "MT")
> + else ()
> + set(_OPENSSL_MSVC_RT_MODE "MD")
> + endif ()
> +
> + # Since OpenSSL 1.1, lib names are like libcrypto32MTd.lib and libssl32MTd.lib
> + if( "${CMAKE_SIZEOF_VOID_P}" STREQUAL "8" )
> + set(_OPENSSL_MSVC_ARCH_SUFFIX "64")
> + else()
> + set(_OPENSSL_MSVC_ARCH_SUFFIX "32")
> + endif()
> +
> + if(OPENSSL_USE_STATIC_LIBS)
> + set(_OPENSSL_PATH_SUFFIXES
> + "lib/VC/static"
> + "VC/static"
> + "lib"
> + )
> + else()
> + set(_OPENSSL_PATH_SUFFIXES
> + "lib/VC"
> + "VC"
> + "lib"
> + )
> + endif ()
> +
> + find_library(LIB_EAY_DEBUG
> + NAMES
> + libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
> + libcrypto${_OPENSSL_MSVC_RT_MODE}d
> + libcryptod
> + libeay32${_OPENSSL_MSVC_RT_MODE}d
> + libeay32d
> + cryptod
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + ${_OPENSSL_PATH_SUFFIXES}
> + )
> +
> + find_library(LIB_EAY_RELEASE
> + NAMES
> + libcrypto${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
> + libcrypto${_OPENSSL_MSVC_RT_MODE}
> + libcrypto
> + libeay32${_OPENSSL_MSVC_RT_MODE}
> + libeay32
> + crypto
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + ${_OPENSSL_PATH_SUFFIXES}
> + )
> +
> + find_library(SSL_EAY_DEBUG
> + NAMES
> + libssl${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}d
> + libssl${_OPENSSL_MSVC_RT_MODE}d
> + libssld
> + ssleay32${_OPENSSL_MSVC_RT_MODE}d
> + ssleay32d
> + ssld
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + ${_OPENSSL_PATH_SUFFIXES}
> + )
> +
> + find_library(SSL_EAY_RELEASE
> + NAMES
> + libssl${_OPENSSL_MSVC_ARCH_SUFFIX}${_OPENSSL_MSVC_RT_MODE}
> + libssl${_OPENSSL_MSVC_RT_MODE}
> + libssl
> + ssleay32${_OPENSSL_MSVC_RT_MODE}
> + ssleay32
> + ssl
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + ${_OPENSSL_PATH_SUFFIXES}
> + )
> +
> + set(LIB_EAY_LIBRARY_DEBUG "${LIB_EAY_DEBUG}")
> + set(LIB_EAY_LIBRARY_RELEASE "${LIB_EAY_RELEASE}")
> + set(SSL_EAY_LIBRARY_DEBUG "${SSL_EAY_DEBUG}")
> + set(SSL_EAY_LIBRARY_RELEASE "${SSL_EAY_RELEASE}")
> +
> + include(${CMAKE_CURRENT_LIST_DIR}/SelectLibraryConfigurations.cmake)
> + select_library_configurations(LIB_EAY)
> + select_library_configurations(SSL_EAY)
> +
> + mark_as_advanced(LIB_EAY_LIBRARY_DEBUG LIB_EAY_LIBRARY_RELEASE
> + SSL_EAY_LIBRARY_DEBUG SSL_EAY_LIBRARY_RELEASE)
> + set(OPENSSL_SSL_LIBRARY ${SSL_EAY_LIBRARY} )
> + set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY_LIBRARY} )
> + elseif(MINGW)
> + # same player, for MinGW
> + set(LIB_EAY_NAMES crypto libeay32)
> + set(SSL_EAY_NAMES ssl ssleay32)
> + find_library(LIB_EAY
> + NAMES
> + ${LIB_EAY_NAMES}
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + "lib/MinGW"
> + "lib"
> + )
> +
> + find_library(SSL_EAY
> + NAMES
> + ${SSL_EAY_NAMES}
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + PATH_SUFFIXES
> + "lib/MinGW"
> + "lib"
> + )
> +
> + mark_as_advanced(SSL_EAY LIB_EAY)
> + set(OPENSSL_SSL_LIBRARY ${SSL_EAY} )
> + set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY} )
> + unset(LIB_EAY_NAMES)
> + unset(SSL_EAY_NAMES)
> + else()
> + # Not sure what to pick for -say- intel, let's use the toplevel ones and hope someone report issues:
> + find_library(LIB_EAY
> + NAMES
> + libcrypto
> + libeay32
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + HINTS
> + ${_OPENSSL_LIBDIR}
> + PATH_SUFFIXES
> + lib
> + )
> +
> + find_library(SSL_EAY
> + NAMES
> + libssl
> + ssleay32
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + HINTS
> + ${_OPENSSL_LIBDIR}
> + PATH_SUFFIXES
> + lib
> + )
> +
> + mark_as_advanced(SSL_EAY LIB_EAY)
> + set(OPENSSL_SSL_LIBRARY ${SSL_EAY} )
> + set(OPENSSL_CRYPTO_LIBRARY ${LIB_EAY} )
> + endif()
> +else()
> +
> + find_library(OPENSSL_SSL_LIBRARY
> + NAMES
> + ssl
> + ssleay32
> + ssleay32MD
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + HINTS
> + ${_OPENSSL_LIBDIR}
> + PATH_SUFFIXES
> + lib
> + )
> +
> + find_library(OPENSSL_CRYPTO_LIBRARY
> + NAMES
> + crypto
> + NAMES_PER_DIR
> + ${_OPENSSL_ROOT_HINTS_AND_PATHS}
> + HINTS
> + ${_OPENSSL_LIBDIR}
> + PATH_SUFFIXES
> + lib
> + )
> +
> + mark_as_advanced(OPENSSL_CRYPTO_LIBRARY OPENSSL_SSL_LIBRARY)
> +
> + # compat defines
> + set(OPENSSL_SSL_LIBRARIES ${OPENSSL_SSL_LIBRARY})
> + set(OPENSSL_CRYPTO_LIBRARIES ${OPENSSL_CRYPTO_LIBRARY})
> +
> +endif()
> +
> +function(from_hex HEX DEC)
> + string(TOUPPER "${HEX}" HEX)
> + set(_res 0)
> + string(LENGTH "${HEX}" _strlen)
> +
> + while (_strlen GREATER 0)
> + math(EXPR _res "${_res} * 16")
> + string(SUBSTRING "${HEX}" 0 1 NIBBLE)
> + string(SUBSTRING "${HEX}" 1 -1 HEX)
> + if (NIBBLE STREQUAL "A")
> + math(EXPR _res "${_res} + 10")
> + elseif (NIBBLE STREQUAL "B")
> + math(EXPR _res "${_res} + 11")
> + elseif (NIBBLE STREQUAL "C")
> + math(EXPR _res "${_res} + 12")
> + elseif (NIBBLE STREQUAL "D")
> + math(EXPR _res "${_res} + 13")
> + elseif (NIBBLE STREQUAL "E")
> + math(EXPR _res "${_res} + 14")
> + elseif (NIBBLE STREQUAL "F")
> + math(EXPR _res "${_res} + 15")
> + else()
> + math(EXPR _res "${_res} + ${NIBBLE}")
> + endif()
> +
> + string(LENGTH "${HEX}" _strlen)
> + endwhile()
> +
> + set(${DEC} ${_res} PARENT_SCOPE)
> +endfunction()
> +
> +if(OPENSSL_INCLUDE_DIR AND EXISTS "${OPENSSL_INCLUDE_DIR}/openssl/opensslv.h")
> + file(STRINGS "${OPENSSL_INCLUDE_DIR}/openssl/opensslv.h" openssl_version_str
> + REGEX "^#[\t ]*define[\t ]+OPENSSL_VERSION_NUMBER[\t ]+0x([0-9a-fA-F])+.*")
> +
> + if(openssl_version_str)
> + # The version number is encoded as 0xMNNFFPPS: major minor fix patch status
> + # The status gives if this is a developer or prerelease and is ignored here.
> + # Major, minor, and fix directly translate into the version numbers shown in
> + # the string. The patch field translates to the single character suffix that
> + # indicates the bug fix state, which 00 -> nothing, 01 -> a, 02 -> b and so
> + # on.
> +
> + string(REGEX REPLACE "^.*OPENSSL_VERSION_NUMBER[\t ]+0x([0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F][0-9a-fA-F])([0-9a-fA-F]).*$"
> + "\\1;\\2;\\3;\\4;\\5" OPENSSL_VERSION_LIST "${openssl_version_str}")
> + list(GET OPENSSL_VERSION_LIST 0 OPENSSL_VERSION_MAJOR)
> + list(GET OPENSSL_VERSION_LIST 1 OPENSSL_VERSION_MINOR)
> + from_hex("${OPENSSL_VERSION_MINOR}" OPENSSL_VERSION_MINOR)
> + list(GET OPENSSL_VERSION_LIST 2 OPENSSL_VERSION_FIX)
> + from_hex("${OPENSSL_VERSION_FIX}" OPENSSL_VERSION_FIX)
> + list(GET OPENSSL_VERSION_LIST 3 OPENSSL_VERSION_PATCH)
> +
> + if (NOT OPENSSL_VERSION_PATCH STREQUAL "00")
> + from_hex("${OPENSSL_VERSION_PATCH}" _tmp)
> + # 96 is the ASCII code of 'a' minus 1
> + math(EXPR OPENSSL_VERSION_PATCH_ASCII "${_tmp} + 96")
> + unset(_tmp)
> + # Once anyone knows how OpenSSL would call the patch versions beyond 'z'
> + # this should be updated to handle that, too. This has not happened yet
> + # so it is simply ignored here for now.
> + string(ASCII "${OPENSSL_VERSION_PATCH_ASCII}" OPENSSL_VERSION_PATCH_STRING)
> + endif ()
> +
> + set(OPENSSL_VERSION "${OPENSSL_VERSION_MAJOR}.${OPENSSL_VERSION_MINOR}.${OPENSSL_VERSION_FIX}${OPENSSL_VERSION_PATCH_STRING}")
> + endif ()
> +endif ()
> +
> +set(OPENSSL_LIBRARIES ${OPENSSL_SSL_LIBRARY} ${OPENSSL_CRYPTO_LIBRARY} )
> +
> +foreach(_comp IN LISTS OpenSSL_FIND_COMPONENTS)
> + if(_comp STREQUAL "Crypto")
> + if(EXISTS "${OPENSSL_INCLUDE_DIR}" AND
> + (EXISTS "${OPENSSL_CRYPTO_LIBRARY}" OR
> + EXISTS "${LIB_EAY_LIBRARY_DEBUG}" OR
> + EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
> + )
> + set(OpenSSL_${_comp}_FOUND TRUE)
> + else()
> + set(OpenSSL_${_comp}_FOUND FALSE)
> + endif()
> + elseif(_comp STREQUAL "SSL")
> + if(EXISTS "${OPENSSL_INCLUDE_DIR}" AND
> + (EXISTS "${OPENSSL_SSL_LIBRARY}" OR
> + EXISTS "${SSL_EAY_LIBRARY_DEBUG}" OR
> + EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
> + )
> + set(OpenSSL_${_comp}_FOUND TRUE)
> + else()
> + set(OpenSSL_${_comp}_FOUND FALSE)
> + endif()
> + else()
> + message(WARNING "${_comp} is not a valid OpenSSL component")
> + set(OpenSSL_${_comp}_FOUND FALSE)
> + endif()
> +endforeach()
> +unset(_comp)
> +
> +include(FindPackageHandleStandardArgs)
> +find_package_handle_standard_args(OpenSSL
> + REQUIRED_VARS
> + OPENSSL_CRYPTO_LIBRARY
> + OPENSSL_INCLUDE_DIR
> + VERSION_VAR
> + OPENSSL_VERSION
> + HANDLE_COMPONENTS
> + FAIL_MESSAGE
> + "Could NOT find OpenSSL, try to set the path to OpenSSL root folder in the system variable OPENSSL_ROOT_DIR"
> +)
> +
> +mark_as_advanced(OPENSSL_INCLUDE_DIR OPENSSL_LIBRARIES)
> +
> +if(OPENSSL_FOUND)
> + if(NOT TARGET OpenSSL::Crypto AND
> + (EXISTS "${OPENSSL_CRYPTO_LIBRARY}" OR
> + EXISTS "${LIB_EAY_LIBRARY_DEBUG}" OR
> + EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
> + )
> + add_library(OpenSSL::Crypto UNKNOWN IMPORTED)
> + set_target_properties(OpenSSL::Crypto PROPERTIES
> + INTERFACE_INCLUDE_DIRECTORIES "${OPENSSL_INCLUDE_DIR}")
> + if(EXISTS "${OPENSSL_CRYPTO_LIBRARY}")
> + set_target_properties(OpenSSL::Crypto PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES "C"
> + IMPORTED_LOCATION "${OPENSSL_CRYPTO_LIBRARY}")
> + endif()
> + if(EXISTS "${LIB_EAY_LIBRARY_RELEASE}")
> + set_property(TARGET OpenSSL::Crypto APPEND PROPERTY
> + IMPORTED_CONFIGURATIONS RELEASE)
> + set_target_properties(OpenSSL::Crypto PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES_RELEASE "C"
> + IMPORTED_LOCATION_RELEASE "${LIB_EAY_LIBRARY_RELEASE}")
> + endif()
> + if(EXISTS "${LIB_EAY_LIBRARY_DEBUG}")
> + set_property(TARGET OpenSSL::Crypto APPEND PROPERTY
> + IMPORTED_CONFIGURATIONS DEBUG)
> + set_target_properties(OpenSSL::Crypto PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES_DEBUG "C"
> + IMPORTED_LOCATION_DEBUG "${LIB_EAY_LIBRARY_DEBUG}")
> + endif()
> + endif()
> +
> + if(NOT TARGET OpenSSL::SSL AND
> + (EXISTS "${OPENSSL_SSL_LIBRARY}" OR
> + EXISTS "${SSL_EAY_LIBRARY_DEBUG}" OR
> + EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
> + )
> + add_library(OpenSSL::SSL UNKNOWN IMPORTED)
> + set_target_properties(OpenSSL::SSL PROPERTIES
> + INTERFACE_INCLUDE_DIRECTORIES "${OPENSSL_INCLUDE_DIR}")
> + if(EXISTS "${OPENSSL_SSL_LIBRARY}")
> + set_target_properties(OpenSSL::SSL PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES "C"
> + IMPORTED_LOCATION "${OPENSSL_SSL_LIBRARY}")
> + endif()
> + if(EXISTS "${SSL_EAY_LIBRARY_RELEASE}")
> + set_property(TARGET OpenSSL::SSL APPEND PROPERTY
> + IMPORTED_CONFIGURATIONS RELEASE)
> + set_target_properties(OpenSSL::SSL PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES_RELEASE "C"
> + IMPORTED_LOCATION_RELEASE "${SSL_EAY_LIBRARY_RELEASE}")
> + endif()
> + if(EXISTS "${SSL_EAY_LIBRARY_DEBUG}")
> + set_property(TARGET OpenSSL::SSL APPEND PROPERTY
> + IMPORTED_CONFIGURATIONS DEBUG)
> + set_target_properties(OpenSSL::SSL PROPERTIES
> + IMPORTED_LINK_INTERFACE_LANGUAGES_DEBUG "C"
> + IMPORTED_LOCATION_DEBUG "${SSL_EAY_LIBRARY_DEBUG}")
> + endif()
> + if(TARGET OpenSSL::Crypto)
> + set_target_properties(OpenSSL::SSL PROPERTIES
> + INTERFACE_LINK_LIBRARIES OpenSSL::Crypto)
> + endif()
> + endif()
> +endif()
> +
> +# Restore the original find library ordering
> +if(OPENSSL_USE_STATIC_LIBS)
> + set(CMAKE_FIND_LIBRARY_SUFFIXES ${_openssl_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES})
> +endif()
> diff --git a/cmake/FindReadline.cmake b/cmake/FindReadline.cmake
> index 681a6f5de..770c4e15f 100644
> --- a/cmake/FindReadline.cmake
> +++ b/cmake/FindReadline.cmake
> @@ -6,22 +6,37 @@
> # READLINE_LIBRARIES
> #
>
> +if(BUILD_STATIC)
> + find_library(CURSES_CURSES_LIBRARY NAMES libcurses.a)
> + find_library(CURSES_NCURSES_LIBRARY NAMES libncurses.a)
> + find_library(CURSES_FORM_LIBRARY NAMES libform.a)
> + find_library(CURSES_INFO_LIBRARY NAMES libtinfo.a)
> + if (NOT CURSES_INFO_LIBRARY)
> + set(CURSES_INFO_LIBRARY "")
> + endif()
> +endif()
> find_package(Curses)
> if(NOT CURSES_FOUND)
> find_package(Termcap)
> endif()
>
> +if(BUILD_STATIC)
> + set(READLINE_LIB_NAME libreadline.a)
> +else()
> + set(READLINE_LIB_NAME readline)
> +endif()
> +
> if (DEFINED READLINE_ROOT)
> set(_FIND_OPTS NO_CMAKE NO_CMAKE_SYSTEM_PATH)
> find_library(READLINE_LIBRARY
> - NAMES readline
> + NAMES ${READLINE_LIB_NAME}
> HINTS ${READLINE_ROOT}/lib
> ${_FIND_OPTS})
> find_path(READLINE_INCLUDE_DIR
> NAMES readline/readline.h
> HINTS ${READLINE_ROOT}/include ${_FIND_OPTS})
> else()
> - find_library(READLINE_LIBRARY NAMES readline)
> + find_library(READLINE_LIBRARY NAMES ${READLINE_LIB_NAME})
> find_path(READLINE_INCLUDE_DIR readline/readline.h)
> endif()
>
> @@ -41,10 +56,10 @@ if(READLINE_FOUND)
> endif()
> endif()
> if(CURSES_FOUND)
> - set(READLINE_LIBRARIES ${READLINE_LIBRARIES} ${CURSES_LIBRARIES})
> + set(READLINE_LIBRARIES ${READLINE_LIBRARIES} ${CURSES_LIBRARIES} ${CURSES_INFO_LIBRARY})
> set(READLINE_INCLUDE_DIRS ${READLINE_INCLUDE_DIRS} ${CURSES_INCLUDE_DIRS})
> elseif(TERMCAP_FOUND)
> - set(READLINE_LIBRARIES ${READLINE_LIBRARIES} ${TERMCAP_LIBRARIES})
> + set(READLINE_LIBRARIES ${READLINE_LIBRARIES} ${TERMCAP_LIBRARIES} ${CURSES_INFO_LIBRARY})
> set(READLINE_INCLUDE_DIRS ${READLINE_INCLUDE_DIRS} ${TERMCAP_INCLUDE_DIRS})
> endif()
> endif(READLINE_FOUND)
> diff --git a/cmake/FindTermcap.cmake b/cmake/FindTermcap.cmake
> index efe0c48cf..fa88fe7b2 100644
> --- a/cmake/FindTermcap.cmake
> +++ b/cmake/FindTermcap.cmake
> @@ -4,7 +4,13 @@
> # TERMCAP_LIBRARY
> # TERMCAP_INCLUDE_DIR
>
> -FIND_LIBRARY(TERMCAP_LIBRARY NAMES termcap)
> +if(BUILD_STATIC)
> + set(TERMCAP_STATIC libtermcap.a)
> +else()
> + set(TERMCAP_STATIC termcap)
> +endif()
> +
> +FIND_LIBRARY(TERMCAP_LIBRARY NAMES ${TERMCAP_STATIC})
> FIND_PATH(TERMCAP_INCLUDE_DIR NAMES termcap.h)
>
> include(FindPackageHandleStandardArgs)
> diff --git a/cmake/FindZSTD.cmake b/cmake/FindZSTD.cmake
> index 738de535d..b4421fbe6 100644
> --- a/cmake/FindZSTD.cmake
> +++ b/cmake/FindZSTD.cmake
> @@ -2,8 +2,13 @@ find_path(ZSTD_INCLUDE_DIR
> NAMES zstd.h
> )
>
> +if(BUILD_STATIC)
> + set(ZSTD_LIB_NAME libzstd.a)
> +else()
> + set(ZSTD_LIB_NAME zstd)
> +endif()
> find_library(ZSTD_LIBRARY
> - NAMES zstd
> + NAMES ${ZSTD_LIB_NAME}
> )
>
> set(ZSTD_INCLUDE_DIRS "${ZSTD_INCLUDE_DIR}")
> diff --git a/cmake/compiler.cmake b/cmake/compiler.cmake
> index 05d33ab48..d990df6b4 100644
> --- a/cmake/compiler.cmake
> +++ b/cmake/compiler.cmake
> @@ -116,7 +116,12 @@ set (CMAKE_CXX_FLAGS_RELWITHDEBINFO
> unset(CC_DEBUG_OPT)
>
> check_include_file(libunwind.h HAVE_LIBUNWIND_H)
> -find_library(UNWIND_LIBRARY PATH_SUFFIXES system NAMES unwind)
> +if(BUILD_STATIC)
> + set(UNWIND_LIB_NAME libunwind.a)
> +else()
> + set(UNWIND_LIB_NAME unwind)
> +endif()
> +find_library(UNWIND_LIBRARY PATH_SUFFIXES system NAMES ${UNWIND_LIB_NAME})
>
> set(ENABLE_BACKTRACE_DEFAULT OFF)
> if (UNWIND_LIBRARY AND HAVE_LIBUNWIND_H)
> @@ -137,20 +142,36 @@ if (ENABLE_BACKTRACE)
> else()
> if (CMAKE_SYSTEM_PROCESSOR STREQUAL "x86_64" OR
> CMAKE_SYSTEM_PROCESSOR STREQUAL "aarch64")
> - find_library(UNWIND_PLATFORM_LIBRARY PATH_SUFFIXES system
> - NAMES "unwind-${CMAKE_SYSTEM_PROCESSOR}")
> + if(BUILD_STATIC)
> + set(UNWIND_PLATFORM_LIB_NAME "libunwind-${CMAKE_SYSTEM_PROCESSOR}.a")
> + else()
> + set(UNWIND_PLATFORM_LIB_NAME "unwind-${CMAKE_SYSTEM_PROCESSOR}")
> + endif()
> elseif (CMAKE_SYSTEM_PROCESSOR STREQUAL "i686")
> - find_library(UNWIND_PLATFORM_LIBRARY PATH_SUFFIXES system
> - NAMES "unwind-x86")
> + if(BUILD_STATIC)
> + set(UNWIND_PLATFORM_LIB_NAME "libunwind-x86.a")
> + else()
> + set(UNWIND_PLATFORM_LIB_NAME "unwind-x86")
> + endif()
> elseif (CMAKE_SYSTEM_PROCESSOR MATCHES "arm*")
> - find_library(UNWIND_PLATFORM_LIBRARY PATH_SUFFIXES system
> - NAMES "unwind-arm")
> + if(BUILD_STATIC)
> + set(UNWIND_PLATFORM_LIB_NAME "libunwind-arm.a")
> + else()
> + set(UNWIND_PLATFORM_LIB_NAME "unwind-arm")
> + endif()
> endif()
> - set (UNWIND_LIBRARIES ${UNWIND_LIBRARY} ${UNWIND_PLATFORM_LIBRARY})
> + find_library(UNWIND_PLATFORM_LIBRARY PATH_SUFFIXES system
> + NAMES ${UNWIND_PLATFORM_LIB_NAME})
> + set(UNWIND_LIBRARIES ${UNWIND_PLATFORM_LIBRARY} ${UNWIND_LIBRARY})
> endif()
> find_package_message(UNWIND_LIBRARIES "Found unwind" "${UNWIND_LIBRARIES}")
> endif()
>
> +if(BUILD_STATIC)
> + # Static linking for c++ routines
> + add_compile_flags("C;CXX" "-static-libstdc++")
> +endif()
> +
> #
> # Set flags for all include files: those maintained by us and
> # coming from third parties.
> @@ -259,11 +280,6 @@ macro(enable_tnt_compile_flags)
> endif()
> endmacro(enable_tnt_compile_flags)
>
> -if (HAVE_OPENMP)
> - add_compile_flags("C;CXX" "-fopenmp")
> -endif()
> -
> -
> if (CMAKE_COMPILER_IS_CLANG OR CMAKE_COMPILER_IS_GNUCC)
> set(HAVE_BUILTIN_CTZ 1)
> set(HAVE_BUILTIN_CTZLL 1)
> diff --git a/extra/mkexports b/extra/mkexports
> index 20b3454d4..145e5b8ce 100755
> --- a/extra/mkexports
> +++ b/extra/mkexports
> @@ -2,6 +2,7 @@
> # $1 - in file
> # $2 - out file
> # $3 - os
> +# $4 - export templates
> if [ "x$3x" = xDarwinx ]; then
> # _func1
> # _func2
> @@ -11,5 +12,16 @@ else
> # func1;
> # func2;
> # };
> - ( echo "{" && sed -e '/^\s*$/d;s/$/;/;' $1 && echo "};" ) > $2
> + echo "$4"
> + ( echo "{" && {
> + # combine static defined list of functions
> + cat $1 ;
> + # with list of exported functions of bundled libraries
> + for so in $4 ; do {
> + # exported names from shared object
> + nm -D $so ||
> + # or follow patch from shared object script
> + nm -D `cat $so | grep GROUP | awk '{print $3}'` ;
> + } | awk '{print $3}' ; done ;
> + } | sed '/^\s*$/d;s/$/;/;' && echo "};" ) > $2
> fi
> diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
> index 3b55ecd41..432214ea1 100644
> --- a/src/CMakeLists.txt
> +++ b/src/CMakeLists.txt
> @@ -67,6 +67,8 @@ add_custom_target(ragel
> WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
> COMMAND ragel -G2 src/uri.rl -o src/uri.c)
>
> +set (generic_libraries pthread dl)
> +
> set (core_sources
> diag.c
> say.c
> @@ -108,18 +110,18 @@ endif ()
>
> add_library(core STATIC ${core_sources})
> target_link_libraries(core
> - salad small pthread
> + salad small
> ${LIBEV_LIBRARIES}
> ${LIBEIO_LIBRARIES}
> ${LIBCORO_LIBRARIES}
> ${MSGPUCK_LIBRARIES}
> -)
> + ${generic_libraries})
>
> add_library(stat STATIC rmean.c latency.c histogram.c)
> target_link_libraries(stat core)
>
> if (ENABLE_BACKTRACE AND NOT TARGET_OS_DARWIN)
> - target_link_libraries(core gcc_s ${UNWIND_LIBRARIES})
> + target_link_libraries(core gcc_s ${UNWIND_LIBRARIES})
> endif()
>
> if (CC_HAS_WNO_IMPLICIT_FALLTHROUGH)
> @@ -224,9 +226,10 @@ set (common_libraries
> ${reexport_libraries}
> ${LIBYAML_LIBRARIES}
> ${READLINE_LIBRARIES}
> - ${OPENSSL_LIBRARIES}
> ${CURL_LIBRARIES}
> ${ICONV_LIBRARIES}
> + ${OPENSSL_LIBRARIES}
> + ${Z_LIBRARY}
> )
>
> if (TARGET_OS_LINUX OR TARGET_OS_DEBIAN_FREEBSD)
> @@ -252,6 +255,31 @@ add_subdirectory(box)
> set(TARANTOOL_C_FLAGS ${CMAKE_C_FLAGS} PARENT_SCOPE)
> set(TARANTOOL_CXX_FLAGS ${CMAKE_CXX_FLAGS} PARENT_SCOPE)
>
> +set(EXPORT_LIST)
> +if(BUILD_STATIC)
> + # for each static library we should find a corresponding shared library to
> + # parse and reexport library api functions
> + foreach(libstatic
> + ${READLINE_LIBRARIES}
> + ${CURL_LIBRARIES}
> + ${OPENSSL_LIBRARIES}
> + ${ICU_LIBRARIES})
> + if (${libstatic} MATCHES "lib[^/]+.a")
> + string(REGEX MATCH "lib[^/]+.a" libname ${libstatic})
> + string(REGEX REPLACE "\\.a$" "" libname ${libname})
> + string(REGEX REPLACE "^lib" "" libname ${libname})
> + find_library(SYMBOLS_LIB NAMES ${libname})
> + # add found library to export list
> + list(APPEND EXPORT_LIST ${SYMBOLS_LIB})
> + # set variable to allow rescan (CMake depended)
> + set(SYMBOLS_LIB "SYMBOLS_LIB-NOTFOUND")
> + else()
> + message(WARNING "${libstatic} should be a static")
> + endif()
> + endforeach(libstatic)
> + string(REPLACE ";" " " EXPORT_LIST "${EXPORT_LIST}")
> +endif()
> +
> # Exports syntax is toolchain-dependent, preprocessing is necessary
> set(exports_file ${CMAKE_BINARY_DIR}/extra/exports.${CMAKE_SYSTEM_NAME})
> add_custom_target(preprocess_exports
> @@ -261,12 +289,14 @@ add_custom_command(
> DEPENDS ${CMAKE_SOURCE_DIR}/extra/exports
> COMMAND ${CMAKE_SOURCE_DIR}/extra/mkexports
> ${CMAKE_SOURCE_DIR}/extra/exports
> - ${exports_file} ${CMAKE_SYSTEM_NAME})
> + ${exports_file} ${CMAKE_SYSTEM_NAME}
> + ${EXPORT_LIST}
> +)
>
> add_executable(
> - tarantool main.cc
> - ${LIBUTIL_FREEBSD_SRC}/flopen.c
> - ${LIBUTIL_FREEBSD_SRC}/pidfile.c)
> + tarantool main.cc
> + ${LIBUTIL_FREEBSD_SRC}/flopen.c
> + ${LIBUTIL_FREEBSD_SRC}/pidfile.c)
>
> add_dependencies(tarantool build_bundled_libs preprocess_exports)
>
> @@ -294,7 +324,8 @@ else ()
> target_link_libraries(tarantool
> -Wl,--whole-archive box ${reexport_libraries}
> salad -Wl,--no-whole-archive
> - ${common_libraries})
> + ${common_libraries}
> + ${generic_libraries})
> set_target_properties(tarantool PROPERTIES
> LINK_FLAGS "-Wl,--dynamic-list,${exports_file}")
> # get rid of -rdynamic
> diff --git a/third_party/crc32.c b/third_party/crc32.c
> index a271d07ec..16b8c4040 100644
> --- a/third_party/crc32.c
> +++ b/third_party/crc32.c
> @@ -45,7 +45,7 @@
> #include <unistd.h>
> #include <stdint.h>
>
> -uint32_t crc32_table[] = {
> +static uint32_t crc32_table[] = {
> 0x00000000, 0x77073096, 0xee0e612c, 0x990951ba, 0x076dc419, 0x706af48f,
> 0xe963a535, 0x9e6495a3, 0x0edb8832, 0x79dcb8a4, 0xe0d5e91e, 0x97d2d988,
> 0x09b64c2b, 0x7eb17cbd, 0xe7b82d07, 0x90bf1d91, 0x1db71064, 0x6ab020f2,
> @@ -92,7 +92,7 @@ uint32_t crc32_table[] = {
> };
>
> uint32_t
> -crc32(const void *buf, size_t size)
> +tnt_crc32(const void *buf, size_t size)
> {
> const uint8_t *p = buf;
> uint32_t crc;
> @@ -735,7 +735,7 @@ multitable_crc32c(uint32_t crc32c,
> }
>
> uint32_t
> -crc32c(uint32_t crc32c,
> +tnt_crc32c(uint32_t crc32c,
> const char *buffer,
> unsigned int length)
> {
> diff --git a/third_party/crc32.h b/third_party/crc32.h
> index 55c7072f3..8dc61d05d 100644
> --- a/third_party/crc32.h
> +++ b/third_party/crc32.h
> @@ -3,7 +3,9 @@
>
> #include <stdint.h>
>
> -uint32_t crc32(const void *buf, size_t size);
> -uint32_t crc32c(uint32_t crc32c, const char *buffer, unsigned int length);
> +#define crc32 tnt_crc32
> +uint32_t tnt_crc32(const void *buf, size_t size);
> +#define crc32c tnt_crc32c
> +uint32_t tnt_crc32c(uint32_t crc32c, const char *buffer, unsigned int length);
>
> #endif
> --
> 2.18.0
>
>
>
>
next prev parent reply other threads:[~2018-08-29 11:19 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-08-29 6:08 [tarantool-patches] " Georgy Kirichenko
2018-08-29 11:19 ` Alexander Turenko [this message]
2018-08-29 11:22 ` [tarantool-patches] " Alexander Turenko
2018-09-06 17:59 ` Kirill Yukhin
2018-09-07 7:30 ` [tarantool-patches] [PATCH] Fix libgomp linking for static build Kirill Yukhin
2018-09-07 9:06 ` [tarantool-patches] " Kirill Yukhin
2018-09-07 9:17 ` [tarantool-patches] " Kirill Yukhin
2018-09-07 17:10 ` [tarantool-patches] " Alexander Turenko
2018-09-10 7:05 ` Kirill Yukhin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180829111941.d4sy6wm5hav647oh@tkn_work_nb \
--to=alexander.turenko@tarantool.org \
--cc=georgy@tarantool.org \
--cc=tarantool-patches@freelists.org \
--subject='[tarantool-patches] Re: [PATCH v4] Tarantool static build ability' \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox