X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=AFBClient.h;h=f42aeea99ae1bad0989c2a6abbd8160f63b4456b;hb=6766079f68f6a7e2ccdd68b36e9eb206229dd4f7;hp=f8f824af2693eaeee102a5a54dc37f7b387344ac;hpb=2f3a00b5f628b9db684505fc6566148cf6701d0a;p=staging%2Fwindowmanager.git diff --git a/AFBClient.h b/AFBClient.h index f8f824a..f42aeea 100644 --- a/AFBClient.h +++ b/AFBClient.h @@ -1,23 +1,15 @@ #ifndef AFBCLIENT_H #define AFBCLIENT_H -#include - #include -extern "C" -{ -#include - -#include "afb-wsj1.h" -#include "afb-ws-client.h" -} - class AFBClient { - explicit AFBClient(); - AFBClient(const AFBClient& that) = delete; - virtual~AFBClient(); + AFBClient(); + ~AFBClient(); + + AFBClient(const AFBClient &) = delete; + AFBClient &operator=(const AFBClient &) = delete; public: enum EventType { @@ -29,14 +21,10 @@ public: Event_FlushDraw, }; - static AFBClient &instance() - { - static AFBClient obj; - return obj; - } + static AFBClient &instance(); int init(int port, char const *token); - int dispatch(uint64_t timeout); + int dispatch(); // WM API int requestSurface(const char *label); @@ -44,22 +32,12 @@ public: int deactivateSurface(const char *label); int endDraw(const char *label); - void set_event_handler(enum EventType et, std::function f); + void set_event_handler(enum EventType et, + std::function 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); + struct Impl; private: - void call(const char *api, const char *verb, const char *object); - void event(const char *event, const char *object); - - struct afb_wsj1 *wsj1; - struct afb_wsj1_itf itf; - - sd_event *loop; - static const char *wmURI; - static const char *wmAPI; + Impl *d; }; #endif // AFBCLIENT_H