X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwayland.hpp;h=ba1effdc235c3231b5471586724712c4bf9d2d36;hb=dc465727c14a7d7588dad8554afc08f55e769b76;hp=20e88c5a46c81d0f63baccf6f99341551e40d1df;hpb=e066b091da80364a84905c3d8fc37ebc6d7e849d;p=staging%2Fwindowmanager.git diff --git a/src/wayland.hpp b/src/wayland.hpp index 20e88c5..ba1effd 100644 --- a/src/wayland.hpp +++ b/src/wayland.hpp @@ -6,8 +6,8 @@ #include "util.h" #include -#include #include +#include #include // _ _ @@ -39,7 +39,25 @@ struct wayland_proxy { // |_| |_|\__,_|_| |_| |_|\___||___/ .__/ \__,_|\___\___| \_/\_/ |_| // |_| namespace wl { -struct registry; +// _ _ +// _ __ ___ __ _(_)___| |_ _ __ _ _ +// | '__/ _ \/ _` | / __| __| '__| | | | +// | | | __/ (_| | \__ \ |_| | | |_| | +// |_| \___|\__, |_|___/\__|_| \__, | +// |___/ |___/ +struct registry : public wayland_proxy { + typedef std::function binder; + std::unordered_map bindings; + + registry(struct wl_display *d); + ~registry(); + + void add_global_handler(char const *iface, binder bind); + + // Events + void global(uint32_t name, char const *iface, uint32_t v); + void global_remove(uint32_t name); +}; // _ _ _ // __| (_)___ _ __ | | __ _ _ _ @@ -50,7 +68,7 @@ struct registry; struct display { std::unique_ptr> d; - std::unique_ptr r; + struct registry r; display(); ~display(); @@ -61,26 +79,6 @@ struct display { int get_fd() const; }; -// _ _ -// _ __ ___ __ _(_)___| |_ _ __ _ _ -// | '__/ _ \/ _` | / __| __| '__| | | | -// | | | __/ (_| | \__ \ |_| | | |_| | -// |_| \___|\__, |_|___/\__|_| \__, | -// |___/ |___/ -struct registry : public wayland_proxy { - typedef std::function binder; - std::map bindings; - - registry(struct wl_display *d); - ~registry(); - - void add_global_handler(char const *iface, binder bind); - - // Events - void global(uint32_t name, char const *iface, uint32_t v); - void global_remove(uint32_t name); -}; - // _ _ // ___ _ _| |_ _ __ _ _| |_ // / _ \| | | | __| '_ \| | | | __| @@ -201,7 +199,15 @@ struct surface : public wayland_proxy, // |___/ struct layer : public wayland_proxy, controlled_entity { + struct rect dst_rect; + struct rect src_rect; + struct size size; + int32_t orientation; + int32_t visibility; + float opacity; + layer(uint32_t i, struct controller *c); + layer(uint32_t i, int32_t w, int32_t h, struct controller *c); ~layer() override; // Requests @@ -249,8 +255,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); } }; @@ -263,6 +274,19 @@ struct layer : public wayland_proxy, struct screen : public wayland_proxy, controlled_entity { 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 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); + } }; // _ _ _ @@ -272,14 +296,16 @@ 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; std::vector pending; + size output_size; + void add_task(char const *name, std::function &&f) { this->pending.emplace_back(std::make_pair(name, f)); @@ -293,12 +319,18 @@ struct controller : public wayland_proxy { } this->pending.clear(); ivi_controller_commit_changes(this->proxy); + // XXX: No flush here... } } controller(struct wl_registry *r, uint32_t name, uint32_t version); ~controller() override; + // Requests + void commit_changes() const { ivi_controller_commit_changes(this->proxy); } + void layer_create(uint32_t id, int32_t w, int32_t h); + void surface_create(uint32_t id); + // Events // controller void controller_screen(uint32_t id, struct ivi_controller_screen *screen);