aboutsummaryrefslogtreecommitdiff
path: root/backend
diff options
context:
space:
mode:
Diffstat (limited to 'backend')
-rw-r--r--backend/wayland/backend.c7
-rw-r--r--backend/wayland/output.c16
2 files changed, 23 insertions, 0 deletions
diff --git a/backend/wayland/backend.c b/backend/wayland/backend.c
index 7c8bb4e0..701ba79b 100644
--- a/backend/wayland/backend.c
+++ b/backend/wayland/backend.c
@@ -16,6 +16,7 @@
#include "backend/wayland.h"
#include "util/signal.h"
+#include "xdg-decoration-unstable-v1-client-protocol.h"
#include "xdg-shell-client-protocol.h"
struct wlr_wl_backend *get_wl_backend_from_backend(struct wlr_backend *backend) {
@@ -76,6 +77,9 @@ static void registry_global(void *data, struct wl_registry *registry,
wl->xdg_wm_base = wl_registry_bind(registry, name,
&xdg_wm_base_interface, 1);
xdg_wm_base_add_listener(wl->xdg_wm_base, &xdg_wm_base_listener, NULL);
+ } else if (strcmp(iface, zxdg_decoration_manager_v1_interface.name) == 0) {
+ wl->zxdg_decoration_manager_v1 = wl_registry_bind(registry, name,
+ &zxdg_decoration_manager_v1_interface, 1);
}
}
@@ -148,6 +152,9 @@ static void backend_destroy(struct wlr_backend *backend) {
if (wl->shm) {
wl_shm_destroy(wl->shm);
}
+ if (wl->zxdg_decoration_manager_v1) {
+ zxdg_decoration_manager_v1_destroy(wl->zxdg_decoration_manager_v1);
+ }
xdg_wm_base_destroy(wl->xdg_wm_base);
wl_compositor_destroy(wl->compositor);
wl_registry_destroy(wl->registry);
diff --git a/backend/wayland/output.c b/backend/wayland/output.c
index 2eaaaf9c..d28e8c01 100644
--- a/backend/wayland/output.c
+++ b/backend/wayland/output.c
@@ -16,6 +16,7 @@
#include "backend/wayland.h"
#include "util/signal.h"
+#include "xdg-decoration-unstable-v1-client-protocol.h"
#include "xdg-shell-client-protocol.h"
static struct wlr_wl_output *get_wl_output_from_output(
@@ -187,6 +188,9 @@ static void output_destroy(struct wlr_output *wlr_output) {
wlr_egl_destroy_surface(&output->backend->egl, output->egl_surface);
wl_egl_window_destroy(output->egl_window);
+ if (output->zxdg_toplevel_decoration_v1) {
+ zxdg_toplevel_decoration_v1_destroy(output->zxdg_toplevel_decoration_v1);
+ }
xdg_toplevel_destroy(output->xdg_toplevel);
xdg_surface_destroy(output->xdg_surface);
wl_surface_destroy(output->surface);
@@ -318,6 +322,18 @@ struct wlr_output *wlr_wl_output_create(struct wlr_backend *wlr_backend) {
goto error;
}
+ if (backend->zxdg_decoration_manager_v1) {
+ output->zxdg_toplevel_decoration_v1 =
+ zxdg_decoration_manager_v1_get_toplevel_decoration(
+ backend->zxdg_decoration_manager_v1, output->xdg_toplevel);
+ if (!output->xdg_toplevel) {
+ wlr_log_errno(WLR_ERROR, "Could not get xdg toplevel decoration");
+ goto error;
+ }
+ zxdg_toplevel_decoration_v1_set_mode(output->zxdg_toplevel_decoration_v1,
+ ZXDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE);
+ }
+
wlr_wl_output_set_title(wlr_output, NULL);
xdg_toplevel_set_app_id(output->xdg_toplevel, "wlroots");