diff options
-rw-r--r-- | sway/desktop/xwayland.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/sway/desktop/xwayland.c b/sway/desktop/xwayland.c index 75bfb7b2..55c42227 100644 --- a/sway/desktop/xwayland.c +++ b/sway/desktop/xwayland.c | |||
@@ -77,6 +77,18 @@ static void unmanaged_handle_unmap(struct wl_listener *listener, void *data) { | |||
77 | desktop_damage_surface(xsurface->surface, xsurface->x, xsurface->y, true); | 77 | desktop_damage_surface(xsurface->surface, xsurface->x, xsurface->y, true); |
78 | wl_list_remove(&surface->link); | 78 | wl_list_remove(&surface->link); |
79 | wl_list_remove(&surface->commit.link); | 79 | wl_list_remove(&surface->commit.link); |
80 | |||
81 | if (!wlr_xwayland_surface_is_unmanaged(xsurface)) { | ||
82 | // Restore focus | ||
83 | struct sway_seat *seat = input_manager_current_seat(input_manager); | ||
84 | struct sway_container *previous = | ||
85 | seat_get_focus_inactive(seat, &root_container); | ||
86 | if (previous) { | ||
87 | // Hack to get seat to re-focus the return value of get_focus | ||
88 | seat_set_focus(seat, previous->parent); | ||
89 | seat_set_focus(seat, previous); | ||
90 | } | ||
91 | } | ||
80 | } | 92 | } |
81 | 93 | ||
82 | static void unmanaged_handle_destroy(struct wl_listener *listener, void *data) { | 94 | static void unmanaged_handle_destroy(struct wl_listener *listener, void *data) { |