mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2024-11-26 06:35:58 +01:00
subcompositor: fix mapped parent check
This commit is contained in:
parent
eb3e8f08a8
commit
911648f430
1 changed files with 9 additions and 4 deletions
|
@ -183,6 +183,8 @@ static const struct wl_subsurface_interface subsurface_implementation = {
|
||||||
.set_desync = subsurface_handle_set_desync,
|
.set_desync = subsurface_handle_set_desync,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const struct wlr_surface_role subsurface_role;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if this subsurface needs to be marked as mapped. The subsurface
|
* Checks if this subsurface needs to be marked as mapped. The subsurface
|
||||||
* is considered mapped if both:
|
* is considered mapped if both:
|
||||||
|
@ -194,11 +196,14 @@ static void subsurface_consider_map(struct wlr_subsurface *subsurface) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: unify "mapped" flag
|
||||||
|
if (subsurface->parent->role == &subsurface_role) {
|
||||||
struct wlr_subsurface *parent =
|
struct wlr_subsurface *parent =
|
||||||
wlr_subsurface_try_from_wlr_surface(subsurface->parent);
|
wlr_subsurface_try_from_wlr_surface(subsurface->parent);
|
||||||
if (parent == NULL || !parent->mapped) {
|
if (parent == NULL || !parent->mapped) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Now we can map the subsurface
|
// Now we can map the subsurface
|
||||||
subsurface->mapped = true;
|
subsurface->mapped = true;
|
||||||
|
|
Loading…
Reference in a new issue