From 8de18f9bb4fe82d94fa76750fa398b28041f3fe3 Mon Sep 17 00:00:00 2001 From: Guido Cella Date: Fri, 4 Sep 2020 21:14:02 +0200 Subject: fix restoring pointer focus I don't know why I thought it was working before. Maybe I should go do something else. --- dwl.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'dwl.c') diff --git a/dwl.c b/dwl.c index 34ca1e4..d6974b0 100644 --- a/dwl.c +++ b/dwl.c @@ -140,6 +140,7 @@ typedef struct { struct wlr_box geo; enum zwlr_layer_shell_v1_layer layer; + bool unmapping; } LayerSurface; typedef struct { @@ -2082,6 +2083,7 @@ toggleview(const Arg *arg) void unmaplayersurface(LayerSurface *layersurface) { + layersurface->unmapping = true; if (layersurface->layer_surface->surface == seat->keyboard_state.focused_surface) focusclient(NULL, selclient(), 1); @@ -2141,7 +2143,10 @@ xytolayersurface(struct wl_list *layer_surfaces, double x, double y, { LayerSurface *layersurface; wl_list_for_each_reverse(layersurface, layer_surfaces, link) { - struct wlr_surface *sub = wlr_layer_surface_v1_surface_at( + struct wlr_surface *sub; + if (layersurface->unmapping) + continue; + sub = wlr_layer_surface_v1_surface_at( layersurface->layer_surface, x - layersurface->geo.x, y - layersurface->geo.y, -- cgit v1.2.3