X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=1d5da5e82ed192ed9bef57709fc54d3ad505a8d5;hb=5011060f04181acbb18babcc2017a2f0b6cfb853;hp=a7d1ff958eb386472f2940ddf18cfb27ac929e80;hpb=7a42848a00166bf5d4b79d341344d81439cc3b60;p=src%2Fapp-framework-binder.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index a7d1ff95..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 # @@ -16,32 +16,55 @@ # limitations under the License. ########################################################################### -if (NOT DEFINED ALLOW_NO_BINDER) - if (CMAKE_C_COMPILER_VERSION VERSION_LESS 4.9) - message(FATAL_ERROR "Require at least gcc-4.9") - endif(CMAKE_C_COMPILER_VERSION VERSION_LESS 4.9) -endif(ALLOW_NO_BINDER) - -INCLUDE(FindPkgConfig) - -ADD_SUBDIRECTORY(genskel) -ADD_SUBDIRECTORY(tests) +if (CMAKE_C_COMPILER_VERSION VERSION_LESS 4.9) + message(FATAL_ERROR "Require at least gcc-4.9") +endif(CMAKE_C_COMPILER_VERSION VERSION_LESS 4.9) 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 @@ -49,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 @@ -58,6 +83,7 @@ ADD_LIBRARY(afb-lib STATIC afb-msg-json.c afb-proto-ws.c afb-session.c + afb-socket.c afb-stub-ws.c afb-trace.c afb-websock.c @@ -66,21 +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 - sd-fds.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} @@ -88,16 +141,30 @@ TARGET_LINK_LIBRARIES(afb-daemon INSTALL(TARGETS afb-daemon RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) +########################################### +# build and install afb-daemon +########################################### +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) +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}) TARGET_LINK_LIBRARIES(afbwsc ${libsystemd_LDFLAGS} ${json-c_LDFLAGS} + -lpthread -Wl,--version-script=${CMAKE_CURRENT_SOURCE_DIR}/export-afbwsc.map -Wl,--as-needed -Wl,--gc-sections @@ -108,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} @@ -117,4 +184,3 @@ TARGET_LINK_LIBRARIES(afb-client-demo INSTALL(TARGETS afb-client-demo RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) -