summaryrefslogtreecommitdiffstats
path: root/AFBClient.h
diff options
context:
space:
mode:
authorMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-08-31 14:15:53 +0200
committerMarcus Fritzsch <marcus_fritzsch@mentor.com>2017-09-14 14:04:51 +0200
commit2f3a00b5f628b9db684505fc6566148cf6701d0a (patch)
treee676218f58f11a828b5d73591fb88ec0779ef873 /AFBClient.h
parentf203185be97a192a4174c7d5f89be3bfb4e29ac2 (diff)
Add set_event_handler, added int returns for all API methods.
Signed-off-by: Marcus Fritzsch <marcus_fritzsch@mentor.com>
Diffstat (limited to 'AFBClient.h')
-rw-r--r--AFBClient.h25
1 files changed, 20 insertions, 5 deletions
diff --git a/AFBClient.h b/AFBClient.h
index 5b8bb6d..f8f824a 100644
--- a/AFBClient.h
+++ b/AFBClient.h
@@ -3,6 +3,8 @@
#include <systemd/sd-event.h>
+#include <functional>
+
extern "C"
{
#include <json-c/json.h>
@@ -18,19 +20,32 @@ class AFBClient
virtual~AFBClient();
public:
+ enum EventType {
+ Event_Active = 1,
+ Event_Inactive,
+ Event_Visible,
+ Event_Invisible,
+ Event_SyncDraw,
+ Event_FlushDraw,
+ };
+
static AFBClient &instance()
{
static AFBClient obj;
return obj;
}
- bool init();
- int requestSurface(const char *label);
- void activateSurface(const char *label);
- void deactivateSurface(const char *label);
- void endDraw(const char *label);
+ int init(int port, char const *token);
int dispatch(uint64_t timeout);
+ // WM API
+ int requestSurface(const char *label);
+ int activateSurface(const char *label);
+ int deactivateSurface(const char *label);
+ int endDraw(const char *label);
+
+ void set_event_handler(enum EventType et, std::function<void(char const *label)> f);
+
static void onCall(void *closure, const char *api, const char *verb, struct afb_wsj1_msg *msg);
static void onEvent(void *closure, const char *event, struct afb_wsj1_msg *msg);
static void onHangup(void *closure, struct afb_wsj1 *wsj1);