X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=3e3a9e159f8f0d7f18208f1fdc4c47ed4c60097a;hb=65353dce81a629e042800bb7b86fcd869a76727e;hp=737faa66d959cb4b0362255e4aa9010c47b1c70b;hpb=15059fa1ed5f94c3b5d96357c9be6adfa5ea37b0;p=src%2Fapp-framework-binder.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 737faa66..3e3a9e15 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,5 +1,5 @@ ########################################################################### -# Copyright 2015, 2016, 2017 IoT.bzh +# Copyright (C) 2015-2020 "IoT.bzh" # # author: José Bollo # @@ -20,42 +20,94 @@ 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}") +ADD_DEFINITIONS(-DINTRINSIC_BINDING_DIR="${INTRINSIC_BINDING_DIR}") # Always add INFER_EXTENSION (more details in afb-hreq.c) ADD_DEFINITIONS(-DINFER_EXTENSION) -ADD_DEFINITIONS(-DAGL_DEVEL) -ADD_LIBRARY(afb-lib STATIC +############################################################################ +# TODO: improve below setting by using config file +option(WITH_SIG_MONITOR_DUMPSTACK "Activate dump stack on error" ON) +option(WITH_SIG_MONITOR_SIGNALS "Activate handling of signals" ON) +option(WITH_SIG_MONITOR_FOR_CALL "Activate monitoring of calls" ON) +option(WITH_SIG_MONITOR_TIMERS "Activate monitoring of call expiration" ON) +option(WITH_AFB_HOOK "Include hooking" ON) +option(WITH_AFB_TRACE "Include monitoring trace" ON) +option(WITH_SUPERVISOR "Activates installation of supervisor" OFF) +option(WITH_DBUS_TRANSPARENCY "Allows API transparency over DBUS" OFF) +option(WITH_LEGACY_BINDING_V1 "Includes the legacy Binding API version 1" OFF) +option(WITH_LEGACY_BINDING_V2 "Includes the legacy Binding API version 2" ON) +option(WITH_LEGACY_BINDING_VDYN "Includes the legacy Binding API version dynamic" OFF) +option(WITH_DYNAMIC_BINDING "Allow to load dynamic bindings (shared libraries)" ON) + +if(INCLUDE_SUPERVISOR) + set(WITH_SUPERVISOR ON) +endif() +if(INCLUDE_DBUS_TRANSPARENCY) + set(WITH_DBUS_TRANSPARENCY ON) +endif() +if(INCLUDE_LEGACY_BINDING_V1) + set(WITH_LEGACY_BINDING_V1 ON) +endif() +if(INCLUDE_LEGACY_BINDING_VDYN) + set(WITH_LEGACY_BINDING_VDYN ON) +endif() + +add_definitions( + -DAGL_DEVEL=$ + -DWITH_SIG_MONITOR_DUMPSTACK=$ + -DWITH_SIG_MONITOR_SIGNALS=$ + -DWITH_SIG_MONITOR_FOR_CALL=$ + -DWITH_SIG_MONITOR_TIMERS=$ + -DWITH_AFB_HOOK=$ + -DWITH_AFB_TRACE=$ + -DWITH_LEGACY_BINDING_V1=$ + -DWITH_LEGACY_BINDING_V2=$ + -DWITH_LEGACY_BINDING_VDYN=$ + -DWITH_DBUS_TRANSPARENCY=$ + -DWITH_SUPERVISION=$ + -DWITH_DYNAMIC_BINDING=$ +) +############################################################################ + +SET(AFB_LIB_SOURCES afb-api.c afb-api-dbus.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-args.c afb-auth.c + afb-autoset.c + afb-calls.c afb-common.c - afb-config.c afb-context.c afb-cred.c afb-debug.c - afb-ditf.c + afb-error-text.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 afb-method.c afb-monitor.c afb-msg-json.c + afb-perm.c + afb-permission-text.c + afb-proto-ws.c afb-session.c + afb-socket.c afb-stub-ws.c - afb-svc.c + afb-supervision.c + afb-token.c afb-trace.c afb-websock.c afb-ws-client.c @@ -63,20 +115,32 @@ 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 - sd-fds.c + pearson.c + process-name.c sig-monitor.c subpath.c + systemd.c + u16id.c + uuid.c verbose.c + watchdog.c websock.c wrap-json.c ) +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} @@ -84,27 +148,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-args.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} @@ -113,4 +191,3 @@ TARGET_LINK_LIBRARIES(afb-client-demo INSTALL(TARGETS afb-client-demo RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) -