diff options
Diffstat (limited to 'lib9p/CMakeLists.txt')
-rw-r--r-- | lib9p/CMakeLists.txt | 67 |
1 files changed, 54 insertions, 13 deletions
diff --git a/lib9p/CMakeLists.txt b/lib9p/CMakeLists.txt index 949b6d6..9ef8465 100644 --- a/lib9p/CMakeLists.txt +++ b/lib9p/CMakeLists.txt @@ -3,27 +3,48 @@ # Copyright (C) 2024-2025 Luke T. Shumaker <lukeshu@lukeshu.com> # SPDX-License-Identifier: AGPL-3.0-or-later -add_library(lib9p INTERFACE) -target_include_directories(lib9p PUBLIC INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/include) -target_sources(lib9p INTERFACE - 9p.generated.c - 9p.c - tables.c - srv.c +add_library(lib9p_core_headers INTERFACE) +target_include_directories(lib9p_core_headers PUBLIC INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/core_include) +target_link_libraries(lib9p_core_headers INTERFACE + libhw_generic_headers + libmisc_headers ) -target_link_libraries(lib9p INTERFACE - libcr_ipc - libfmt + +add_library(lib9p_core INTERFACE) +target_link_libraries(lib9p_core INTERFACE lib9p_core_headers) +target_sources(lib9p_core INTERFACE + core.c + core_generated.c +) +target_link_libraries(lib9p_core INTERFACE libhw_generic libmisc ) +add_library(lib9p_srv_headers INTERFACE) +target_include_directories(lib9p_srv_headers PUBLIC INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}/srv_include) +target_link_libraries(lib9p_srv_headers INTERFACE + lib9p_core_headers + libcr_ipc_headers +) + +add_library(lib9p_srv INTERFACE) +target_link_libraries(lib9p_srv INTERFACE lib9p_srv_headers) +target_sources(lib9p_srv INTERFACE + srv.c + srv_generated.c +) +target_link_libraries(lib9p_srv INTERFACE + lib9p_core + libcr_ipc +) + if (ENABLE_TESTS) add_subdirectory(tests/test_server) function(add_lib9p_executable arg_testname) add_executable("${arg_testname}" "tests/${arg_testname}.c") - target_link_libraries("${arg_testname}" lib9p) + target_link_libraries("${arg_testname}" lib9p_core) target_include_directories("${arg_testname}" PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/tests ${CMAKE_CURRENT_SOURCE_DIR}/tests/client_config @@ -42,6 +63,26 @@ if (ENABLE_TESTS) add_lib9p_executable("testclient-sess") add_lib9p_test("./testclient-sess") - add_lib_test(lib9p test_compile) - target_include_directories(test_compile PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/tests/test_compile_config) + add_lib9p_executable("testclient-hangup") + add_lib9p_test("./testclient-hangup") + + set(cfg_matrix + "CONFIG_9P_ENABLE_9P2000;[0;1]" + "CONFIG_9P_ENABLE_9P2000_u;[0;1]" + "CONFIG_9P_ENABLE_9P2000_e;[0;1]" + "CONFIG_9P_ENABLE_9P2000_L;[0;1]" + "CONFIG_9P_ENABLE_9P2000_p9p;[0;1]" + ) + function(add_compile_test n defs) + add_library("test_compile${n}" STATIC "tests/test_compile.c" + core.c + core_generated.c + srv.c + srv_generated.c + ) + target_link_libraries("test_compile${n}" PUBLIC lib9p_srv_headers) + target_include_directories("test_compile${n}" PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/tests/test_compile_config) + target_compile_definitions("test_compile${n}" PUBLIC "${defs}") + endfunction() + apply_matrix(add_compile_test "${cfg_matrix}") endif() |