X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=1d5da5e82ed192ed9bef57709fc54d3ad505a8d5;hb=5011060f04181acbb18babcc2017a2f0b6cfb853;hp=4ef87853a00d88a65a50042e039b89c5ed158f97;hpb=f15ea770dd9b13a20331853a026091316984f9ca;p=src%2Fapp-framework-binder.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 4ef87853..1d5da5e8 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,5 +1,5 @@ ########################################################################### -# Copyright 2015, 2016, 2017 IoT.bzh +# Copyright (C) 2015-2019 "IoT.bzh" # # author: José Bollo # @@ -24,17 +24,47 @@ ADD_DEFINITIONS(-DBINDING_INSTALL_DIR="${binding_install_dir}") # Always add INFER_EXTENSION (more details in afb-hreq.c) ADD_DEFINITIONS(-DINFER_EXTENSION) -ADD_LIBRARY(afb-lib STATIC +############################################################################ +# TODO: improve below setting +set(USE_SIG_MONITOR_DUMPSTACK ON CACHE BOOL "activate dump stack on error") +set(USE_SIG_MONITOR_SIGNALS ON CACHE BOOL "activate handling of signals") +set(USE_SIG_MONITOR_FOR_CALL ON CACHE BOOL "activate monitoring of calls") +set(USE_SIG_MONITOR_TIMERS ON CACHE BOOL "activate monitoring of call expiration") + +if(USE_SIG_MONITOR_DUMPSTACK) + add_definitions(-DUSE_SIG_MONITOR_DUMPSTACK=1) +else() + add_definitions(-DUSE_SIG_MONITOR_DUMPSTACK=0) +endif() +if(USE_SIG_MONITOR_SIGNALS) + add_definitions(-DUSE_SIG_MONITOR_SIGNALS=1) +else() + add_definitions(-DUSE_SIG_MONITOR_SIGNALS=0) +endif() +if(USE_SIG_MONITOR_FOR_CALL) + add_definitions(-DUSE_SIG_MONITOR_FOR_CALL=1) +else() + add_definitions(-DUSE_SIG_MONITOR_FOR_CALL=0) +endif() +if(USE_SIG_MONITOR_TIMERS) + add_definitions(-DUSE_SIG_MONITOR_TIMERS=1) +else() + add_definitions(-DUSE_SIG_MONITOR_TIMERS=0) +endif() +############################################################################ + +SET(AFB_LIB_SOURCES afb-api.c - afb-api-dbus.c - afb-api-dyn.c afb-api-so.c - afb-api-so-v1.c afb-api-so-v2.c + afb-api-so-v3.c afb-api-so-vdyn.c + afb-api-v3.c afb-api-ws.c afb-apiset.c afb-auth.c + afb-autoset.c + afb-calls.c afb-common.c afb-config.c afb-context.c @@ -42,7 +72,9 @@ ADD_LIBRARY(afb-lib STATIC afb-debug.c afb-evt.c afb-export.c + afb-fdev.c afb-hook.c + afb-hook-flags.c afb-hreq.c afb-hsrv.c afb-hswitch.c @@ -51,9 +83,8 @@ ADD_LIBRARY(afb-lib STATIC afb-msg-json.c afb-proto-ws.c afb-session.c + afb-socket.c afb-stub-ws.c - afb-supervision.c - afb-systemd.c afb-trace.c afb-websock.c afb-ws-client.c @@ -61,20 +92,48 @@ ADD_LIBRARY(afb-lib STATIC afb-ws.c afb-wsj1.c afb-xreq.c + evmgr.c + fdev.c + fdev-epoll.c + fdev-systemd.c + globset.c jobs.c locale-root.c + pearson.c process-name.c sig-monitor.c subpath.c + systemd.c verbose.c + watchdog.c websock.c wrap-json.c ) +IF(INCLUDE_LEGACY_BINDING_V1) + ADD_DEFINITIONS(-DWITH_LEGACY_BINDING_V1) + SET(AFB_LIB_SOURCES ${AFB_LIB_SOURCES} afb-api-so-v1.c) +ENDIF(INCLUDE_LEGACY_BINDING_V1) +IF(INCLUDE_LEGACY_BINDING_VDYN) + ADD_DEFINITIONS(-DWITH_LEGACY_BINDING_VDYN) + SET(AFB_LIB_SOURCES ${AFB_LIB_SOURCES} afb-api-so-vdyn.c) +ENDIF(INCLUDE_LEGACY_BINDING_VDYN) + +IF(INCLUDE_DBUS_TRANSPARENCY) + ADD_DEFINITIONS(-DWITH_DBUS_TRANSPARENCY) + SET(AFB_LIB_SOURCES ${AFB_LIB_SOURCES} afb-api-dbus.c) +ENDIF() +IF(INCLUDE_SUPERVISOR) + ADD_DEFINITIONS(-DWITH_SUPERVISION) + SET(AFB_LIB_SOURCES ${AFB_LIB_SOURCES} afb-supervision.c) +ENDIF() + +ADD_LIBRARY(afb-lib STATIC ${AFB_LIB_SOURCES}) + ########################################### # build and install afb-daemon ########################################### -ADD_EXECUTABLE(afb-daemon main.c) +ADD_EXECUTABLE(afb-daemon main-afb-daemon.c) TARGET_LINK_LIBRARIES(afb-daemon afb-lib ${link_libraries} @@ -85,18 +144,20 @@ INSTALL(TARGETS afb-daemon ########################################### # build and install afb-daemon ########################################### -ADD_EXECUTABLE(afs-supervisor afs-supervisor.c afs-discover.c) -TARGET_LINK_LIBRARIES(afs-supervisor - afb-lib - ${link_libraries} -) -INSTALL(TARGETS afs-supervisor - RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) +IF(INCLUDE_SUPERVISOR) + ADD_EXECUTABLE(afs-supervisor main-afs-supervisor.c afs-supervisor.c afs-discover.c afs-config.c) + TARGET_LINK_LIBRARIES(afs-supervisor + afb-lib + ${link_libraries} + ) + INSTALL(TARGETS afs-supervisor + RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) +ENDIF() ########################################### # build and install libafbwsc ########################################### -ADD_LIBRARY(afbwsc SHARED afb-ws.c afb-ws-client.c afb-wsj1.c websock.c afb-proto-ws.c jobs-fake.c) +ADD_LIBRARY(afbwsc SHARED afb-ws.c afb-ws-client.c afb-wsj1.c websock.c afb-proto-ws.c fdev.c fdev-systemd.c verbose.c) SET_TARGET_PROPERTIES(afbwsc PROPERTIES VERSION ${LIBAFBWSC_VERSION} SOVERSION ${LIBAFBWSC_SOVERSION}) @@ -114,7 +175,7 @@ INSTALL(FILES afb-wsj1.h afb-ws-client.h afb-proto-ws.h DESTINATION ${CMAKE_INST ########################################### # build and install afb-client-demo ########################################### -ADD_EXECUTABLE(afb-client-demo afb-client-demo.c) +ADD_EXECUTABLE(afb-client-demo main-afb-client-demo.c) TARGET_LINK_LIBRARIES(afb-client-demo afbwsc ${link_libraries}