slightly reworked CMakeLists for the service project

This commit is contained in:
vladimir.kuznetsov 2022-12-28 19:35:48 +03:00
parent 36b25915a6
commit 788539973f
2 changed files with 32 additions and 33 deletions

View file

@ -6,10 +6,20 @@ project(${PROJECT})
set(CMAKE_CXX_STANDARD 20)
set(CMAKE_CXX_STANDARD_REQUIRED ON)
find_package(Qt6 REQUIRED COMPONENTS Core Network RemoteObjects Core5Compat)
qt_standard_project_setup()
set(HEADERS
add_executable(${PROJECT})
find_package(Qt6 REQUIRED COMPONENTS Core
Network RemoteObjects Core5Compat
)
target_link_libraries(${PROJECT} PRIVATE
Qt6::Core Qt6::Network
Qt6::RemoteObjects Qt6::Core5Compat
)
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/../../client/utilities.h
${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipc.h
${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipcserver.h
@ -18,9 +28,7 @@ set(HEADERS
${CMAKE_CURRENT_LIST_DIR}/logger.h
${CMAKE_CURRENT_LIST_DIR}/router.h
${CMAKE_CURRENT_LIST_DIR}/systemservice.h
)
set(SOURCES
${CMAKE_CURRENT_LIST_DIR}/../../client/utilities.cpp
${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipcserver.cpp
${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipcserverprocess.cpp
@ -32,17 +40,15 @@ set(SOURCES
)
if(WIN32)
set(HEADERS ${HEADERS}
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/tapcontroller_win.h
${CMAKE_CURRENT_LIST_DIR}/router_win.h
)
set(SOURCES ${SOURCES}
${CMAKE_CURRENT_LIST_DIR}/tapcontroller_win.cpp
${CMAKE_CURRENT_LIST_DIR}/router_win.cpp
)
set(LIBS
target_link_libraries(${PROJECT} PRIVATE
user32
rasapi32
shlwapi
@ -54,43 +60,36 @@ if(WIN32)
Kernel32
)
add_compile_definitions(_WINSOCKAPI_)
target_compile_definitions(${PROJECT} PRIVATE _WINSOCKAPI_)
endif()
if(APPLE)
set(HEADERS ${HEADERS}
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/helper_route_mac.h
${CMAKE_CURRENT_LIST_DIR}/router_mac.h
)
set(SOURCES ${SOURCES}
${CMAKE_CURRENT_LIST_DIR}/helper_route_mac.c
${CMAKE_CURRENT_LIST_DIR}/router_mac.cpp
)
endif()
if(LINUX)
set(HEADERS ${HEADERS}
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/router_linux.h
)
set(SOURCES ${SOURCES}
${CMAKE_CURRENT_LIST_DIR}/router_linux.cpp
)
endif()
include(${CMAKE_CURRENT_LIST_DIR}/../src/qtservice.cmake)
include_directories(
target_include_directories(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}
${CMAKE_CURRENT_LIST_DIR}/../../client
${CMAKE_CURRENT_LIST_DIR}/../../ipc
${CMAKE_CURRENT_BINARY_DIR}
)
add_executable(${PROJECT} ${SOURCES} ${HEADERS})
target_link_libraries(${PROJECT} PRIVATE Qt6::Core Qt6::Network Qt6::RemoteObjects Qt6::Core5Compat ${LIBS})
qt_add_repc_sources(${PROJECT} ${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipc_interface.rep)
if(NOT IOS)
qt_add_repc_sources(${PROJECT} ${CMAKE_CURRENT_LIST_DIR}/../../ipc/ipc_process_interface.rep)

View file

@ -1,27 +1,27 @@
include_directories(${CMAKE_CURRENT_LIST_DIR})
if(NOT WIN32)
set(LIBS ${LIBS} Qt6::Network)
elseif(WIN32)
set(LIBS ${LIBS} user32)
if(${PROJECT} STREQUAL "")
message(FATAL_ERROR "You must set PROJECT variable")
endif()
set(HEADERS ${HEADERS}
target_include_directories(${PROJECT} PRIVATE ${CMAKE_CURRENT_LIST_DIR})
if(NOT WIN32)
target_include_directories(${PROJECT} PRIVATE Qt6::Network)
elseif(WIN32)
target_include_directories(${PROJECT} PRIVATE user32)
endif()
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/qtservice.h
${CMAKE_CURRENT_LIST_DIR}/qtservice_p.h
)
set(SOURCES ${SOURCES}
${CMAKE_CURRENT_LIST_DIR}/qtservice.cpp
)
if(UNIX)
set(HEADERS ${HEADERS}
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/qtunixsocket.h
${CMAKE_CURRENT_LIST_DIR}/qtunixserversocket.h
)
set(SOURCES ${SOURCES}
${CMAKE_CURRENT_LIST_DIR}/qtservice_unix.cpp
${CMAKE_CURRENT_LIST_DIR}/qtunixsocket.cpp
${CMAKE_CURRENT_LIST_DIR}/qtunixserversocket.cpp
@ -29,7 +29,7 @@ if(UNIX)
endif()
if(WIN32)
set(SOURCES ${SOURCES}
target_sources(${PROJECT} PRIVATE
${CMAKE_CURRENT_LIST_DIR}/qtservice_win.cpp
)
endif()