Skip to content

Commit 3c9fd96

Browse files
committed
simplify
1 parent 6900c91 commit 3c9fd96

File tree

1 file changed

+24
-40
lines changed

1 file changed

+24
-40
lines changed

CMakeLists.txt

+24-40
Original file line numberDiff line numberDiff line change
@@ -1,23 +1,15 @@
11
CMAKE_MINIMUM_REQUIRED(VERSION 2.8.12)
22

3-
if(DEFINED PROJECT_NAME)
4-
set(KCP_IS_TOP_PROJECT OFF)
5-
else()
6-
set(KCP_IS_TOP_PROJECT ON)
7-
endif()
8-
93
project(kcp LANGUAGES C)
104

11-
cmake_policy(SET CMP0054 NEW)
5+
include(CTest)
6+
include(GNUInstallDirs)
127

13-
option(KCP_BUILD_SHARED_LIBS "Build KCP as a shared lib" OFF)
14-
option(KCP_BUILD_INSTALL "Build install target" ${KCP_IS_TOP_PROJECT})
15-
option(KCP_BUILD_TESTS "Build tests" ${KCP_IS_TOP_PROJECT})
8+
cmake_policy(SET CMP0054 NEW)
169

17-
if(KCP_BUILD_SHARED_LIBS)
18-
if(WIN32)
19-
set(exports_def_file "${CMAKE_CURRENT_BINARY_DIR}/exports.def")
20-
set(exports_def_contents
10+
if(BUILD_SHARED_LIBS AND WIN32)
11+
set(exports_def_file "${CMAKE_CURRENT_BINARY_DIR}/exports.def")
12+
set(exports_def_contents
2113
"EXPORTS
2214
ikcp_create
2315
ikcp_release
@@ -38,39 +30,31 @@ if(KCP_BUILD_SHARED_LIBS)
3830
ikcp_getconv
3931
")
4032

41-
file(WRITE "${exports_def_file}" "${exports_def_contents}")
42-
add_library(kcp SHARED ikcp.h ikcp.c "${exports_def_file}")
43-
else()
44-
add_library(kcp SHARED ikcp.h ikcp.c)
45-
endif()
33+
file(WRITE "${exports_def_file}" "${exports_def_contents}")
34+
add_library(kcp ikcp.c "${exports_def_file}")
4635
else()
47-
add_library(kcp STATIC ikcp.h ikcp.c)
36+
add_library(kcp ikcp.c)
4837
endif()
4938

50-
if(KCP_BUILD_INSTALL)
51-
include(GNUInstallDirs)
52-
53-
set_target_properties(kcp PROPERTIES PUBLIC_HEADER ikcp.h)
39+
install(FILES ikcp.h DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}")
5440

55-
install(TARGETS kcp
56-
EXPORT kcp-targets
57-
PUBLIC_HEADER DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
58-
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
59-
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
60-
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
61-
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
62-
)
41+
install(TARGETS kcp
42+
EXPORT kcp-targets
43+
ARCHIVE DESTINATION "${CMAKE_INSTALL_LIBDIR}"
44+
LIBRARY DESTINATION "${CMAKE_INSTALL_LIBDIR}"
45+
RUNTIME DESTINATION "${CMAKE_INSTALL_BINDIR}"
46+
INCLUDES DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}"
47+
)
6348

64-
install(EXPORT kcp-targets
65-
FILE kcp-config.cmake
66-
NAMESPACE kcp::
67-
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/kcp
68-
)
69-
endif()
49+
install(EXPORT kcp-targets
50+
FILE kcp-config.cmake
51+
NAMESPACE kcp::
52+
DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/kcp
53+
)
7054

71-
if(KCP_BUILD_TESTS)
55+
if(BUILD_TESTING)
7256
enable_language(CXX)
73-
57+
7458
add_executable(kcp_test test.cpp)
7559
if(MSVC AND NOT (MSVC_VERSION LESS 1900))
7660
target_compile_options(kcp_test PRIVATE /utf-8)

0 commit comments

Comments
 (0)