summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFurkan Sahin <furkan-dev@proton.me>2025-05-21 18:47:10 -0500
committerFurkan Sahin <furkan-dev@proton.me>2025-05-21 18:47:10 -0500
commit7416b643637e05f77110aa98155c9721a5353c64 (patch)
treea731c57338c4dd942f3c259a7e83fd04aee32179
parentb39314b329172fc3adec6c562e3297d92367e99b (diff)
layer-shell: reclaim space from unmapped layer surfaces
wlroots resets 'initialized' when a layer surface is unmapped and sway doesn't rearrange the layer surfaces in response to a commit of a surface where 'initialized' is false. This results in space not getting reclaimed from a recently unmapped layer surface until some other action causes 'arrange_layers' to get called. This commit makes sure all layer surfaces get rearranged when a layer surface is unmapped.
-rw-r--r--sway/desktop/layer_shell.c6
1 files changed, 1 insertions, 5 deletions
diff --git a/sway/desktop/layer_shell.c b/sway/desktop/layer_shell.c
index b14a9a4b..08b5b1de 100644
--- a/sway/desktop/layer_shell.c
+++ b/sway/desktop/layer_shell.c
@@ -269,12 +269,8 @@ static void handle_surface_commit(struct wl_listener *listener, void *data) {
wl_container_of(listener, surface, surface_commit);
struct wlr_layer_surface_v1 *layer_surface = surface->layer_surface;
- if (!layer_surface->initialized) {
- return;
- }
-
uint32_t committed = layer_surface->current.committed;
- if (committed & WLR_LAYER_SURFACE_V1_STATE_LAYER) {
+ if (layer_surface->initialized && committed & WLR_LAYER_SURFACE_V1_STATE_LAYER) {
enum zwlr_layer_shell_v1_layer layer_type = layer_surface->current.layer;
struct wlr_scene_tree *output_layer = sway_layer_get_scene(
surface->output, layer_type);