mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-04-18 21:44:02 +03:00
260 lines
13 KiB
CMake
Executable File
260 lines
13 KiB
CMake
Executable File
|
|
CMAKE_MINIMUM_REQUIRED(VERSION 2.8.12)
|
|
|
|
# Avoid warnings in higher versions
|
|
if("${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}" GREATER 2.6)
|
|
CMAKE_POLICY(VERSION 2.8)
|
|
endif()
|
|
|
|
# explicitly set the policy to OLD
|
|
# (cannot use NEW, not everyone is on cmake-2.8.12 yet)
|
|
IF(POLICY CMP0022)
|
|
CMAKE_POLICY(SET CMP0022 OLD)
|
|
ENDIF()
|
|
|
|
# We use the LOCATION target property (CMP0026)
|
|
# and get_target_property() for non-existent targets (CMP0045)
|
|
# and INSTALL_NAME_DIR (CMP0042)
|
|
IF(CMAKE_VERSION VERSION_EQUAL "3.0.0" OR
|
|
CMAKE_VERSION VERSION_GREATER "3.0.0")
|
|
CMAKE_POLICY(SET CMP0026 OLD)
|
|
CMAKE_POLICY(SET CMP0045 OLD)
|
|
CMAKE_POLICY(SET CMP0042 OLD)
|
|
ENDIF()
|
|
|
|
MESSAGE(STATUS "Running cmake version ${CMAKE_VERSION}")
|
|
|
|
# Distinguish between community and non-community builds, with the
|
|
# default being a community build. This does not impact the feature
|
|
# set that will be compiled in; it's merely provided as a hint to
|
|
# custom packaging steps.
|
|
OPTION(COMMUNITY_BUILD "Set to true if this is a community build" ON)
|
|
|
|
IF(NOT CMAKE_BUILD_TYPE)
|
|
SET(CMAKE_BUILD_TYPE RELWITHDEBINFO CACHE STRING
|
|
"Choose the type of build, options are: None(CMAKE_CXX_FLAGS or CMAKE_C_FLAGS used) Debug Release RelWithDebInfo MinSizeRel" FORCE)
|
|
ENDIF(NOT CMAKE_BUILD_TYPE)
|
|
|
|
#set( CMAKE_VERBOSE_MAKEFILE on )
|
|
|
|
INCLUDE(columnstore_version.cmake)
|
|
|
|
SET (PACKAGE columnstore)
|
|
SET (PACKAGE_NAME columnstore)
|
|
SET (PACKAGE_TARNAME columnstore)
|
|
SET (PACKAGE_BUGREPORT support@mariadb.com)
|
|
SET (PACKAGE_URL "")
|
|
|
|
SET (PACKAGE_STRING columnstore-${PACKAGE_VERSION})
|
|
|
|
|
|
SET (ENGINE_SRC_DIR ${CMAKE_CURRENT_SOURCE_DIR})
|
|
SET (INSTALL_ENGINE "/usr/local/mariadb/columnstore")
|
|
|
|
# use, i.e. don't skip the full RPATH for the build tree
|
|
SET(CMAKE_SKIP_BUILD_RPATH FALSE)
|
|
|
|
# when building, don't use the install RPATH already
|
|
# (but later on when installing)
|
|
SET(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE)
|
|
|
|
SET(CMAKE_INSTALL_RPATH "${INSTALL_ENGINE}/lib;${INSTALL_ENGINE}/mysql/lib")
|
|
|
|
# add the automatically determined parts of the RPATH
|
|
# which point to directories outside the build tree to the install RPATH
|
|
SET(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
|
|
|
|
# the RPATH to be used when installing, but only if it's not a system directory
|
|
LIST(FIND CMAKE_PLATFORM_IMPLICIT_LINK_DIRECTORIES "${INSTALL_ENGINE}/lib" isSystemDir)
|
|
IF("${isSystemDir}" STREQUAL "-1")
|
|
SET(CMAKE_INSTALL_RPATH "${INSTALL_ENGINE}/lib")
|
|
ENDIF("${isSystemDir}" STREQUAL "-1")
|
|
|
|
LIST(FIND CMAKE_PLATFORM_IMPLICIT_LINK_DIRECTORIES "${SERVER_SOURCE_ROOT_DIR}/libmysql/" isSystemDir)
|
|
IF("${isSystemDir}" STREQUAL "-1")
|
|
SET(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_RPATH};${INSTALL_ENGINE}/mysql/lib")
|
|
ENDIF("${isSystemDir}" STREQUAL "-1")
|
|
|
|
INCLUDE (configureEngine.cmake)
|
|
|
|
# releasenum is used by external scripts for various tasks. Leave it alone.
|
|
CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/build/releasenum.in ${CMAKE_CURRENT_BINARY_DIR}/build/releasenum IMMEDIATE)
|
|
INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/build/releasenum DESTINATION ${INSTALL_ENGINE} COMPONENT platform)
|
|
CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/columnstoreversion.h.in ${CMAKE_CURRENT_SOURCE_DIR}/columnstoreversion.h)
|
|
CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config.h)
|
|
|
|
exec_program("git"
|
|
${CMAKE_CURRENT_SOURCE_DIR}
|
|
ARGS "describe --match=NeVeRmAtCh --always --dirty"
|
|
OUTPUT_VARIABLE GIT_VERSION)
|
|
|
|
CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/gitversionEngine.in ${CMAKE_CURRENT_BINARY_DIR}/gitversionEngine IMMEDIATE)
|
|
INSTALL(FILES ${CMAKE_CURRENT_BINARY_DIR}/gitversionEngine DESTINATION ${INSTALL_ENGINE} COMPONENT platform)
|
|
|
|
INCLUDE(bison.cmake)
|
|
|
|
FIND_PROGRAM(LEX_EXECUTABLE flex DOC "path to the flex executable")
|
|
if(NOT LEX_EXECUTABLE)
|
|
FIND_PROGRAM(LEX_EXECUTABLE lex DOC "path to the lex executable")
|
|
if(NOT LEX_EXECUTABLE)
|
|
message(FATAL_ERROR "flex/lex not found!")
|
|
endif()
|
|
endif()
|
|
|
|
INCLUDE (FindLibXml2)
|
|
|
|
if (NOT LIBXML2_FOUND)
|
|
MESSAGE(FATAL_ERROR "Could not find a usable libxml2 development environment!")
|
|
endif()
|
|
|
|
INCLUDE (FindSnappy.cmake)
|
|
if (NOT SNAPPY_FOUND)
|
|
MESSAGE(FATAL_ERROR "Snappy not found please install snappy-devel for CentOS/RedHat or libsnappy-dev for Ubuntu/Debian")
|
|
endif()
|
|
|
|
FIND_PROGRAM(AWK_EXECUTABLE awk DOC "path to the awk executable")
|
|
if(NOT AWK_EXECUTABLE)
|
|
message(FATAL_ERROR "awk not found!")
|
|
endif()
|
|
|
|
INCLUDE(check_compiler_flag.cmake)
|
|
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-g -O3 -fno-omit-frame-pointer -fno-strict-aliasing -Wall -fno-tree-vectorize -DDBUG_OFF -DHAVE_CONFIG_H" RELEASE RELWITHDEBINFO MINSIZEREL)
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-ggdb3 -fno-omit-frame-pointer -fno-tree-vectorize -DSAFE_MUTEX -DSAFEMALLOC -DENABLED_DEBUG_SYNC -O0 -Wall -D_DEBUG -DHAVE_CONFIG_H" DEBUG)
|
|
|
|
# enable security hardening features, like most distributions do
|
|
# in our benchmarks that costs about ~1% of performance, depending on the load
|
|
IF(CMAKE_C_COMPILER_VERSION VERSION_LESS "4.6")
|
|
SET(security_default OFF)
|
|
ELSE()
|
|
SET(security_default ON)
|
|
ENDIF()
|
|
OPTION(SECURITY_HARDENED "Use security-enhancing compiler features (stack protector, relro, etc)" ${security_default})
|
|
IF(SECURITY_HARDENED)
|
|
# security-enhancing flags
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-pie -fPIC")
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-Wl,-z,relro,-z,now")
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-fstack-protector --param=ssp-buffer-size=4")
|
|
MY_CHECK_AND_SET_COMPILER_FLAG("-D_FORTIFY_SOURCE=2" RELEASE RELWITHDEBINFO)
|
|
ENDIF()
|
|
|
|
SET (ENGINE_LDFLAGS "-Wl,--no-as-needed -Wl,--add-needed")
|
|
|
|
|
|
FIND_PACKAGE(Boost 1.53.0 REQUIRED COMPONENTS system filesystem thread regex date_time)
|
|
|
|
SET (ENGINE_LIBDIR "${INSTALL_ENGINE}/lib")
|
|
SET (ENGINE_BINDIR "${INSTALL_ENGINE}/bin")
|
|
SET (ENGINE_INCDIR "${INSTALL_ENGINE}/include")
|
|
SET (ENGINE_ETCDIR "${INSTALL_ENGINE}/etc")
|
|
SET (ENGINE_SYSCONFDIR "${INSTALL_ENGINE}/etc")
|
|
SET (ENGINE_MANDIR "${INSTALL_ENGINE}/man")
|
|
SET (ENGINE_SBINDIR "${INSTALL_ENGINE}/sbin")
|
|
SET (ENGINE_SHAREDIR "${INSTALL_ENGINE}/share")
|
|
SET (ENGINE_POSTDIR "${INSTALL_ENGINE}/post")
|
|
SET (ENGINE_LOCALDIR "${INSTALL_ENGINE}/local")
|
|
SET (ENGINE_MYSQLDIR "${INSTALL_ENGINE}/mysql")
|
|
SET (ENGINE_TOOLSDIR "${INSTALL_ENGINE}/tools")
|
|
|
|
SET (ENGINE_COMMON_LIBS messageqcpp loggingcpp configcpp idbboot ${Boost_LIBRARIES} xml2 pthread rt)
|
|
SET (ENGINE_OAM_LIBS oamcpp alarmmanager)
|
|
SET (ENGINE_BRM_LIBS brm idbdatafile cacheutils rwlock ${ENGINE_OAM_LIBS} ${ENGINE_COMMON_LIBS})
|
|
SET (ENGINE_EXEC_LIBS joblist execplan windowfunction joiner rowgroup funcexp udfsdk dataconvert common compress querystats querytele thrift threadpool ${ENGINE_BRM_LIBS})
|
|
SET (ENGINE_WRITE_LIBS ddlpackageproc ddlpackage dmlpackageproc dmlpackage writeengine writeengineclient idbdatafile cacheutils ${ENGINE_EXEC_LIBS})
|
|
|
|
SET (ENGINE_COMMON_LDFLAGS "")
|
|
|
|
IF (SERVER_BUILD_INCLUDE_DIR)
|
|
SET (SERVER_BUILD_INCLUDE_DIR ${CMAKE_BINARY_DIR}/${SERVER_BUILD_INCLUDE_DIR})
|
|
ELSE()
|
|
SET (SERVER_BUILD_INCLUDE_DIR ${CMAKE_BINARY_DIR}/../include)
|
|
ENDIF()
|
|
|
|
IF (SERVER_SOURCE_ROOT_DIR)
|
|
SET (SERVER_SOURCE_ROOT_DIR ${CMAKE_BINARY_DIR}/${SERVER_SOURCE_ROOT_DIR})
|
|
ELSE()
|
|
SET (SERVER_SOURCE_ROOT_DIR ${CMAKE_BINARY_DIR}/..)
|
|
ENDIF()
|
|
|
|
MESSAGE("SERVER_BUILD_INCLUDE_DIR = ${SERVER_BUILD_INCLUDE_DIR}")
|
|
MESSAGE("SERVER_SOURCE_ROOT_DIR = ${SERVER_SOURCE_ROOT_DIR}")
|
|
|
|
SET (MARIADB_CLIENT_LIBS -L${SERVER_BUILD_INCLUDE_DIR}/../libmariadb/libmariadb/ libmariadb.so)
|
|
|
|
#SET (ENGINE_UTILS_BOOSTIDB_INCLUDE "{CMAKE_CURRENT_SOURCE_DIR}/utils/boost_idb")
|
|
SET (ENGINE_UTILS_MESSAGEQCPP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/messageqcpp")
|
|
SET (ENGINE_WE_SHARED_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/writeengine/shared")
|
|
SET (ENGINE_UTILS_IDBDATAFILE_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/idbdatafile")
|
|
SET (ENGINE_UTILS_LOGGINGCPP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/loggingcpp")
|
|
SET (ENGINE_UTILS_CONFIGCPP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/configcpp")
|
|
SET (ENGINE_UTILS_COMPRESS_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/compress")
|
|
SET (ENGINE_VERSIONING_BRM_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/versioning/BRM")
|
|
SET (ENGINE_UTILS_ROWGROUP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/rowgroup")
|
|
SET (ENGINE_UTILS_COMMON_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/common")
|
|
SET (ENGINE_UTILS_DATACONVERT_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/dataconvert")
|
|
SET (ENGINE_UTILS_RWLOCK_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/rwlock")
|
|
SET (ENGINE_UTILS_FUNCEXP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/funcexp")
|
|
SET (ENGINE_OAMAPPS_ALARMMANAGER_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/oamapps/alarmmanager")
|
|
SET (ENGINE_UTILS_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils")
|
|
SET (ENGINE_OAM_OAMCPP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/oam/oamcpp")
|
|
SET (ENGINE_DBCON_DDLPKGPROC_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/ddlpackageproc")
|
|
SET (ENGINE_DBCON_DDLPKG_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/ddlpackage")
|
|
SET (ENGINE_DBCON_EXECPLAN_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/execplan")
|
|
SET (ENGINE_UTILS_STARTUP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/startup")
|
|
SET (ENGINE_DBCON_JOBLIST_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/joblist")
|
|
SET (ENGINE_WE_WRAPPER_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/writeengine/wrapper")
|
|
SET (ENGINE_WE_SERVER_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/writeengine/server")
|
|
SET (ENGINE_DBCON_DMLPKG_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/dmlpackage")
|
|
SET (ENGINE_WE_CLIENT_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/writeengine/client")
|
|
SET (ENGINE_DBCON_DMLPKGPROC_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/dbcon/dmlpackageproc")
|
|
SET (ENGINE_UTILS_CACHEUTILS_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/cacheutils")
|
|
SET (ENGINE_UTILS_MYSQLCL_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/mysqlcl_idb")
|
|
SET (ENGINE_UTILS_QUERYTELE_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/querytele")
|
|
SET (ENGINE_UTILS_THRIFT_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/thrift")
|
|
SET (ENGINE_UTILS_JOINER_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/joiner")
|
|
SET (ENGINE_UTILS_THREADPOOL_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/threadpool")
|
|
SET (ENGINE_UTILS_BATCHLDR_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/batchloader")
|
|
SET (ENGINE_UTILS_DDLCLEANUP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/ddlcleanup")
|
|
SET (ENGINE_UTILS_QUERYSTATS_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/querystats")
|
|
SET (ENGINE_WE_CONFIGCPP_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/writeengine/xml")
|
|
SET (ENGINE_SERVER_SQL_INCLUDE "${SERVER_SOURCE_ROOT_DIR}/sql")
|
|
SET (ENGINE_SERVER_INCLUDE_INCLUDE "${SERVER_SOURCE_ROOT_DIR}/include")
|
|
SET (ENGINE_SERVER_PCRE_INCLUDE "${SERVER_BUILD_INCLUDE_DIR}/../pcre")
|
|
SET (ENGINE_UTILS_UDFSDK_INCLUDE "${CMAKE_CURRENT_SOURCE_DIR}/utils/udfsdk")
|
|
|
|
SET (ENGINE_DEFAULT_INCLUDES ${CMAKE_BINARY_DIR} "." "../" "../../" ${SERVER_BUILD_INCLUDE_DIR})
|
|
|
|
SET (ENGINE_COMMON_INCLUDES ${ENGINE_DEFAULT_INCLUDES} ${Boost_INCLUDE_DIR} ${LIBXML2_INCLUDE_DIR} ${ENGINE_UTILS_MESSAGEQCPP_INCLUDE} ${ENGINE_WE_SHARED_INCLUDE} ${ENGINE_UTILS_IDBDATAFILE_INCLUDE} ${ENGINE_UTILS_LOGGINGCPP_INCLUDE} ${ENGINE_UTILS_CONFIGCPP_INCLUDE} ${ENGINE_UTILS_COMPRESS_INCLUDE} ${ENGINE_VERSIONING_BRM_INCLUDE} ${ENGINE_UTILS_ROWGROUP_INCLUDE} ${ENGINE_UTILS_COMMON_INCLUDE} ${ENGINE_UTILS_DATACONVERT_INCLUDE} ${ENGINE_UTILS_RWLOCK_INCLUDE} ${ENGINE_UTILS_FUNCEXP_INCLUDE} ${ENGINE_OAMAPPS_ALARMMANAGER_INCLUDE} ${ENGINE_UTILS_INCLUDE} ${ENGINE_OAM_OAMCPP_INCLUDE} ${ENGINE_DBCON_DDLPKGPROC_INCLUDE} ${ENGINE_DBCON_DDLPKG_INCLUDE} ${ENGINE_DBCON_EXECPLAN_INCLUDE} ${ENGINE_UTILS_STARTUP_INCLUDE} ${ENGINE_DBCON_JOBLIST_INCLUDE} ${ENGINE_WE_WRAPPER_INCLUDE} ${ENGINE_WE_SERVER_INCLUDE} ${ENGINE_DBCON_DMLPKG_INCLUDE} ${ENGINE_WE_CLIENT_INCLUDE} ${ENGINE_DBCON_DMLPKGPROC_INCLUDE} ${ENGINE_UTILS_CACHEUTILS_INCLUDE} ${ENGINE_UTILS_MYSQLCL_INCLUDE} ${ENGINE_UTILS_QUERYTELE_INCLUDE} ${ENGINE_UTILS_THRIFT_INCLUDE} ${ENGINE_UTILS_JOINER_INCLUDE} ${ENGINE_UTILS_THREADPOOL_INCLUDE} ${ENGINE_UTILS_BATCHLDR_INCLUDE} ${ENGINE_UTILS_DDLCLEANUP_INCLUDE} ${ENGINE_UTILS_QUERYSTATS_INCLUDE} ${ENGINE_WE_CONFIGCPP_INCLUDE} ${ENGINE_SERVER_SQL_INCLUDE} ${ENGINE_SERVER_INCLUDE_INCLUDE} ${ENGINE_SERVER_PCRE_INCLUDE} ${ENGINE_UTILS_UDFSDK_INCLUDE})
|
|
|
|
ADD_SUBDIRECTORY(utils)
|
|
ADD_SUBDIRECTORY(oam/oamcpp)
|
|
ADD_SUBDIRECTORY(dbcon/execplan)
|
|
ADD_SUBDIRECTORY(dbcon/joblist)
|
|
ADD_SUBDIRECTORY(versioning)
|
|
ADD_SUBDIRECTORY(oam)
|
|
ADD_SUBDIRECTORY(writeengine/wrapper)
|
|
ADD_SUBDIRECTORY(writeengine/client)
|
|
ADD_SUBDIRECTORY(writeengine/xml)
|
|
ADD_SUBDIRECTORY(writeengine/redistribute)
|
|
ADD_SUBDIRECTORY(dbcon/ddlpackage)
|
|
ADD_SUBDIRECTORY(dbcon/ddlpackageproc)
|
|
ADD_SUBDIRECTORY(dbcon/dmlpackage)
|
|
ADD_SUBDIRECTORY(dbcon/dmlpackageproc)
|
|
ADD_SUBDIRECTORY(dbcon/mysql)
|
|
ADD_SUBDIRECTORY(exemgr)
|
|
ADD_SUBDIRECTORY(ddlproc)
|
|
ADD_SUBDIRECTORY(dmlproc)
|
|
ADD_SUBDIRECTORY(procmon)
|
|
ADD_SUBDIRECTORY(procmgr)
|
|
ADD_SUBDIRECTORY(oamapps)
|
|
ADD_SUBDIRECTORY(decomsvr)
|
|
ADD_SUBDIRECTORY(primitives)
|
|
ADD_SUBDIRECTORY(tools)
|
|
ADD_SUBDIRECTORY(writeengine/server)
|
|
ADD_SUBDIRECTORY(writeengine/bulk)
|
|
ADD_SUBDIRECTORY(writeengine/splitter)
|
|
|
|
INCLUDE(cpackEngineRPM.cmake)
|
|
INCLUDE(cpackEngineDEB.cmake)
|
|
|