Add an cmake option which respect `CMAKE_CXX_STANDARD` for cxx standard.
Signed-off-by: Tao He <sighingnow@gmail.com>
This commit is contained in:
parent
974ec2e11e
commit
827c4680c3
|
|
@ -16,10 +16,6 @@ jobs:
|
|||
os: [ubuntu-20.04]
|
||||
etcd: [v3.4.13]
|
||||
steps:
|
||||
- name: Get time
|
||||
run: |
|
||||
date +'%Y-%m' > snapshot.txt
|
||||
|
||||
- name: Install dependencies for Linux
|
||||
run: |
|
||||
# switch to centos stream
|
||||
|
|
|
|||
|
|
@ -30,6 +30,16 @@ option(BUILD_SHARED_LIBS "Build etcd-cpp-apiv3 shared libraries" ON)
|
|||
option(BUILD_ETCD_TESTS "Build etcd-cpp-apiv3 test cases" OFF)
|
||||
option(CMAKE_POSITION_INDEPENDENT_CODE "Build etcd-cpp-apiv3 with -fPIC" ON)
|
||||
option(ETCD_W_STRICT "Build etcd-cpp-apiv3 with -Werror" ON)
|
||||
option(ETCD_CMAKE_CXX_STANDARD "Build etcd-cpp-apiv3 with specified C++ standard, e.g., 11, 14, 17, 20" "")
|
||||
|
||||
if(NOT "${ETCD_CMAKE_CXX_STANDARD}")
|
||||
if(NOT "${CMAKE_CXX_STANDARD}")
|
||||
set(ETCD_CMAKE_CXX_STANDARD 11)
|
||||
else()
|
||||
set(ETCD_CMAKE_CXX_STANDARD ${CMAKE_CXX_STANDARD})
|
||||
endif()
|
||||
endif()
|
||||
message("Building etcd-cpp-apiv3 with C++${ETCD_CMAKE_CXX_STANDARD}")
|
||||
|
||||
# reference: https://gitlab.kitware.com/cmake/community/-/wikis/doc/cmake/RPATH-handling#always-full-rpath
|
||||
set(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE)
|
||||
|
|
@ -60,20 +70,20 @@ if(NOT (CMAKE_CXX_COMPILER_LAUNCHER MATCHES "ccache") AND NOT (CMAKE_C_COMPILER_
|
|||
endif(ccache_EXECUTABLE)
|
||||
endif()
|
||||
|
||||
macro(use_cxx14 target)
|
||||
macro(use_cxx target)
|
||||
if(CMAKE_VERSION VERSION_LESS "3.1")
|
||||
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
||||
target_compile_options(${target} PRIVATE "-std=gnu++14")
|
||||
target_compile_options(${target} PRIVATE "-std=gnu++${ETCD_CMAKE_CXX_STANDARD}")
|
||||
else()
|
||||
target_compile_options(${target} PRIVATE "-std=c++14")
|
||||
target_compile_options(${target} PRIVATE "-std=c++${ETCD_CMAKE_CXX_STANDARD}")
|
||||
endif()
|
||||
else()
|
||||
set_target_properties(${target} PROPERTIES
|
||||
CXX_STANDARD 14
|
||||
CXX_STANDARD ${ETCD_CMAKE_CXX_STANDARD}
|
||||
CXX_STANDARD_REQUIRED ON
|
||||
)
|
||||
endif()
|
||||
endmacro(use_cxx14)
|
||||
endmacro(use_cxx)
|
||||
|
||||
find_package(Boost REQUIRED COMPONENTS system thread random)
|
||||
if(APPLE)
|
||||
|
|
|
|||
|
|
@ -18,13 +18,13 @@ file(GLOB_RECURSE CPP_CLIENT_CORE_SRC
|
|||
)
|
||||
|
||||
add_library(etcd-cpp-api-core-objects OBJECT ${CPP_CLIENT_CORE_SRC} ${PROTOBUF_GENERATES})
|
||||
use_cxx14(etcd-cpp-api-core-objects)
|
||||
use_cxx(etcd-cpp-api-core-objects)
|
||||
add_dependencies(etcd-cpp-api-core-objects protobuf_generates)
|
||||
include_generated_protobuf_files(etcd-cpp-api-core-objects)
|
||||
|
||||
# add the core library, includes the sycnhronous client only
|
||||
add_library(etcd-cpp-api-core $<TARGET_OBJECTS:etcd-cpp-api-core-objects>)
|
||||
use_cxx14(etcd-cpp-api-core)
|
||||
use_cxx(etcd-cpp-api-core)
|
||||
target_link_libraries(etcd-cpp-api-core PUBLIC
|
||||
${Boost_LIBRARIES}
|
||||
${PROTOBUF_LIBRARIES}
|
||||
|
|
@ -36,7 +36,7 @@ include_generated_protobuf_files(etcd-cpp-api-core)
|
|||
# add the client with asynchronus client
|
||||
add_library(etcd-cpp-api $<TARGET_OBJECTS:etcd-cpp-api-core-objects>
|
||||
"${CMAKE_CURRENT_SOURCE_DIR}/Client.cpp")
|
||||
use_cxx14(etcd-cpp-api)
|
||||
use_cxx(etcd-cpp-api)
|
||||
target_link_libraries(etcd-cpp-api PUBLIC
|
||||
${Boost_LIBRARIES}
|
||||
${CPPREST_LIB} # n.b.: the asynchronous client requires pplx in cpprestsdk
|
||||
|
|
|
|||
|
|
@ -18,7 +18,7 @@ foreach(testfile ${TEST_FILES})
|
|||
else()
|
||||
add_executable(${test_name} EXCLUDE_FROM_ALL ${CMAKE_CURRENT_SOURCE_DIR}/${testfile})
|
||||
endif()
|
||||
use_cxx14(${test_name})
|
||||
use_cxx(${test_name})
|
||||
add_test(NAME ${test_name} COMMAND $<TARGET_FILE:${test_name}>)
|
||||
|
||||
target_include_directories(${test_name} PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/../proto/gen)
|
||||
|
|
|
|||
Loading…
Reference in New Issue