sig-monitor: Add compiling switches
[src/app-framework-binder.git] / src / CMakeLists.txt
index 4ef8785..1d5da5e 100644 (file)
@@ -1,5 +1,5 @@
 ###########################################################################
-# Copyright 2015, 2016, 2017 IoT.bzh
+# Copyright (C) 2015-2019 "IoT.bzh"
 #
 # author: José Bollo <jose.bollo@iot.bzh>
 #
@@ -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}