Introduce afb_eventid
[src/app-framework-binder.git] / include / afb / afb-binding-v1.h
index e6f322f..4f881cd 100644 (file)
 
 struct json_object;
 
-#include "afb-req-itf.h"
-#include "afb-event-itf.h"
+#include "afb-req-common.h"
+#include "afb-event.h"
 #include "afb-service-common.h"
 #include "afb-daemon-common.h"
 
+#include "afb-req-v1.h"
 #include "afb-session-v1.h"
-#include "afb-daemon-v1.h"
+#include "afb-service-v1.h"
 #include "afb-daemon-v1.h"
 
 struct afb_binding_v1;
@@ -126,7 +127,8 @@ struct afb_binding_v1
 /*
  * config mode
  */
-enum afb_mode_v1 {
+enum afb_mode_v1
+{
        AFB_MODE_LOCAL = 0,     /* run locally */
        AFB_MODE_REMOTE,        /* run remotely */
        AFB_MODE_GLOBAL         /* run either remotely or locally (DONT USE! reserved for future) */
@@ -145,87 +147,60 @@ struct afb_binding_interface_v1
 /*
  * Macros for logging messages
  */
-#if !defined(AFB_BINDING_PRAGMA_NO_VERBOSE_MACRO)
-# if !defined(AFB_BINDING_PRAGMA_NO_VERBOSE_DETAILS)
-#  define AFB_ERROR_V1(itf,...)   do{if(itf->verbosity>=0)afb_daemon_verbose(itf->daemon,3,__FILE__,__LINE__,__VA_ARGS__);}while(0)
-#  define AFB_WARNING_V1(itf,...) do{if(itf->verbosity>=1)afb_daemon_verbose(itf->daemon,4,__FILE__,__LINE__,__VA_ARGS__);}while(0)
-#  define AFB_NOTICE_V1(itf,...)  do{if(itf->verbosity>=1)afb_daemon_verbose(itf->daemon,5,__FILE__,__LINE__,__VA_ARGS__);}while(0)
-#  define AFB_INFO_V1(itf,...)    do{if(itf->verbosity>=2)afb_daemon_verbose(itf->daemon,6,__FILE__,__LINE__,__VA_ARGS__);}while(0)
-#  define AFB_DEBUG_V1(itf,...)   do{if(itf->verbosity>=3)afb_daemon_verbose(itf->daemon,7,__FILE__,__LINE__,__VA_ARGS__);}while(0)
-# else
-#  define AFB_ERROR_V1(itf,...)   do{if(itf->verbosity>=0)afb_daemon_verbose(itf->daemon,3,NULL,0,__VA_ARGS__);}while(0)
-#  define AFB_WARNING_V1(itf,...) do{if(itf->verbosity>=1)afb_daemon_verbose(itf->daemon,4,NULL,0,__VA_ARGS__);}while(0)
-#  define AFB_NOTICE_V1(itf,...)  do{if(itf->verbosity>=1)afb_daemon_verbose(itf->daemon,5,NULL,0,__VA_ARGS__);}while(0)
-#  define AFB_INFO_V1(itf,...)    do{if(itf->verbosity>=2)afb_daemon_verbose(itf->daemon,6,NULL,0,__VA_ARGS__);}while(0)
-#  define AFB_DEBUG_V1(itf,...)   do{if(itf->verbosity>=3)afb_daemon_verbose(itf->daemon,7,NULL,0,__VA_ARGS__);}while(0)
-# endif
-#endif
-
-
-/***************************************************************************************************/
-
-#if AFB_BINDING_VERSION == 1
-
-# define afb_binding           afb_binding_v1
-# define afb_binding_interface afb_binding_interface_v1
-
-# define AFB_SESSION_NONE      AFB_SESSION_NONE_V1
-# define AFB_SESSION_CREATE    AFB_SESSION_CREATE_V1
-# define AFB_SESSION_CLOSE     AFB_SESSION_CLOSE_V1
-# define AFB_SESSION_RENEW     AFB_SESSION_RENEW_V1
-# define AFB_SESSION_CHECK     AFB_SESSION_CHECK_V1
-
-# define AFB_SESSION_LOA_GE    AFB_SESSION_LOA_GE_V1
-# define AFB_SESSION_LOA_LE    AFB_SESSION_LOA_LE_V1
-# define AFB_SESSION_LOA_EQ    AFB_SESSION_LOA_EQ_V1
-
-# define AFB_SESSION_LOA_SHIFT AFB_SESSION_LOA_SHIFT_V1
-# define AFB_SESSION_LOA_MASK  AFB_SESSION_LOA_MASK_V1
-
-# define AFB_SESSION_LOA_0     AFB_SESSION_LOA_0_V1
-# define AFB_SESSION_LOA_1     AFB_SESSION_LOA_1_V1
-# define AFB_SESSION_LOA_2     AFB_SESSION_LOA_2_V1
-# define AFB_SESSION_LOA_3     AFB_SESSION_LOA_3_V1
-# define AFB_SESSION_LOA_4     AFB_SESSION_LOA_4_V1
-
-# define AFB_SESSION_LOA_LE_0  AFB_SESSION_LOA_LE_0_V1
-# define AFB_SESSION_LOA_LE_1  AFB_SESSION_LOA_LE_1_V1
-# define AFB_SESSION_LOA_LE_2  AFB_SESSION_LOA_LE_2_V1
-# define AFB_SESSION_LOA_LE_3  AFB_SESSION_LOA_LE_3_V1
-
-# define AFB_SESSION_LOA_EQ_0  AFB_SESSION_LOA_EQ_0_V1
-# define AFB_SESSION_LOA_EQ_1  AFB_SESSION_LOA_EQ_1_V1
-# define AFB_SESSION_LOA_EQ_2  AFB_SESSION_LOA_EQ_2_V1
-# define AFB_SESSION_LOA_EQ_3  AFB_SESSION_LOA_EQ_3_V1
-
-# define AFB_SESSION_LOA_GE_0  AFB_SESSION_LOA_GE_0_V1
-# define AFB_SESSION_LOA_GE_1  AFB_SESSION_LOA_GE_1_V1
-# define AFB_SESSION_LOA_GE_2  AFB_SESSION_LOA_GE_2_V1
-# define AFB_SESSION_LOA_GE_3  AFB_SESSION_LOA_GE_3_V1
-
-# if !defined(AFB_BINDING_PRAGMA_NO_VERBOSE_MACRO)
-
-#  define ERROR                        AFB_ERROR_V1
-#  define WARNING              AFB_WARNING_V1
-#  define NOTICE               AFB_NOTICE_V1
-#  define INFO                 AFB_INFO_V1
-#  define DEBUG                        AFB_DEBUG_V1
-
-# endif
-
-#define afb_daemon_get_event_loop      afb_daemon_get_event_loop_v1
-#define afb_daemon_get_user_bus                afb_daemon_get_user_bus_v1
-#define afb_daemon_get_system_bus      afb_daemon_get_system_bus_v1
-#define afb_daemon_broadcast_event     afb_daemon_broadcast_event_v1
-#define afb_daemon_make_event          afb_daemon_make_event_v1
-#define afb_daemon_verbose             afb_daemon_verbose_v1
-#define afb_daemon_rootdir_get_fd      afb_daemon_rootdir_get_fd_v1
-#define afb_daemon_rootdir_open_locale afb_daemon_rootdir_open_locale_v1
-#define afb_daemon_queue_job           afb_daemon_queue_job_v1
-
-#define afb_service_call               afb_service_call_v1
+#if defined(AFB_BINDING_PRAGMA_NO_VERBOSE_DATA)
+
+# define _AFB_LOGGING_V1_(itf,vlevel,llevel,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) {\
+                       if (llevel <= AFB_VERBOSITY_LEVEL_ERROR) \
+                               afb_daemon_verbose2_v1(itf->daemon,llevel,__FILE__,__LINE__,__func__,__VA_ARGS__); \
+                       else \
+                               afb_daemon_verbose2_v1(itf->daemon,llevel,__FILE__,__LINE__,NULL,NULL); \
+               } \
+       }while(0)
+# define _AFB_REQ_LOGGING_V1_(itf,vlevel,llevel,req,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) \
+                       afb_req_verbose(req,llevel,__FILE__,__LINE__,NULL,NULL); \
+       }while(0)
+
+#elif defined(AFB_BINDING_PRAGMA_NO_VERBOSE_DETAILS)
+
+# define _AFB_LOGGING_V1_(itf,vlevel,llevel,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) \
+                       afb_daemon_verbose2_v1(itf->daemon,llevel,NULL,0,NULL,__VA_ARGS__); \
+       }while(0)
+# define _AFB_REQ_LOGGING_V1_(itf,vlevel,llevel,req,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) \
+                       afb_req_verbose(req,llevel,NULL,0,NULL,__VA_ARGS__); \
+       }while(0)
+
+#else
+
+# define _AFB_LOGGING_V1_(itf,vlevel,llevel,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) \
+                       afb_daemon_verbose2_v1(itf->daemon,llevel,__FILE__,__LINE__,__func__,__VA_ARGS__); \
+       }while(0)
+# define _AFB_REQ_LOGGING_V1_(itf,vlevel,llevel,req,...) \
+       do{ \
+               if(itf->verbosity>=vlevel) \
+                       afb_req_verbose(req,llevel,__FILE__,__LINE__,__func__,__VA_ARGS__); \
+       }while(0)
 
 #endif
 
