mirror of
https://github.com/swaywm/sway.git
synced 2025-01-02 18:37:55 +01:00
Fix crash when fullscreen view closes on inactive workspace
When a view unmaps, normally the surviving ancestor (ie. after reaping) needs to be arranged. When a fullscreen view unmaps, it arranges the workspace rather than the surviving ancestor, but didn't handle cases where the workspace itself was reaped. This happens if the workspace is not currently shown and the fullscreen view was the last container on that workspace. This commit rewrites this part of view_unmap so it's more readable, and fixes the crash by not arranging the workspace if it's been reaped. Note that it no longer arranges the output under any circumstance - this wasn't required anyway.
This commit is contained in:
parent
5ac3509d54
commit
854c5fbec8
1 changed files with 9 additions and 10 deletions
|
@ -592,19 +592,18 @@ void view_unmap(struct sway_view *view) {
|
||||||
view->urgent_timer = NULL;
|
view->urgent_timer = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct sway_container *ws = container_parent(view->swayc, C_WORKSPACE);
|
bool was_fullscreen = view->swayc->is_fullscreen;
|
||||||
|
struct sway_container *surviving_ancestor = container_destroy(view->swayc);
|
||||||
|
|
||||||
struct sway_container *parent;
|
// If the workspace wasn't reaped
|
||||||
if (container_is_fullscreen_or_child(view->swayc)) {
|
if (surviving_ancestor->type >= C_WORKSPACE) {
|
||||||
parent = container_destroy(view->swayc);
|
struct sway_container *ws = surviving_ancestor->type == C_WORKSPACE ?
|
||||||
arrange_windows(ws->parent);
|
surviving_ancestor :
|
||||||
} else {
|
container_parent(surviving_ancestor, C_WORKSPACE);
|
||||||
parent = container_destroy(view->swayc);
|
arrange_windows(was_fullscreen ? ws : surviving_ancestor);
|
||||||
arrange_windows(parent);
|
|
||||||
}
|
|
||||||
if (parent->type >= C_WORKSPACE) { // if the workspace still exists
|
|
||||||
workspace_detect_urgent(ws);
|
workspace_detect_urgent(ws);
|
||||||
}
|
}
|
||||||
|
|
||||||
transaction_commit_dirty();
|
transaction_commit_dirty();
|
||||||
view->surface = NULL;
|
view->surface = NULL;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue