mirror of
https://github.com/swaywm/sway.git
synced 2025-01-02 10:26:42 +01:00
handle_seat_node_destroy: update seat->workspace
If an unmanaged or layer surface is focused when an output gets disabled and an empty workspace on the output was focused by the seat, the seat needs to refocus it's focus inactive to update the value of `seat->workspace`.
This commit is contained in:
parent
cdf30033af
commit
9350a52c0e
1 changed files with 13 additions and 0 deletions
|
@ -146,6 +146,19 @@ static void handle_seat_node_destroy(struct wl_listener *listener, void *data) {
|
||||||
struct sway_node *focus = seat_get_focus(seat);
|
struct sway_node *focus = seat_get_focus(seat);
|
||||||
|
|
||||||
if (node->type == N_WORKSPACE) {
|
if (node->type == N_WORKSPACE) {
|
||||||
|
// If an unmanaged or layer surface is focused when an output gets
|
||||||
|
// disabled and an empty workspace on the output was focused by the
|
||||||
|
// seat, the seat needs to refocus it's focus inactive to update the
|
||||||
|
// value of seat->workspace.
|
||||||
|
if (seat->workspace == node->sway_workspace) {
|
||||||
|
struct sway_node *node = seat_get_focus_inactive(seat, &root->node);
|
||||||
|
seat_set_focus(seat, NULL);
|
||||||
|
if (node) {
|
||||||
|
seat_set_focus(seat, node);
|
||||||
|
} else {
|
||||||
|
seat->workspace = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
seat_node_destroy(seat_node);
|
seat_node_destroy(seat_node);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue