diff options
author | Kazumasa Mitsunari <knimitz@witz-inc.co.jp> | 2017-10-23 18:26:46 +0900 |
---|---|---|
committer | Jan-Simon Moeller <jsmoeller@linuxfoundation.org> | 2017-11-01 11:02:10 +0000 |
commit | be02238a0e92c74a13daaf516b5f379f29217eb8 (patch) | |
tree | 15e1b814a50a9f4833a318a1ba55b8d029f81b8b /src/app.hpp | |
parent | ac5b834e535b95d2b893dbe527b2a7a9b6e2103d (diff) |
Modify event notification from broadcast to subscribe model
The event notification was implemented using a broadcast model,
change it to a subscription model.
Bug-AGL: SPEC-987
Change-Id: I344a3a73320eb81c3f670736b032f07400bb8f64
Signed-off-by: Kazumasa Mitsunari <knimitz@witz-inc.co.jp>
Diffstat (limited to 'src/app.hpp')
-rw-r--r-- | src/app.hpp | 28 |
1 files changed, 27 insertions, 1 deletions
diff --git a/src/app.hpp b/src/app.hpp index ea3e92b..9f8b7ce 100644 --- a/src/app.hpp +++ b/src/app.hpp @@ -93,7 +93,6 @@ struct id_allocator { } // Remove a surface id and name - // I don't think I will need this, do I? void remove_id(std::string const &name) { auto i = this->name2id.find(name); if (i != this->name2id.end()) { @@ -112,6 +111,30 @@ struct id_allocator { }; struct App { + enum EventType { + Event_Val_Min = 0, + + Event_Active = Event_Val_Min, + Event_Inactive, + + Event_Visible, + Event_Invisible, + + Event_SyncDraw, + Event_FlushDraw, + + Event_Val_Max = Event_FlushDraw, + }; + + const std::vector<const char *> kListEventName{ + "active", + "inactive", + "visible", + "invisible", + "syncdraw", + "flushdraw" + }; + struct binding_api api; struct controller_hooks chooks; @@ -136,6 +159,8 @@ struct App { Policy policy; + std::map<const char *, struct afb_event> map_afb_event; + explicit App(wl::display *d); ~App() = default; @@ -155,6 +180,7 @@ struct App { char const *api_activate_surface(char const *drawing_name, char const *drawing_area); char const *api_deactivate_surface(char const *drawing_name); char const *api_enddraw(char const *drawing_name); + char const *api_subscribe(afb_req *req, char const *event_name); void api_ping(); // Events from the compositor we are interested in |