CMakeLists.txt 9.9 KB
Newer Older
J
jinhai 已提交
1
#-------------------------------------------------------------------------------
J
jinhai 已提交
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you 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.
J
jinhai 已提交
18 19
#-------------------------------------------------------------------------------

J
jinhai 已提交
20

Q
quicksilver 已提交
21
cmake_minimum_required(VERSION 3.12)
Z
zhiru 已提交
22
message(STATUS "Building using CMake version: ${CMAKE_VERSION}")
J
jinhai 已提交
23

24 25
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${CMAKE_CURRENT_SOURCE_DIR}/cmake")

Y
youny626 已提交
26
MACRO(GET_CURRENT_TIME CURRENT_TIME)
27
    execute_process(COMMAND "date" +"%Y-%m-%d %H:%M.%S" OUTPUT_VARIABLE ${CURRENT_TIME})
Y
youny626 已提交
28
ENDMACRO(GET_CURRENT_TIME)
29 30 31 32 33

GET_CURRENT_TIME(BUILD_TIME)
string(REGEX REPLACE "\n" "" BUILD_TIME ${BUILD_TIME})
message(STATUS "Build time = ${BUILD_TIME}")

Z
Zhiru Zhu 已提交
34
MACRO(GET_GIT_BRANCH_NAME GIT_BRANCH_NAME)
35
    execute_process(COMMAND sh "-c" "git log --decorate | head -n 1 | sed 's/.*(\\(.*\\))/\\1/' | sed 's/.* \\(.*\\),.*/\\1/' | sed 's=[a-zA-Z]*\/==g'"
36
            OUTPUT_VARIABLE ${GIT_BRANCH_NAME})
Z
Zhiru Zhu 已提交
37
ENDMACRO(GET_GIT_BRANCH_NAME)
38 39

GET_GIT_BRANCH_NAME(GIT_BRANCH_NAME)
S
starlord 已提交
40
message(STATUS "GIT_BRANCH_NAME = ${GIT_BRANCH_NAME}")
Z
Zhiru Zhu 已提交
41
if (NOT GIT_BRANCH_NAME STREQUAL "")
G
groot 已提交
42
    string(REGEX REPLACE "\n" "" GIT_BRANCH_NAME ${GIT_BRANCH_NAME})
Y
youny626 已提交
43
endif ()
44

Y
youny626 已提交
45
set(MILVUS_VERSION "${GIT_BRANCH_NAME}")
G
groot 已提交
46
string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]" MILVUS_VERSION "${MILVUS_VERSION}")
47

Y
youny626 已提交
48
if (CMAKE_BUILD_TYPE STREQUAL "Release")
Z
zhiru 已提交
49
    set(BUILD_TYPE "Release")
Y
youny626 已提交
50
else ()
Z
zhiru 已提交
51
    set(BUILD_TYPE "Debug")
Y
youny626 已提交
52
endif ()
53 54
message(STATUS "Build type = ${BUILD_TYPE}")

G
groot 已提交
55
project(milvus VERSION "${MILVUS_VERSION}")
Y
youny626 已提交
56
project(milvus_engine LANGUAGES CXX)
X
xj.lin 已提交
57

S
starlord 已提交
58 59 60
unset(CMAKE_EXPORT_COMPILE_COMMANDS CACHE)
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)

G
groot 已提交
61 62 63
set(MILVUS_VERSION_MAJOR "${milvus_VERSION_MAJOR}")
set(MILVUS_VERSION_MINOR "${milvus_VERSION_MINOR}")
set(MILVUS_VERSION_PATCH "${milvus_VERSION_PATCH}")
Z
zhiru 已提交
64

Y
youny626 已提交
65
if (MILVUS_VERSION_MAJOR STREQUAL ""
G
groot 已提交
66 67
        OR MILVUS_VERSION_MINOR STREQUAL ""
        OR MILVUS_VERSION_PATCH STREQUAL "")
G
groot 已提交
68
    message(WARNING "Failed to determine Milvus version from git branch name")
G
groot 已提交
69
    set(MILVUS_VERSION "0.6.0")
Z
zhiru 已提交
70 71
endif()

G
groot 已提交
72
message(STATUS "Build version = ${MILVUS_VERSION}")
G
groot 已提交
73
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/src/version.h.in ${CMAKE_CURRENT_SOURCE_DIR}/src/version.h @ONLY)
G
groot 已提交
74

G
groot 已提交
75 76 77
message(STATUS "Milvus version: "
        "${MILVUS_VERSION_MAJOR}.${MILVUS_VERSION_MINOR}.${MILVUS_VERSION_PATCH} "
        "(full: '${MILVUS_VERSION}')")
Z
zhiru 已提交
78

J
jinhai 已提交
79
set(CMAKE_CXX_STANDARD 14)
Z
zhiru 已提交
80
set(CMAKE_CXX_STANDARD_REQUIRED on)
J
jinhai 已提交
81

Y
youny626 已提交
82
if (CMAKE_SYSTEM_PROCESSOR MATCHES "(x86)|(X86)|(amd64)|(AMD64)")
Z
zhiru 已提交
83
    message(STATUS "Building milvus_engine on x86 architecture")
G
groot 已提交
84
    set(MILVUS_BUILD_ARCH x86_64)
Y
youny626 已提交
85
elseif (CMAKE_SYSTEM_PROCESSOR MATCHES "(ppc)")
Z
zhiru 已提交
86
    message(STATUS "Building milvus_engine on ppc architecture")
G
groot 已提交
87
    set(MILVUS_BUILD_ARCH ppc64le)
Y
youny626 已提交
88
else ()
Z
zhiru 已提交
89
    message(WARNING "Unknown processor type")
Z
zhiru 已提交
90
    message(WARNING "CMAKE_SYSTEM_PROCESSOR=${CMAKE_SYSTEM_PROCESSOR}")
G
groot 已提交
91
    set(MILVUS_BUILD_ARCH unknown)
Y
youny626 已提交
92
endif ()
J
jinhai 已提交
93

Z
zhiru 已提交
94
# Ensure that a default make is set
Y
youny626 已提交
95 96
if ("${MAKE}" STREQUAL "")
    if (NOT MSVC)
Z
zhiru 已提交
97
        find_program(MAKE make)
Y
youny626 已提交
98 99
    endif ()
endif ()
Z
zhiru 已提交
100 101

find_path(MYSQL_INCLUDE_DIR
Y
youny626 已提交
102 103
        NAMES "mysql.h"
        PATH_SUFFIXES "mysql")
Z
zhiru 已提交
104 105
if (${MYSQL_INCLUDE_DIR} STREQUAL "MYSQL_INCLUDE_DIR-NOTFOUND")
    message(FATAL_ERROR "Could not found MySQL include directory")
Y
youny626 已提交
106
else ()
Z
zhiru 已提交
107
    include_directories(${MYSQL_INCLUDE_DIR})
Y
youny626 已提交
108
endif ()
Z
zhiru 已提交
109 110 111 112

set(MILVUS_SOURCE_DIR ${PROJECT_SOURCE_DIR})
set(MILVUS_BINARY_DIR ${PROJECT_BINARY_DIR})
set(MILVUS_ENGINE_SRC ${PROJECT_SOURCE_DIR}/src)
W
wxyu 已提交
113
set(MILVUS_THIRDPARTY_SRC ${PROJECT_SOURCE_DIR}/thirdparty)
Z
zhiru 已提交
114

Z
zhiru 已提交
115 116 117 118 119
include(ExternalProject)
include(DefineOptions)
include(BuildUtils)
include(ThirdPartyPackages)

120 121 122 123 124 125 126 127 128 129 130
if (MILVUS_USE_CCACHE)
    find_program(CCACHE_FOUND ccache)
    if (CCACHE_FOUND)
        message(STATUS "Using ccache: ${CCACHE_FOUND}")
        set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ${CCACHE_FOUND})
        set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ${CCACHE_FOUND})
        # let ccache preserve C++ comments, because some of them may be
        # meaningful to the compiler
        set(ENV{CCACHE_COMMENTS} "1")
    endif (CCACHE_FOUND)
