mirror of
https://github.com/KingDuckZ/incredis
synced 2024-11-23 00:33:46 +00:00
Improve installation, but there are some cmake warnings now.
This commit is contained in:
parent
6480102b38
commit
2c324ae647
2 changed files with 29 additions and 3 deletions
|
@ -7,10 +7,20 @@ include(CTest)
|
||||||
|
|
||||||
option(INCREDIS_FORCE_DISABLE_TESTS "Ignore unit tests even if BUILD_TESTING is set to ON - useful if you want to disable incredis tests from your top-level cmake project" OFF)
|
option(INCREDIS_FORCE_DISABLE_TESTS "Ignore unit tests even if BUILD_TESTING is set to ON - useful if you want to disable incredis tests from your top-level cmake project" OFF)
|
||||||
set(CMAKE_INSTALL_INCLUDEDIR "" CACHE PATH "Specify the output directory for header files (default is include)")
|
set(CMAKE_INSTALL_INCLUDEDIR "" CACHE PATH "Specify the output directory for header files (default is include)")
|
||||||
|
set(CMAKE_INSTALL_LIBDIR "" CACHE PATH "Specify the output directory for libraries (default is lib)")
|
||||||
|
set(CMAKE_INSTALL_PKGCONFIGDIR "" CACHE PATH "Specify the output directory for pkgconfig files (default is lib/pkgconfig)")
|
||||||
|
set(PROJECT_URL "https://github.com/KingDuckZ/incredis")
|
||||||
|
set(PROJECT_DESCRIPTION "A lightweight C++ wrapper around hiredis")
|
||||||
|
|
||||||
if(NOT CMAKE_INSTALL_INCLUDEDIR)
|
if(NOT CMAKE_INSTALL_INCLUDEDIR)
|
||||||
set(CMAKE_INSTALL_INCLUDEDIR "${CMAKE_INSTALL_PREFIX}/include")
|
set(CMAKE_INSTALL_INCLUDEDIR "${CMAKE_INSTALL_PREFIX}/include")
|
||||||
endif(NOT CMAKE_INSTALL_INCLUDEDIR)
|
endif(NOT CMAKE_INSTALL_INCLUDEDIR)
|
||||||
|
if(NOT CMAKE_INSTALL_LIBDIR)
|
||||||
|
set(CMAKE_INSTALL_LIBDIR "${CMAKE_INSTALL_PREFIX}/lib${LIB_SUFFIX}")
|
||||||
|
endif(NOT CMAKE_INSTALL_LIBDIR)
|
||||||
|
if(NOT CMAKE_INSTALL_PKGCONFIGDIR)
|
||||||
|
set(CMAKE_INSTALL_PKGCONFIGDIR "${CMAKE_INSTALL_LIBDIR}/pkgconfig")
|
||||||
|
endif(NOT CMAKE_INSTALL_PKGCONFIGDIR)
|
||||||
|
|
||||||
find_package(hiredis 0.11.0 REQUIRED)
|
find_package(hiredis 0.11.0 REQUIRED)
|
||||||
find_package(CryptoPP 5.6)
|
find_package(CryptoPP 5.6)
|
||||||
|
@ -35,13 +45,12 @@ add_library(${PROJECT_NAME} SHARED
|
||||||
target_include_directories(${PROJECT_NAME} SYSTEM
|
target_include_directories(${PROJECT_NAME} SYSTEM
|
||||||
PUBLIC ${Boost_INCLUDE_DIRS}
|
PUBLIC ${Boost_INCLUDE_DIRS}
|
||||||
PRIVATE ${HIREDIS_INCLUDE_DIRS}
|
PRIVATE ${HIREDIS_INCLUDE_DIRS}
|
||||||
PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/lib/better-enums
|
PUBLIC lib/better-enums
|
||||||
PRIVATE ${LIBEV_INCLUDE_DIRS}
|
PRIVATE ${LIBEV_INCLUDE_DIRS}
|
||||||
)
|
)
|
||||||
target_include_directories(${PROJECT_NAME} PUBLIC
|
target_include_directories(${PROJECT_NAME} PUBLIC
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
$<INSTALL_INTERFACE:include>
|
$<INSTALL_INTERFACE:include>
|
||||||
PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include
|
|
||||||
PRIVATE ${CMAKE_CURRENT_BINARY_DIR}
|
PRIVATE ${CMAKE_CURRENT_BINARY_DIR}
|
||||||
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/incredis
|
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include/incredis
|
||||||
)
|
)
|
||||||
|
@ -57,6 +66,11 @@ configure_file(
|
||||||
src/incredisConfig.h.in
|
src/incredisConfig.h.in
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/incredisConfig.h
|
${CMAKE_CURRENT_BINARY_DIR}/incredisConfig.h
|
||||||
)
|
)
|
||||||
|
configure_file(
|
||||||
|
"${CMAKE_CURRENT_SOURCE_DIR}/pkgconfig/incredis.pc.in"
|
||||||
|
"${CMAKE_CURRENT_BINARY_DIR}/incredis.pc"
|
||||||
|
@ONLY
|
||||||
|
)
|
||||||
|
|
||||||
target_compile_definitions(${PROJECT_NAME}
|
target_compile_definitions(${PROJECT_NAME}
|
||||||
PRIVATE EV_COMPAT3=0
|
PRIVATE EV_COMPAT3=0
|
||||||
|
@ -71,13 +85,14 @@ else()
|
||||||
endif()
|
endif()
|
||||||
set(INCREDIS_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
|
set(INCREDIS_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}")
|
||||||
|
|
||||||
install(TARGETS ${PROJECT_NAME}
|
install(TARGETS ${PROJECT_NAME} EXPORT ${PROJECT_NAME}Config
|
||||||
LIBRARY DESTINATION lib
|
LIBRARY DESTINATION lib
|
||||||
RUNTIME DESTINATION bin
|
RUNTIME DESTINATION bin
|
||||||
ARCHIVE DESTINATION lib/static
|
ARCHIVE DESTINATION lib/static
|
||||||
)
|
)
|
||||||
install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
|
||||||
install(EXPORT ${PROJECT_NAME}Config DESTINATION share/${PROJECT_NAME}/cmake)
|
install(EXPORT ${PROJECT_NAME}Config DESTINATION share/${PROJECT_NAME}/cmake)
|
||||||
|
install(FILES "${CMAKE_CURRENT_BINARY_DIR}/incredis.pc" DESTINATION ${CMAKE_INSTALL_PKGCONFIGDIR})
|
||||||
|
|
||||||
target_compile_features(${PROJECT_NAME}
|
target_compile_features(${PROJECT_NAME}
|
||||||
PUBLIC cxx_nullptr
|
PUBLIC cxx_nullptr
|
||||||
|
|
11
pkgconfig/incredis.pc.in
Normal file
11
pkgconfig/incredis.pc.in
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
prefix=@CMAKE_INSTALL_PREFIX@
|
||||||
|
exec_prefix=${prefix}
|
||||||
|
libdir=@CMAKE_INSTALL_LIBDIR@
|
||||||
|
includedir=@CMAKE_INSTALL_INCLUDEDIR@
|
||||||
|
|
||||||
|
Name: @PROJECT_NAME@
|
||||||
|
Description: @PROJECT_DESCRIPTION@
|
||||||
|
Version: @PROJECT_VERSION_FULL@
|
||||||
|
URL: @PROJECT_URL@
|
||||||
|
Libs: -L${libdir} -l@PROJECT_NAME@
|
||||||
|
Cflags: -I${includedir}
|
Loading…
Reference in a new issue