view: Recursively check mapped of view_child tree

A subsurface may be set to mapped without its parent.
This commit is contained in:
Kenny Levinsen 2021-02-19 18:39:54 +01:00 committed by Simon Ser
parent 2c917a8c34
commit e7af5b6309

View file

@ -982,8 +982,18 @@ static void view_child_subsurface_create(struct sway_view_child *child,
view_child_damage(&subsurface->child, true); view_child_damage(&subsurface->child, true);
} }
static bool view_child_is_mapped(struct sway_view_child *child) {
while (child) {
if (!child->mapped) {
return false;
}
child = child->parent;
}
return true;
}
static void view_child_damage(struct sway_view_child *child, bool whole) { static void view_child_damage(struct sway_view_child *child, bool whole) {
if (!child || !child->mapped || !child->view || !child->view->container) { if (!child || !view_child_is_mapped(child) || !child->view || !child->view->container) {
return; return;
} }
int sx, sy; int sx, sy;
@ -1082,7 +1092,7 @@ void view_child_init(struct sway_view_child *child,
} }
void view_child_destroy(struct sway_view_child *child) { void view_child_destroy(struct sway_view_child *child) {
if (child->mapped && child->view->container != NULL) { if (view_child_is_mapped(child) && child->view->container != NULL) {
view_child_damage(child, true); view_child_damage(child, true);
} }