-
+# include "afb-verbosity.h"
+# define AFB_ERROR_V1(itf,...)       _AFB_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_ERROR,_AFB_SYSLOG_LEVEL_ERROR_,__VA_ARGS__)
+# define AFB_WARNING_V1(itf,...)     _AFB_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_WARNING,_AFB_SYSLOG_LEVEL_WARNING_,__VA_ARGS__)
+# define AFB_NOTICE_V1(itf,...)      _AFB_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_NOTICE,_AFB_SYSLOG_LEVEL_NOTICE_,__VA_ARGS__)
+# define AFB_INFO_V1(itf,...)        _AFB_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_INFO,_AFB_SYSLOG_LEVEL_INFO_,__VA_ARGS__)
+# define AFB_DEBUG_V1(itf,...)       _AFB_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_DEBUG,_AFB_SYSLOG_LEVEL_DEBUG_,__VA_ARGS__)
+# define AFB_REQ_ERROR_V1(itf,...)   _AFB_REQ_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_ERROR,_AFB_SYSLOG_LEVEL_ERROR_,__VA_ARGS__)
+# define AFB_REQ_WARNING_V1(itf,...) _AFB_REQ_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_WARNING,_AFB_SYSLOG_LEVEL_WARNING_,__VA_ARGS__)
+# define AFB_REQ_NOTICE_V1(itf,...)  _AFB_REQ_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_NOTICE,_AFB_SYSLOG_LEVEL_NOTICE_,__VA_ARGS__)
+# define AFB_REQ_INFO_V1(itf,...)    _AFB_REQ_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_INFO,_AFB_SYSLOG_LEVEL_INFO_,__VA_ARGS__)
+# define AFB_REQ_DEBUG_V1(itf,...)   _AFB_REQ_LOGGING_V1_(itf,AFB_VERBOSITY_LEVEL_DEBUG,_AFB_SYSLOG_LEVEL_DEBUG_,__VA_ARGS__)