]> git.mdlowis.com Git - proto/labwc.git/commitdiff
xdg-deco: Respect decoration requests properly
authorJoshua Ashton <joshua@froggi.es>
Wed, 20 Oct 2021 16:03:27 +0000 (16:03 +0000)
committerJohan Malm <johanmalm@users.noreply.github.com>
Wed, 20 Oct 2021 17:49:02 +0000 (18:49 +0100)
Signed-off-by: Joshua Ashton <joshua@froggi.es>
include/labwc.h
src/view.c
src/xdg-deco.c

index ab8ad091c37aa00b83fe548ddf461f86a1ba6a3f..6ab051822cfbf1d25ca9bb9470e7574895b47d11 100644 (file)
@@ -355,6 +355,7 @@ void view_set_fullscreen(struct view *view, bool fullscreen,
        struct wlr_output *wlr_output);
 void view_toggle_maximize(struct view *view);
 void view_toggle_decorations(struct view *view);
+void view_set_decorations(struct view *view, bool decorations);
 void view_toggle_fullscreen(struct view *view);
 void view_for_each_surface(struct view *view,
        wlr_surface_iterator_func_t iterator, void *user_data);
index bb5c2b12871e51fc8df9fa26943c199dcf4e3c6d..a8b91ac76238bbfccd44d731fc0a29194963c093 100644 (file)
@@ -177,6 +177,15 @@ view_toggle_decorations(struct view *view)
        ssd_update_geometry(view, true);
 }
 
+void
+view_set_decorations(struct view *view, bool decorations)
+{
+       if (view->ssd.enabled != decorations) {
+               view->ssd.enabled = decorations;
+               ssd_update_geometry(view, true);
+       }
+}
+
 void
 view_toggle_fullscreen(struct view *view)
 {
index c4e4b57286f1955792f05b728db6772e1963eb90..b5d110fa7b6db9501a9f12611a6ddfc25335fc0b 100644 (file)
@@ -4,6 +4,7 @@
 struct xdg_deco {
        struct wlr_xdg_toplevel_decoration_v1 *wlr_decoration;
        struct server *server;
+       struct view *view;
        struct wl_listener destroy;
        struct wl_listener request_mode;
 };
@@ -21,15 +22,19 @@ xdg_deco_destroy(struct wl_listener *listener, void *data)
 static void
 xdg_deco_request_mode(struct wl_listener *listener, void *data)
 {
-       struct xdg_deco *xdg_deco;
-       xdg_deco = wl_container_of(listener, xdg_deco, request_mode);
-       enum wlr_xdg_toplevel_decoration_v1_mode mode;
-       if (rc.xdg_shell_server_side_deco) {
-               mode = WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE;
-       } else {
-               mode = WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_CLIENT_SIDE;
+       struct xdg_deco *xdg_deco = wl_container_of(listener, xdg_deco, request_mode);
+       enum wlr_xdg_toplevel_decoration_v1_mode client_mode =
+               xdg_deco->wlr_decoration->requested_mode;
+       
+       if (client_mode == WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_NONE) {
+               client_mode = rc.xdg_shell_server_side_deco
+                       ? WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE
+                       : WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_CLIENT_SIDE;
        }
-       wlr_xdg_toplevel_decoration_v1_set_mode(xdg_deco->wlr_decoration, mode);
+
+       wlr_xdg_toplevel_decoration_v1_set_mode(xdg_deco->wlr_decoration, client_mode);
+       view_set_decorations(xdg_deco->view,
+               client_mode == WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE);
 }
 
 void
@@ -44,10 +49,12 @@ xdg_toplevel_decoration(struct wl_listener *listener, void *data)
        }
        xdg_deco->wlr_decoration = wlr_decoration;
        xdg_deco->server = server;
+       xdg_deco->view = wlr_decoration->surface->data;
        xdg_deco->destroy.notify = xdg_deco_destroy;
        wl_signal_add(&wlr_decoration->events.destroy, &xdg_deco->destroy);
        xdg_deco->request_mode.notify = xdg_deco_request_mode;
        wl_signal_add(&wlr_decoration->events.request_mode,
                      &xdg_deco->request_mode);
+
        xdg_deco_request_mode(&xdg_deco->request_mode, wlr_decoration);
 }