X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=eb299d28ea66de8513d84cb2cc6fbcafe4c1f0fd;hb=a2cf84ecde926adeebf09bc2c284401513d3fab3;hp=0e05f850273380e06acaec519a89f0ce62aafc85;hpb=59cd34b59853f6a47e756d7ab5bc0329f40a471c;p=src%2Fapp-framework-binder.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 0e05f850..eb299d28 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 # @@ -20,25 +20,41 @@ 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) -INCLUDE(FindPkgConfig) - -ADD_SUBDIRECTORY(genskel) -ADD_SUBDIRECTORY(tests) - 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 +option(USE_SIG_MONITOR_DUMPSTACK "activate dump stack on error" ON) +option(USE_SIG_MONITOR_SIGNALS "activate handling of signals" ON) +option(USE_SIG_MONITOR_FOR_CALL "activate monitoring of calls" ON) +option(USE_SIG_MONITOR_TIMERS "activate monitoring of call expiration" ON) +option(WITH_AFB_HOOK "include hooking" ON) +option(WITH_AFB_TRACE "include monitoring trace" ON) + +add_definitions( + -DUSE_SIG_MONITOR_DUMPSTACK=$ + -DUSE_SIG_MONITOR_SIGNALS=$ + -DUSE_SIG_MONITOR_FOR_CALL=$ + -DUSE_SIG_MONITOR_TIMERS=$ + -DWITH_AFB_HOOK=$ + -DWITH_AFB_TRACE=$ +) +############################################################################ + +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 @@ -46,7 +62,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 @@ -55,6 +73,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 @@ -63,21 +82,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} @@ -85,27 +131,41 @@ 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) +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 ) INSTALL(TARGETS afbwsc LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}) -INSTALL(FILES afb-wsj1.h afb-ws-client.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/afb) +INSTALL(FILES afb-wsj1.h afb-ws-client.h afb-proto-ws.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/afb) ########################################### # 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} @@ -114,4 +174,3 @@ TARGET_LINK_LIBRARIES(afb-client-demo INSTALL(TARGETS afb-client-demo RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) -