Add set_event_handler, added int returns for all API methods.
[staging/windowmanager.git] / AFBClient.h
index 3961baf..f8f824a 100644 (file)
@@ -3,7 +3,8 @@
 
 #include <systemd/sd-event.h>
 
-#ifdef AFB
+#include <functional>
+
 extern "C"
 {
 #include <json-c/json.h>
@@ -11,7 +12,6 @@ extern "C"
 #include "afb-wsj1.h"
 #include "afb-ws-client.h"
 }
-#endif
 
 class AFBClient
 {
@@ -20,23 +20,36 @@ 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();
-    void 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);
     static void onReply(void *closure, struct afb_wsj1_msg *msg);
-    static void onRequestSurfaceReply(void *closure, struct afb_wsj1_msg *msg);
 
 private:
     void call(const char *api, const char *verb, const char *object);
@@ -49,5 +62,4 @@ private:
     static const char *wmURI;
     static const char *wmAPI;
 };
-
 #endif // AFBCLIENT_H