diff options
author | emersion <contact@emersion.fr> | 2018-04-06 14:13:52 -0400 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2018-04-06 14:13:52 -0400 |
commit | 8b07a4d05559698d3d88e227b2bb97f3fc9c4ca8 (patch) | |
tree | 477dd94767e5365cf2a916ed2cee5834c4f5fa16 | |
parent | ae4cef9e4189bddee5c7d8bd0e0e99c0bed43ea5 (diff) |
Emit xwayland unmap signal before unmapping
This allows compositors to access the surface being unmapped. This
is also more consistent with the destroy signal.
-rw-r--r-- | xwayland/xwm.c | 10 |
1 files changed, 5 insertions, 5 deletions
diff --git a/xwayland/xwm.c b/xwayland/xwm.c index c2b9bd11..886fe251 100644 --- a/xwayland/xwm.c +++ b/xwayland/xwm.c @@ -743,6 +743,11 @@ static void xwm_handle_unmap_notify(struct wlr_xwm *xwm, return; } + if (xsurface->mapped) { + xsurface->mapped = false; + wlr_signal_emit_safe(&xsurface->events.unmap, xsurface); + } + if (xsurface->surface_id) { // Make sure we're not on the unpaired surface list or we // could be assigned a surface during surface creation that @@ -757,11 +762,6 @@ static void xwm_handle_unmap_notify(struct wlr_xwm *xwm, } xsurface->surface = NULL; - if (xsurface->mapped) { - xsurface->mapped = false; - wlr_signal_emit_safe(&xsurface->events.unmap, xsurface); - } - xsurface_set_wm_state(xsurface, ICCCM_WITHDRAWN_STATE); } |