This commit is contained in:
myd7349 2022-11-28 21:23:26 +08:00
parent 6900c9128e
commit 3c9fd966f9

View File

@ -1,21 +1,13 @@
CMAKE_MINIMUM_REQUIRED(VERSION 2.8.12) CMAKE_MINIMUM_REQUIRED(VERSION 2.8.12)
if(DEFINED PROJECT_NAME)
set(KCP_IS_TOP_PROJECT OFF)
else()
set(KCP_IS_TOP_PROJECT ON)
endif()
project(kcp LANGUAGES C) project(kcp LANGUAGES C)
include(CTest)
include(GNUInstallDirs)
cmake_policy(SET CMP0054 NEW) cmake_policy(SET CMP0054 NEW)
option(KCP_BUILD_SHARED_LIBS "Build KCP as a shared lib" OFF) if(BUILD_SHARED_LIBS AND WIN32)
option(KCP_BUILD_INSTALL "Build install target" ${KCP_IS_TOP_PROJECT})
option(KCP_BUILD_TESTS "Build tests" ${KCP_IS_TOP_PROJECT})
if(KCP_BUILD_SHARED_LIBS)
if(WIN32)
set(exports_def_file "${CMAKE_CURRENT_BINARY_DIR}/exports.def") set(exports_def_file "${CMAKE_CURRENT_BINARY_DIR}/exports.def")
set(exports_def_contents set(exports_def_contents
"EXPORTS "EXPORTS
@ -39,26 +31,19 @@ if(KCP_BUILD_SHARED_LIBS)
") ")
file(WRITE "${exports_def_file}" "${exports_def_contents}") file(WRITE "${exports_def_file}" "${exports_def_contents}")
add_library(kcp SHARED ikcp.h ikcp.c "${exports_def_file}") add_library(kcp ikcp.c "${exports_def_file}")
else() else()
add_library(kcp SHARED ikcp.h ikcp.c) add_library(kcp ikcp.c)
endif()
else()
add_library(kcp STATIC ikcp.h ikcp.c)
endif() endif()
if(KCP_BUILD_INSTALL) install(FILES ikcp.h DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}")
include(GNUInstallDirs)
set_target_properties(kcp PROPERTIES PUBLIC_HEADER ikcp.h)
install(TARGETS kcp install(TARGETS kcp
EXPORT kcp-targets EXPORT kcp-targets
PUBLIC_HEADER DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}" ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}" LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}" RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} INCLUDES DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
) )
install(EXPORT kcp-targets install(EXPORT kcp-targets
@ -66,9 +51,8 @@ if(KCP_BUILD_INSTALL)
NAMESPACE kcp:: NAMESPACE kcp::
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/kcp DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/kcp
) )
endif()
if(KCP_BUILD_TESTS) if(BUILD_TESTING)
enable_language(CXX) enable_language(CXX)
add_executable(kcp_test test.cpp) add_executable(kcp_test test.cpp)