Add support for L4Re Virtio Sockets
[src/app-framework-binder.git] / src / CMakeLists.txt
index d81c314..4696894 100644 (file)
@@ -1,5 +1,5 @@
 ###########################################################################
-# Copyright (C) 2015-2018 "IoT.bzh"
+# Copyright (C) 2015-2019 "IoT.bzh"
 #
 # author: José Bollo <jose.bollo@iot.bzh>
 #
@@ -20,24 +20,67 @@ 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_definitions(-DBINDING_INSTALL_DIR="${binding_install_dir}")
+
+############################################################################
+# TODO: improve below setting by using config file
+
+add_definitions(
+  -DAGL_DEVEL=$<BOOL:${AGL_DEVEL}>
+  -DWITH_SIG_MONITOR_DUMPSTACK=$<BOOL:${WITH_SIG_MONITOR_DUMPSTACK}>
+  -DWITH_SIG_MONITOR_SIGNALS=$<BOOL:${WITH_SIG_MONITOR_SIGNALS}>
+  -DWITH_SIG_MONITOR_FOR_CALL=$<BOOL:${WITH_SIG_MONITOR_FOR_CALL}>
+  -DWITH_SIG_MONITOR_TIMERS=$<BOOL:${WITH_SIG_MONITOR_TIMERS}>
+  -DWITH_AFB_HOOK=$<BOOL:${WITH_AFB_HOOK}>
+  -DWITH_AFB_TRACE=$<BOOL:${WITH_AFB_TRACE}>
+  -DWITH_LEGACY_BINDING_V1=$<BOOL:${INCLUDE_LEGACY_BINDING_V1}>
+  -DWITH_LEGACY_BINDING_V2=$<BOOL:${WITH_LEGACY_BINDING_V2}>
+  -DWITH_LEGACY_BINDING_VDYN=$<BOOL:${INCLUDE_LEGACY_BINDING_VDYN}>
+  -DWITH_DBUS_TRANSPARENCY=$<BOOL:${INCLUDE_DBUS_TRANSPARENCY}>
+  -DWITH_SUPERVISION=$<BOOL:${INCLUDE_SUPERVISOR}>
+  -DWITH_DYNAMIC_BINDING=$<BOOL:${WITH_DYNAMIC_BINDING}>
+  -DWITH_SYSTEMD=$<BOOL:${WITH_SYSTEMD}>
+  -DWITH_FDEV_EPOLL=$<NOT:$<BOOL:${WITH_SYSTEMD}>>
+  -DWITH_LIBMICROHTTPD=$<BOOL:${WITH_LIBMICROHTTPD}>
+  -DWITH_MONITORING=$<BOOL:${WITH_MONITORING}>
+  -DWITH_FNMATCH=$<BOOL:${WITH_FNMATCH}>
+  -DWITH_L4VSOCK=$<BOOL:${WITH_L4VSOCK}>
+)
+
+if (WITH_SUPERVISOR)
+  add_definitions(
+     -DAFS_SUPERVISION_SOCKET=\"${AFS_SUPERVISION_SOCKET}\"
+     -DAFS_SUPERVISOR_TOKEN=\"${AFS_SUPERVISOR_TOKEN}\"
+     -DAFS_SUPERVISOR_PORT=${AFS_SUPERVISOR_PORT}
+  )
+endif()
+
+if(WITH_LIBMICROHTTPD)
+  # Always add INFER_EXTENSION (more details in afb-hreq.c)
+  add_definitions(
+     -DINFER_EXTENSION=1
+     -DUSE_MAGIC_MIME_TYPE=1
+  )
+endif()
+
+############################################################################
 
 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
@@ -56,7 +99,7 @@ SET(AFB_LIB_SOURCES
        afb-session.c
        afb-socket.c
        afb-stub-ws.c
-       afb-systemd.c
+       afb-supervision.c
        afb-trace.c
        afb-websock.c
        afb-ws-client.c
@@ -64,9 +107,11 @@ SET(AFB_LIB_SOURCES
        afb-ws.c
        afb-wsj1.c
        afb-xreq.c
+       evmgr.c
        fdev.c
        fdev-epoll.c
        fdev-systemd.c
+       globmatch.c
        globset.c
        jobs.c
        locale-root.c
@@ -74,29 +119,13 @@ SET(AFB_LIB_SOURCES
        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})
 
 ###########################################
@@ -114,7 +143,7 @@ INSTALL(TARGETS afb-daemon
 # 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)
+       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}