endif ()
131

Z
Zhiru Zhu 已提交
132 133
set(MILVUS_CPU_VERSION false)
if (MILVUS_GPU_VERSION)
Y
youny626 已提交
134 135 136 137 138
    message(STATUS "Building Milvus GPU version")
    add_compile_definitions("MILVUS_GPU_VERSION")
    enable_language(CUDA)
    find_package(CUDA 10 REQUIRED)
    set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -Xcompiler -fPIC -std=c++11 -D_FORCE_INLINES --expt-extended-lambda")
Z
Zhiru Zhu 已提交
139 140 141 142
else ()
    message(STATUS "Building Milvus CPU version")
    set(MILVUS_CPU_VERSION true)
    add_compile_definitions("MILVUS_CPU_VERSION")
Y
youny626 已提交
143 144
endif ()

145 146 147 148
if (MILVUS_WITH_PROMETHEUS)
    add_compile_definitions("MILVUS_WITH_PROMETHEUS")
endif ()

Y
youny626 已提交
149 150 151 152 153 154 155 156 157 158 159
if (CMAKE_BUILD_TYPE STREQUAL "Release")
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O3 -fPIC -DELPP_THREAD_SAFE -fopenmp")
    if (MILVUS_GPU_VERSION)
        set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -O3")
    endif ()
else ()
    set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O0 -g -fPIC -DELPP_THREAD_SAFE -fopenmp")
    if (MILVUS_GPU_VERSION)
        set(CUDA_NVCC_FLAGS "${CUDA_NVCC_FLAGS} -O0 -g")
    endif ()
endif ()
J
jinhai 已提交
160

X
update  
xiaojun.lin 已提交
161 162 163 164
if (CUSTOMIZATION)
    add_definitions(-DCUSTOMIZATION)
endif (CUSTOMIZATION)

Y
youny626 已提交
165
config_summary()
Z
zhiru 已提交
166
add_subdirectory(src)
J
jinhai 已提交
167

G
groot 已提交
168
if (BUILD_UNIT_TEST STREQUAL "ON")
Z
zhiru 已提交
169 170
    if (BUILD_COVERAGE STREQUAL "ON")
        set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fprofile-arcs -ftest-coverage")
Y
youny626 已提交
171
    endif ()
J
jinhai 已提交
172
    add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/unittest)
Y
youny626 已提交
173
endif ()
Y
yu yunfeng 已提交
174

G
groot 已提交
175
add_custom_target(Clean-All COMMAND ${CMAKE_BUILD_TOOL} clean)
176

Y
youny626 已提交
177
if ("${MILVUS_DB_PATH}" STREQUAL "")
G
groot 已提交
178
    set(MILVUS_DB_PATH "/tmp/milvus")
Y
youny626 已提交
179
endif ()
Z
ZhifengZhang-CN 已提交
180 181 182

if (MILVUS_GPU_VERSION)
    configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/server_gpu_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/server_config.yaml)
183
else ()
Z
ZhifengZhang-CN 已提交
184
    configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/server_cpu_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/server_config.yaml)
185
endif ()
Z
ZhifengZhang-CN 已提交
186

G
groot 已提交
187 188
configure_file(${CMAKE_CURRENT_SOURCE_DIR}/conf/log_config.template ${CMAKE_CURRENT_SOURCE_DIR}/conf/log_config.conf)

189
install(DIRECTORY scripts/
190
        DESTINATION scripts
191
        FILE_PERMISSIONS OWNER_EXECUTE OWNER_WRITE OWNER_READ
192 193 194
        GROUP_EXECUTE GROUP_READ
        WORLD_EXECUTE WORLD_READ
        FILES_MATCHING PATTERN "*.sh")
195 196
install(FILES
        conf/server_config.yaml
G
groot 已提交
197
        conf/log_config.conf
198 199
        DESTINATION
        conf)
200

Y
youny626 已提交
201 202 203
find_package(Python COMPONENTS Interpreter Development)
find_package(ClangTools)
set(BUILD_SUPPORT_DIR "${CMAKE_SOURCE_DIR}/build-support")
204 205 206 207

