mirror of https://github.com/milvus-io/milvus.git
MS-590 Refine cmake code to support cpplint
Former-commit-id: 583d31a79b3b491c3c3bf7eda9fa613d1c6a58ffpull/191/head
parent
7761fd9d12
commit
455a31c8bc
|
@ -44,13 +44,7 @@ set(MILVUS_VERSION "${GIT_BRANCH_NAME}")
|
||||||
string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]" MILVUS_VERSION "${MILVUS_VERSION}")
|
string(REGEX MATCH "[0-9]+\\.[0-9]+\\.[0-9]" MILVUS_VERSION "${MILVUS_VERSION}")
|
||||||
|
|
||||||
find_package(ClangTools)
|
find_package(ClangTools)
|
||||||
if("$ENV{CMAKE_EXPORT_COMPILE_COMMANDS}" STREQUAL "1" OR CLANG_TIDY_FOUND)
|
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
||||||
# Generate a Clang compile_commands.json "compilation database" file for use
|
|
||||||
# with various development tools, such as Vim's YouCompleteMe plugin.
|
|
||||||
# See http://clang.llvm.org/docs/JSONCompilationDatabase.html
|
|
||||||
set(CMAKE_EXPORT_COMPILE_COMMANDS 1)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
set(BUILD_SUPPORT_DIR "${CMAKE_SOURCE_DIR}/build-support")
|
set(BUILD_SUPPORT_DIR "${CMAKE_SOURCE_DIR}/build-support")
|
||||||
|
|
||||||
if(CMAKE_BUILD_TYPE STREQUAL "Release")
|
if(CMAKE_BUILD_TYPE STREQUAL "Release")
|
||||||
|
@ -71,7 +65,7 @@ if(MILVUS_VERSION_MAJOR STREQUAL ""
|
||||||
OR MILVUS_VERSION_MINOR STREQUAL ""
|
OR MILVUS_VERSION_MINOR STREQUAL ""
|
||||||
OR MILVUS_VERSION_PATCH STREQUAL "")
|
OR MILVUS_VERSION_PATCH STREQUAL "")
|
||||||
message(WARNING "Failed to determine Milvus version from git branch name")
|
message(WARNING "Failed to determine Milvus version from git branch name")
|
||||||
set(MILVUS_VERSION "0.4.0")
|
set(MILVUS_VERSION "0.5.0")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
message(STATUS "Build version = ${MILVUS_VERSION}")
|
message(STATUS "Build version = ${MILVUS_VERSION}")
|
||||||
|
@ -182,6 +176,9 @@ endif()
|
||||||
find_program(CPPLINT_BIN NAMES cpplint cpplint.py HINTS ${BUILD_SUPPORT_DIR})
|
find_program(CPPLINT_BIN NAMES cpplint cpplint.py HINTS ${BUILD_SUPPORT_DIR})
|
||||||
message(STATUS "Found cpplint executable at ${CPPLINT_BIN}")
|
message(STATUS "Found cpplint executable at ${CPPLINT_BIN}")
|
||||||
|
|
||||||
|
#
|
||||||
|
# "make lint" targets
|
||||||
|
#
|
||||||
add_custom_target(lint
|
add_custom_target(lint
|
||||||
${PYTHON_EXECUTABLE}
|
${PYTHON_EXECUTABLE}
|
||||||
${BUILD_SUPPORT_DIR}/run_cpplint.py
|
${BUILD_SUPPORT_DIR}/run_cpplint.py
|
||||||
|
@ -194,11 +191,11 @@ add_custom_target(lint
|
||||||
${MILVUS_LINT_QUIET})
|
${MILVUS_LINT_QUIET})
|
||||||
|
|
||||||
#
|
#
|
||||||
# "make format" and "make check-format" targets
|
# "make clang-format" and "make check-clang-format" targets
|
||||||
#
|
#
|
||||||
if(${CLANG_FORMAT_FOUND})
|
if(${CLANG_FORMAT_FOUND})
|
||||||
# runs clang format and updates files in place.
|
# runs clang format and updates files in place.
|
||||||
add_custom_target(format
|
add_custom_target(clang-format
|
||||||
${PYTHON_EXECUTABLE}
|
${PYTHON_EXECUTABLE}
|
||||||
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
||||||
--clang_format_binary
|
--clang_format_binary
|
||||||
|
@ -211,7 +208,7 @@ if(${CLANG_FORMAT_FOUND})
|
||||||
${MILVUS_LINT_QUIET})
|
${MILVUS_LINT_QUIET})
|
||||||
|
|
||||||
# runs clang format and exits with a non-zero exit code if any files need to be reformatted
|
# runs clang format and exits with a non-zero exit code if any files need to be reformatted
|
||||||
add_custom_target(check-format
|
add_custom_target(check-clang-format
|
||||||
${PYTHON_EXECUTABLE}
|
${PYTHON_EXECUTABLE}
|
||||||
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
${BUILD_SUPPORT_DIR}/run_clang_format.py
|
||||||
--clang_format_binary
|
--clang_format_binary
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
*cmake-build-debug*
|
||||||
|
*cmake-build-release*
|
||||||
|
*cmake_build*
|
||||||
|
*src/thirdparty*
|
||||||
|
*src/core/thirdparty*
|
||||||
|
*src/grpc*
|
102
cpp/build.sh
102
cpp/build.sh
|
@ -8,10 +8,18 @@ BUILD_COVERAGE="OFF"
|
||||||
DB_PATH="/opt/milvus"
|
DB_PATH="/opt/milvus"
|
||||||
PROFILING="OFF"
|
PROFILING="OFF"
|
||||||
USE_JFROG_CACHE="OFF"
|
USE_JFROG_CACHE="OFF"
|
||||||
|
RUN_CPPLINT="OFF"
|
||||||
|
CUDA_COMPILER=/usr/local/cuda/bin/nvcc
|
||||||
|
|
||||||
while getopts "p:d:t:uhrcgj" arg
|
while getopts "p:d:t:ulrcgjh" arg
|
||||||
do
|
do
|
||||||
case $arg in
|
case $arg in
|
||||||
|
p)
|
||||||
|
INSTALL_PREFIX=$OPTARG
|
||||||
|
;;
|
||||||
|
d)
|
||||||
|
DB_PATH=$OPTARG
|
||||||
|
;;
|
||||||
t)
|
t)
|
||||||
BUILD_TYPE=$OPTARG # BUILD_TYPE
|
BUILD_TYPE=$OPTARG # BUILD_TYPE
|
||||||
;;
|
;;
|
||||||
|
@ -19,11 +27,8 @@ do
|
||||||
echo "Build and run unittest cases" ;
|
echo "Build and run unittest cases" ;
|
||||||
BUILD_UNITTEST="ON";
|
BUILD_UNITTEST="ON";
|
||||||
;;
|
;;
|
||||||
p)
|
l)
|
||||||
INSTALL_PREFIX=$OPTARG
|
RUN_CPPLINT="ON"
|
||||||
;;
|
|
||||||
d)
|
|
||||||
DB_PATH=$OPTARG
|
|
||||||
;;
|
;;
|
||||||
r)
|
r)
|
||||||
if [[ -d cmake_build ]]; then
|
if [[ -d cmake_build ]]; then
|
||||||
|
@ -44,63 +49,86 @@ do
|
||||||
echo "
|
echo "
|
||||||
|
|
||||||
parameter:
|
parameter:
|
||||||
-t: build type(default: Debug)
|
|
||||||
-u: building unit test options(default: OFF)
|
|
||||||
-p: install prefix(default: $(pwd)/milvus)
|
-p: install prefix(default: $(pwd)/milvus)
|
||||||
-d: db path(default: /opt/milvus)
|
-d: db path(default: /opt/milvus)
|
||||||
|
-t: build type(default: Debug)
|
||||||
|
-u: building unit test options(default: OFF)
|
||||||
|
-l: run cpplint, clang-format and clang-tidy(default: OFF)
|
||||||
-r: remove previous build directory(default: OFF)
|
-r: remove previous build directory(default: OFF)
|
||||||
-c: code coverage(default: OFF)
|
-c: code coverage(default: OFF)
|
||||||
-g: profiling(default: OFF)
|
-g: profiling(default: OFF)
|
||||||
-j: use jfrog cache build directory
|
-j: use jfrog cache build directory(default: OFF)
|
||||||
|
-h: help
|
||||||
|
|
||||||
usage:
|
usage:
|
||||||
./build.sh -t \${BUILD_TYPE} [-u] [-h] [-g] [-r] [-c] [-k] [-j]
|
./build.sh -p \${INSTALL_PREFIX} -t \${BUILD_TYPE} [-u] [-l] [-r] [-c] [-g] [-j] [-h]
|
||||||
"
|
"
|
||||||
exit 0
|
exit 0
|
||||||
;;
|
;;
|
||||||
?)
|
?)
|
||||||
echo "unknown argument"
|
echo "ERROR! unknown argument"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
if [[ ! -d cmake_build ]]; then
|
if [[ ! -d cmake_build ]]; then
|
||||||
mkdir cmake_build
|
mkdir cmake_build
|
||||||
MAKE_CLEAN="ON"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd cmake_build
|
cd cmake_build
|
||||||
|
|
||||||
CUDA_COMPILER=/usr/local/cuda/bin/nvcc
|
CMAKE_CMD="cmake \
|
||||||
|
-DBUILD_UNIT_TEST=${BUILD_UNITTEST} \
|
||||||
|
-DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX}
|
||||||
|
-DCMAKE_BUILD_TYPE=${BUILD_TYPE} \
|
||||||
|
-DCMAKE_CUDA_COMPILER=${CUDA_COMPILER} \
|
||||||
|
-DBUILD_COVERAGE=${BUILD_COVERAGE} \
|
||||||
|
-DMILVUS_DB_PATH=${DB_PATH} \
|
||||||
|
-DMILVUS_ENABLE_PROFILING=${PROFILING} \
|
||||||
|
-DUSE_JFROG_CACHE=${USE_JFROG_CACHE} \
|
||||||
|
../"
|
||||||
|
echo ${CMAKE_CMD}
|
||||||
|
${CMAKE_CMD}
|
||||||
|
|
||||||
if [[ ${MAKE_CLEAN} == "ON" ]]; then
|
if [[ ${MAKE_CLEAN} == "ON" ]]; then
|
||||||
CMAKE_CMD="cmake -DBUILD_UNIT_TEST=${BUILD_UNITTEST} \
|
|
||||||
-DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX}
|
|
||||||
-DCMAKE_BUILD_TYPE=${BUILD_TYPE} \
|
|
||||||
-DCMAKE_CUDA_COMPILER=${CUDA_COMPILER} \
|
|
||||||
-DBUILD_COVERAGE=${BUILD_COVERAGE} \
|
|
||||||
-DMILVUS_DB_PATH=${DB_PATH} \
|
|
||||||
-DMILVUS_ENABLE_PROFILING=${PROFILING} \
|
|
||||||
-DUSE_JFROG_CACHE=${USE_JFROG_CACHE} \
|
|
||||||
-DCMAKE_EXPORT_COMPILE_COMMANDS=ON \
|
|
||||||
../"
|
|
||||||
echo ${CMAKE_CMD}
|
|
||||||
|
|
||||||
${CMAKE_CMD}
|
|
||||||
make clean
|
make clean
|
||||||
fi
|
fi
|
||||||
|
|
||||||
make -j 4 || exit 1
|
if [[ ${RUN_CPPLINT} == "ON" ]]; then
|
||||||
|
# cpplint check
|
||||||
|
make lint
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "ERROR! cpplint check not pass"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
# clang-format check
|
||||||
|
make check-clang-format
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "ERROR! clang-format check failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
# clang-tidy check
|
||||||
|
make check-clang-tidy
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
echo "ERROR! clang-tidy check failed"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
# compile and build
|
||||||
|
make -j 4 || exit 1
|
||||||
|
|
||||||
if [[ ${BUILD_TYPE} != "Debug" ]]; then
|
# strip binary symbol
|
||||||
strip src/milvus_server
|
if [[ ${BUILD_TYPE} != "Debug" ]]; then
|
||||||
fi
|
strip src/milvus_server
|
||||||
|
fi
|
||||||
|
|
||||||
make install || exit 1
|
make install || exit 1
|
||||||
|
|
||||||
if [[ ${BUILD_COVERAGE} == "ON" ]]; then
|
# evaluate code coverage
|
||||||
cd -
|
if [[ ${BUILD_COVERAGE} == "ON" ]]; then
|
||||||
bash `pwd`/coverage.sh
|
cd -
|
||||||
cd -
|
bash `pwd`/coverage.sh
|
||||||
fi
|
cd -
|
||||||
|
fi
|
||||||
|
fi
|
|
@ -110,6 +110,7 @@ endif()
|
||||||
#----------------------------------------------------------------------
|
#----------------------------------------------------------------------
|
||||||
set_option_category("Test and benchmark")
|
set_option_category("Test and benchmark")
|
||||||
|
|
||||||
|
unset(MILVUS_BUILD_TESTS CACHE)
|
||||||
if (BUILD_UNIT_TEST)
|
if (BUILD_UNIT_TEST)
|
||||||
define_option(MILVUS_BUILD_TESTS "Build the MILVUS googletest unit tests" ON)
|
define_option(MILVUS_BUILD_TESTS "Build the MILVUS googletest unit tests" ON)
|
||||||
else()
|
else()
|
||||||
|
|
Loading…
Reference in New Issue