X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fwayland.hpp;h=da3cc29647bdee8ad0f4e3b537e43791ef5da37b;hb=1e4ce4dfbb457caa9452d16d76f112cff228ff69;hp=889b7220b97a11e41753a1b3db73389ccd3383d7;hpb=a0eba6dbbf675a45f744fb8d6f4fb3cc1c901713;p=staging%2Fwindowmanager.git diff --git a/src/wayland.hpp b/src/wayland.hpp index 889b722..da3cc29 100644 --- a/src/wayland.hpp +++ b/src/wayland.hpp @@ -27,7 +27,7 @@ struct wayland_proxy { // custom wayland dtor if (this->proxy) { logdebug("%s %p @ %p", __func__, this, this->proxy); - wl_proxy_destroy(reinterpret_cast(proxy)); + wl_proxy_destroy(reinterpret_cast(this->proxy)); } } }; @@ -57,6 +57,8 @@ struct display { bool ok() const; void roundtrip(); int dispatch(); + void flush(); + int get_fd() const; }; // _ _ @@ -86,6 +88,10 @@ struct registry : public wayland_proxy { // \___/ \__,_|\__| .__/ \__,_|\__| // |_| struct output : wayland_proxy { + int width; + int height; + int refresh; + output(struct wl_registry *registry, uint32_t name, uint32_t version); // Events @@ -110,45 +116,14 @@ struct output : wayland_proxy { // |___/ namespace genivi { -// -// _ __ __ _ _ __ ___ ___ ___ _ __ __ _ ___ ___ -// | '_ \ / _` | '_ ` _ \ / _ \/ __| '_ \ / _` |/ __/ _ \ -// | | | | (_| | | | | | | __/\__ \ |_) | (_| | (_| __/ -// |_| |_|\__,_|_| |_| |_|\___||___/ .__/ \__,_|\___\___| -// |_| -// _ _ __ -// _ __ ___ | |_(_)/ _|_ _ -// | '_ \ / _ \| __| | |_| | | | -// | | | | (_) | |_| | _| |_| | -// |_| |_|\___/ \__|_|_| \__, | -// |___/ -namespace notify { -enum property { - Dimensions, // i.e. configure - DestRect, - SrcRect, - ZOrder, - Vibility, - Opacity, - Layer, - Surface, - Content, - Orientation, - Screen, +struct size { + uint32_t w, h; }; -template -struct notifier { - typedef std::function ReceiverT; - - std::vector receivers; - - virtual ~notifier() {} - - void add_receiver(ReceiverT); - void notify(enum property) const; +struct rect { + uint32_t w, h; + int32_t x, y; }; -} struct controller; @@ -168,6 +143,13 @@ struct controlled_entity { // struct surface : public wayland_proxy, controlled_entity { + struct rect dst_rect; + struct rect src_rect; + struct size size; + int32_t orientation; + int32_t visibility; + float opacity; + surface(uint32_t i, struct controller *c); ~surface() override; @@ -219,7 +201,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 @@ -267,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); } }; @@ -281,6 +276,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); + } }; // _ _ _ @@ -294,15 +302,44 @@ struct controller : public wayland_proxy { std::map> layers; std::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)); + } + + void execute_pending() { + if (!this->pending.empty()) { + for (auto &t : this->pending) { + logdebug("executing task '%s'", t.first); + t.second(this); + } + 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 screen(uint32_t id, struct ivi_controller_screen *screen); - void layer(uint32_t id); - void surface(uint32_t id); - void error(int32_t oid, int32_t otype, int32_t code, char const *text); + void controller_screen(uint32_t id, struct ivi_controller_screen *screen); + void controller_layer(uint32_t id); + void controller_surface(uint32_t id); + void controller_error(int32_t oid, int32_t otype, int32_t code, + char const *text); // surface void surface_visibility(uint32_t id, int32_t visibility);