#
# "make lint" target
#
Y
youny626 已提交
208 209 210
if (NOT MILVUS_VERBOSE_LINT)
    set(MILVUS_LINT_QUIET "--quiet")
endif ()
211

Y
youny626 已提交
212 213 214 215 216
if (NOT LINT_EXCLUSIONS_FILE)
    # source files matching a glob from a line in this file
    # will be excluded from linting (cpplint, clang-tidy, clang-format)
    set(LINT_EXCLUSIONS_FILE ${BUILD_SUPPORT_DIR}/lint_exclusions.txt)
endif ()
217

218 219 220
find_program(CPPLINT_BIN NAMES cpplint cpplint.py HINTS ${BUILD_SUPPORT_DIR})
message(STATUS "Found cpplint executable at ${CPPLINT_BIN}")

221 222 223
#
# "make lint" targets
#
224
add_custom_target(lint
Y
youny626 已提交
225 226 227 228 229 230 231 232 233
        ${PYTHON_EXECUTABLE}
        ${BUILD_SUPPORT_DIR}/run_cpplint.py
        --cpplint_binary
        ${CPPLINT_BIN}
        --exclude_globs
        ${LINT_EXCLUSIONS_FILE}
        --source_dir
        ${CMAKE_CURRENT_SOURCE_DIR}
        ${MILVUS_LINT_QUIET})
234

235
#
236
# "make clang-format" and "make check-clang-format" targets
237
#
Y
youny626 已提交
238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263
if (${CLANG_FORMAT_FOUND})
    # runs clang format and updates files in place.
    add_custom_target(clang-format
            ${PYTHON_EXECUTABLE}
            ${BUILD_SUPPORT_DIR}/run_clang_format.py
            --clang_format_binary
            ${CLANG_FORMAT_BIN}
            --exclude_globs
            ${LINT_EXCLUSIONS_FILE}
            --source_dir
            ${CMAKE_CURRENT_SOURCE_DIR}/src
            --fix
            ${MILVUS_LINT_QUIET})

    # runs clang format and exits with a non-zero exit code if any files need to be reformatted
    add_custom_target(check-clang-format
            ${PYTHON_EXECUTABLE}
            ${BUILD_SUPPORT_DIR}/run_clang_format.py
            --clang_format_binary
            ${CLANG_FORMAT_BIN}
            --exclude_globs
            ${LINT_EXCLUSIONS_FILE}
            --source_dir
            ${CMAKE_CURRENT_SOURCE_DIR}/src
            ${MILVUS_LINT_QUIET})
endif ()
264

265 266 267
#
# "make clang-tidy" and "make check-clang-tidy" targets
#
Y
youny626 已提交
268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296
if (${CLANG_TIDY_FOUND})
    # runs clang-tidy and attempts to fix any warning automatically
    add_custom_target(clang-tidy
            ${PYTHON_EXECUTABLE}
            ${BUILD_SUPPORT_DIR}/run_clang_tidy.py
            --clang_tidy_binary
            ${CLANG_TIDY_BIN}
            --exclude_globs
            ${LINT_EXCLUSIONS_FILE}
            --compile_commands
            ${CMAKE_BINARY_DIR}/compile_commands.json
            --source_dir
            ${CMAKE_CURRENT_SOURCE_DIR}/src
            --fix
            ${MILVUS_LINT_QUIET})

    # runs clang-tidy and exits with a non-zero exit code if any errors are found.
    add_custom_target(check-clang-tidy
            ${PYTHON_EXECUTABLE}
            ${BUILD_SUPPORT_DIR}/run_clang_tidy.py
            --clang_tidy_binary
            ${CLANG_TIDY_BIN}
            --exclude_globs
            ${LINT_EXCLUSIONS_FILE}
            --compile_commands
            ${CMAKE_BINARY_DIR}/compile_commands.json
            --source_dir
            ${CMAKE_CURRENT_SOURCE_DIR}/src
            ${MILVUS_LINT_QUIET})
Q
quicksilver 已提交
297
endif ()