forked from HuangDunD/RucDDBS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
CMakeLists.txt
executable file
·133 lines (113 loc) · 4.66 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
cmake_minimum_required(VERSION 3.2)
project(RUCDDBS)
option(RUCDDBS_STORAGE "if build kv_storage" OFF)
option(RUCDDBS_TRANSACTION "if build transaction" OFF)
option(RUCDDBS_TEST "build rucddbs test" OFF)
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED true)
set(CMAKE_CXX_FLAGS "-Wall -ggdb -O0")
IF(NOT CMAKE_BUILD_TYPE)
SET(CMAKE_BUILD_TYPE Release)
ENDIF()
# find_package(GTest REQUIRED)
find_package(Threads REQUIRED)
# include_directories(${GTEST_INCLUDE_DIRS})
find_library(THRIFT_LIB NAMES thrift)
if (NOT THRIFT_LIB)
set(THRIFT_LIB "")
endif()
find_library(THRIFTNB_LIB NAMES thriftnb)
if (NOT THRIFTNB_LIB)
set(THRIFTNB_LIB "")
endif()
find_path(BRPC_INCLUDE_PATH NAMES brpc/server.h)
if(LINK_SO)
find_library(BRPC_LIB NAMES brpc)
else()
find_library(BRPC_LIB NAMES libbrpc.a brpc)
endif()
if((NOT BRPC_INCLUDE_PATH) OR (NOT BRPC_LIB))
message(FATAL_ERROR "Fail to find brpc")
endif()
include_directories(${BRPC_INCLUDE_PATH})
find_path(GFLAGS_INCLUDE_PATH gflags/gflags.h)
find_library(GFLAGS_LIBRARY NAMES gflags libgflags)
if((NOT GFLAGS_INCLUDE_PATH) OR (NOT GFLAGS_LIBRARY))
message(FATAL_ERROR "Fail to find gflags")
endif()
include_directories(${GFLAGS_INCLUDE_PATH})
find_path(LEVELDB_INCLUDE_PATH NAMES leveldb/db.h)
find_library(LEVELDB_LIB NAMES leveldb)
if ((NOT LEVELDB_INCLUDE_PATH) OR (NOT LEVELDB_LIB))
message(FATAL_ERROR "Fail to find leveldb")
endif()
include_directories(${LEVELDB_INCLUDE_PATH})
find_package(OpenSSL)
include_directories(${OPENSSL_INCLUDE_DIR})
set(DYNAMIC_LIB
${CMAKE_THREAD_LIBS_INIT}
${GFLAGS_LIBRARY}
${PROTOBUF_LIBRARIES}
${LEVELDB_LIB}
${OPENSSL_CRYPTO_LIBRARY}
${OPENSSL_SSL_LIBRARY}
${THRIFT_LIB}
${THRIFTNB_LIB}
dl
)
include_directories(${PROJECT_SOURCE_DIR})
include_directories(${PROJECT_SOURCE_DIR}/meta_server/)
include_directories(${PROJECT_SOURCE_DIR}/meta_server/build)
include_directories(${PROJECT_SOURCE_DIR}/include/)
set(INCLUDE_DIR ${PROJECT_SOURCE_DIR}/include/)
set(STORAGE_DIR ${PROJECT_SOURCE_DIR}/include/storage/)
set(TRANSACTION_DIR ${PROJECT_SOURCE_DIR}/include/transaction/)
set(IMMEMORY_DIR ${PROJECT_SOURCE_DIR}/include/Inmemory/)
set(RECOVERY_DIR ${PROJECT_SOURCE_DIR}/include/recovery/)
set(EXECUTION_DIR ${PROJECT_SOURCE_DIR}/src/execution)
set(ENGINE_DIR ${PROJECT_SOURCE_DIR}/include/engine/)
set(PARSER_DIR ${PROJECT_SOURCE_DIR}/include/parser/)
add_library(config STATIC dbconfig.cc)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/storage STORAGE_SRC)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/transaction TRANSACTION_SRC)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/recovery RECOVERY_SRC)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/execution EXECUTION_SRC)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/engine ENGINE_SRC)
aux_source_directory(${PROJECT_SOURCE_DIR}/src/parser PARSER_SRC)
# 添加依赖
add_subdirectory(${PROJECT_SOURCE_DIR}/deps/snappy)
add_subdirectory(${PROJECT_SOURCE_DIR}/include/proto)
IF(RUCDDBS_TEST)
message("build ructest")
add_subdirectory(${PROJECT_SOURCE_DIR}/deps/googletest)
add_subdirectory(${PROJECT_SOURCE_DIR}/test/storage)
add_subdirectory(${PROJECT_SOURCE_DIR}/test/recovery)
add_subdirectory(${PROJECT_SOURCE_DIR}/test/transaction)
add_subdirectory(${PROJECT_SOURCE_DIR}/test/benchmark)
endif()
if(RUCDDBS_STORAGE)
message("build rucddbs storage")
add_subdirectory(${PROJECT_SOURCE_DIR}/src/storage)
add_executable(storage_example ${PROJECT_SOURCE_DIR}/storage_example.cpp)
target_link_libraries(storage_example KV_STORAGE_BETA)
endif()
if(RUCDDBS_TRANSACTION)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/recovery)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/transaction)
endif()
message("build rucddbs engine & store")
add_subdirectory(${PROJECT_SOURCE_DIR}/src/recovery)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/storage)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/engine)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/parser)
add_subdirectory(${PROJECT_SOURCE_DIR}/src/transaction)
# add_executable(storage_example ${PROJECT_SOURCE_DIR}/storage_example.cpp)
add_executable(client1 ${PROJECT_SOURCE_DIR}/client.cpp)
add_executable(client2 ${PROJECT_SOURCE_DIR}/client.cpp)
add_executable(server1 ${PROJECT_SOURCE_DIR}/server1.cpp meta_server/build/meta_service.pb.cc dbconfig.cc)
add_executable(server2 ${PROJECT_SOURCE_DIR}/server2.cpp meta_server/build/meta_service.pb.cc dbconfig.cc)
# target_link_libraries(storage_example KV_STORAGE_BETA)
target_link_libraries(client1 proto KV_STORAGE_BETA engine parser)
target_link_libraries(client2 proto KV_STORAGE_BETA engine parser)
target_link_libraries(server1 proto KV_STORAGE_BETA engine parser)
target_link_libraries(server2 proto KV_STORAGE_BETA engine parser)