diff options
-rw-r--r-- | generate-binding-glue.py | 5 | ||||
-rw-r--r-- | src/afb_binding_api.cpp | 2 | ||||
-rw-r--r-- | src/app.cpp | 14 | ||||
-rw-r--r-- | src/app.hpp | 1 | ||||
-rw-r--r-- | src/main.cpp | 1 | ||||
-rw-r--r-- | src/wayland.cpp | 3 |
6 files changed, 19 insertions, 7 deletions
diff --git a/generate-binding-glue.py b/generate-binding-glue.py index 086ad32..4791b4d 100644 --- a/generate-binding-glue.py +++ b/generate-binding-glue.py @@ -73,7 +73,8 @@ def emit_afb_verbs(api): p(' {}', '};') def emit_binding(api): - p('namespace {', '') + p('namespace {') + p('std::mutex binding_m;', '') for func in api['functions']: emit_func(api, func) p('} // namespace', '') @@ -95,7 +96,7 @@ def emit_afb_api(api): for f in api['functions']: p(' result_type %(name)s(' % f + ', '.join(map(lambda x: '%(type)s %(name)s' % x, f.get('args', []))) + ');') p('};', '') - p('} // namespace wm') + p('} // namespace wm', '') # names must always be valid in c and unique for each function (that is its arguments) # arguments will be looked up from json request, range checking needs to be implemented diff --git a/src/afb_binding_api.cpp b/src/afb_binding_api.cpp index 7e6aa89..41eed13 100644 --- a/src/afb_binding_api.cpp +++ b/src/afb_binding_api.cpp @@ -100,7 +100,7 @@ binding_api::result_type binding_api::debug_terminate() { } binding_api::result_type binding_api::ping() { - this->app->dispatch_events(); + this->app->dispatch_pending_events(); return Ok(json_object_new_object()); } diff --git a/src/app.cpp b/src/app.cpp index e42d05f..7b2b69c 100644 --- a/src/app.cpp +++ b/src/app.cpp @@ -147,9 +147,8 @@ int App::init() { } int App::dispatch_events() { - if (this->pending_events.load(std::memory_order_consume)) { - this->pending_events.store(false, std::memory_order_release); - return this->display->dispatch_pending(); + if (this->dispatch_events() == 0) { + return 0; } int ret = this->display->dispatch(); @@ -166,6 +165,15 @@ int App::dispatch_events() { return 0; } +int App::dispatch_pending_events() { + if (this->pending_events.load(std::memory_order_consume)) { + this->pending_events.store(false, std::memory_order_release); + this->display->dispatch_pending(); + return 0; + } + return -1; +} + // _ _ _ _ _ ____ // (_)_ __ (_) |_ | | __ _ _ _ ___ _ _| |_ / /\ \ // | | '_ \| | __| | |/ _` | | | |/ _ \| | | | __| | | | diff --git a/src/app.hpp b/src/app.hpp index 00a2ba2..e295797 100644 --- a/src/app.hpp +++ b/src/app.hpp @@ -162,6 +162,7 @@ struct App { int init_layers(); int dispatch_events(); + int dispatch_pending_events(); void surface_set_layout_full(uint32_t surface_id); void surface_set_layout_split(uint32_t surface_id, uint32_t sub_surface_id); diff --git a/src/main.cpp b/src/main.cpp index 4c04f74..aee2756 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -30,7 +30,6 @@ extern "C" { } namespace { -std::mutex binding_m; struct afb_instance { std::unique_ptr<wl::display> display; diff --git a/src/wayland.cpp b/src/wayland.cpp index 25c2359..fb18386 100644 --- a/src/wayland.cpp +++ b/src/wayland.cpp @@ -16,6 +16,7 @@ #include <utility> +#include "util.hpp" #include "wayland.hpp" // _ @@ -46,8 +47,10 @@ int display::dispatch() { return wl_display_dispatch(this->d.get()); } int display::dispatch_pending() { return wl_display_dispatch_pending(this->d.get()); } int display::read_events() { + ST(); // XXX: uhm, how?! while (wl_display_prepare_read(this->d.get()) == -1) { + STN(pending_events_dispatch); if (wl_display_dispatch_pending(this->d.get()) == -1) { return -1; } |