X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=3e3a9e159f8f0d7f18208f1fdc4c47ed4c60097a;hb=65353dce81a629e042800bb7b86fcd869a76727e;hp=67e3abce5c3955371c09c7303fa719c6ef43ed07;hpb=c7e9786d408f13d8f8f43c6b68da916bbb1ed5f3;p=src%2Fapp-framework-binder.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 67e3abce..3e3a9e15 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,36 +1,193 @@ +########################################################################### +# Copyright (C) 2015-2020 "IoT.bzh" +# +# author: José Bollo +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +########################################################################### -ADD_LIBRARY(afb-lib OBJECT +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(-DINTRINSIC_BINDING_DIR="${INTRINSIC_BINDING_DIR}") +# Always add INFER_EXTENSION (more details in afb-hreq.c) +ADD_DEFINITIONS(-DINFER_EXTENSION) + +############################################################################ +# 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-apis.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-context.c + afb-cred.c + afb-debug.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-sig-handler.c + afb-perm.c + afb-permission-text.c + afb-proto-ws.c + afb-session.c + afb-socket.c + afb-stub-ws.c + afb-supervision.c + afb-token.c + afb-trace.c afb-websock.c afb-ws-client.c afb-ws-json1.c afb-ws.c afb-wsj1.c - session.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 + u16id.c + uuid.c verbose.c + watchdog.c websock.c + wrap-json.c ) +ADD_LIBRARY(afb-lib STATIC ${AFB_LIB_SOURCES}) -INCLUDE_DIRECTORIES(${include_dirs}) +########################################### +# build and install afb-daemon +########################################### +ADD_EXECUTABLE(afb-daemon main-afb-daemon.c) +TARGET_LINK_LIBRARIES(afb-daemon + afb-lib + ${link_libraries} +) +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() -ADD_EXECUTABLE(afb-daemon $ main.c) -INCLUDE_DIRECTORIES(${include_dirs}) -TARGET_LINK_LIBRARIES(afb-daemon ${link_libraries}) +########################################### +# build and install libafbwsc +########################################### +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 afb-proto-ws.h DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/afb) -ADD_EXECUTABLE(afb-client-demo $ afb-client-demo.c) -INCLUDE_DIRECTORIES(${include_dirs}) -TARGET_LINK_LIBRARIES(afb-client-demo ${link_libraries}) +########################################### +# build and install afb-client-demo +########################################### +ADD_EXECUTABLE(afb-client-demo main-afb-client-demo.c) +TARGET_LINK_LIBRARIES(afb-client-demo + afbwsc + ${link_libraries} + ${libsystemd_LDFLAGS} +) +INSTALL(TARGETS afb-client-demo + RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) -INSTALL(TARGETS afb-daemon - RUNTIME DESTINATION ${CMAKE_INSTALL_PREFIX}/${CMAKE_INSTALL_BINDIR})