diff options
author | Marcus Fritzsch <marcus_fritzsch@mentor.com> | 2017-08-31 14:15:53 +0200 |
---|---|---|
committer | Marcus Fritzsch <marcus_fritzsch@mentor.com> | 2017-09-14 14:04:51 +0200 |
commit | 2f3a00b5f628b9db684505fc6566148cf6701d0a (patch) | |
tree | e676218f58f11a828b5d73591fb88ec0779ef873 /AFBClient.h | |
parent | f203185be97a192a4174c7d5f89be3bfb4e29ac2 (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.h | 25 |
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); |