X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwayland.hpp;h=df9b68e33019af3834da7bef0d4d868cd0eda0d6;hb=304eff45622c058bacad63326d5ffc2b8f75b8da;hp=c8a7113a0115fba458ed748517156f4728d4de98;hpb=edb416241ef3a38dbade052c8361b8b96049894e;p=staging%2Fwindowmanager.git diff --git a/src/wayland.hpp b/src/wayland.hpp index c8a7113..df9b68e 100644 --- a/src/wayland.hpp +++ b/src/wayland.hpp @@ -6,7 +6,7 @@ #include "util.h" #include -#include +#include #include #include @@ -69,7 +69,7 @@ struct display { // |___/ |___/ struct registry : public wayland_proxy { typedef std::function binder; - std::map bindings; + std::unordered_map bindings; registry(struct wl_display *d); ~registry(); @@ -257,8 +257,13 @@ struct layer : public wayland_proxy, ivi_controller_layer_remove_surface(this->proxy, surface->proxy); } - inline void set_render_order(struct wl_array *surfaces) { - ivi_controller_layer_set_render_order(this->proxy, surfaces); + void set_render_order(std::vector const &ro) { + struct wl_array wlro{ + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_layer_set_render_order(this->proxy, &wlro); } }; @@ -273,7 +278,17 @@ struct screen : public wayland_proxy, screen(uint32_t i, struct controller *c, struct ivi_controller_screen *p); void clear() { ivi_controller_screen_clear(this->proxy); } - void add_layer(layer *l) { ivi_controller_screen_add_layer(this->proxy, l->proxy); } + void add_layer(layer *l) { + ivi_controller_screen_add_layer(this->proxy, l->proxy); + } + void set_render_order(std::vector const &ro) { + struct wl_array wlro{ + .size = ro.size() * sizeof(ro[0]), + .alloc = ro.capacity() * sizeof(ro[0]), + .data = const_cast(static_cast(ro.data())) + }; + ivi_controller_screen_set_render_order(this->proxy, &wlro); + } }; // _ _ _ @@ -283,9 +298,9 @@ struct screen : public wayland_proxy, // \___\___/|_| |_|\__|_| \___/|_|_|\___|_| // struct controller : public wayland_proxy { - std::map> surfaces; - std::map> layers; - std::map> screens; + std::unordered_map> surfaces; + std::unordered_map> layers; + std::unordered_map> screens; typedef std::pair> name_task_pair;