-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
54 lines (45 loc) · 1.69 KB
/
CMakeLists.txt
File metadata and controls
54 lines (45 loc) · 1.69 KB
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
cmake_minimum_required(VERSION 3.15)
project(distributed-query-runtime-cpp LANGUAGES CXX)
set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
# Dependencies
find_package(gRPC CONFIG REQUIRED)
find_package(Protobuf CONFIG REQUIRED)
find_package(Arrow REQUIRED)
find_package(Parquet REQUIRED)
find_package(absl REQUIRED)
find_package(spdlog REQUIRED)
find_package(GTest REQUIRED)
# Protobuf/gRPC generation helper
function(generate_grpc_proto SRCS HDRS PROTO_FILE)
get_filename_component(PROTO_PATH "${PROTO_FILE}" ABSOLUTE)
get_filename_component(PROTO_DIR "${PROTO_PATH}" DIRECTORY)
get_filename_component(PROTO_NAME "${PROTO_FILE}" NAME_WE)
set(GENERATED_SRCS
"${CMAKE_CURRENT_BINARY_DIR}/${PROTO_NAME}.pb.cc"
"${CMAKE_CURRENT_BINARY_DIR}/${PROTO_NAME}.grpc.pb.cc"
)
set(GENERATED_HDRS
"${CMAKE_CURRENT_BINARY_DIR}/${PROTO_NAME}.pb.h"
"${CMAKE_CURRENT_BINARY_DIR}/${PROTO_NAME}.grpc.pb.h"
)
add_custom_command(
OUTPUT ${GENERATED_SRCS} ${GENERATED_HDRS}
COMMAND ${Protobuf_PROTOC_EXECUTABLE}
ARGS --cpp_out "${CMAKE_CURRENT_BINARY_DIR}"
--grpc_out "${CMAKE_CURRENT_BINARY_DIR}"
--plugin=protoc-gen-grpc=$<TARGET_FILE:gRPC::grpc_cpp_plugin>
-I "${PROTO_DIR}"
"${PROTO_PATH}"
DEPENDS "${PROTO_PATH}"
)
set(${SRCS} ${GENERATED_SRCS} PARENT_SCOPE)
set(${HDRS} ${GENERATED_HDRS} PARENT_SCOPE)
endfunction()
# Generate proto code
generate_grpc_proto(PROTO_SRCS PROTO_HDRS "${CMAKE_CURRENT_SOURCE_DIR}/proto/runtime.proto")
# Directories
include_directories(src)
include_directories(${CMAKE_CURRENT_BINARY_DIR})
add_subdirectory(src)
add_subdirectory(tests)