mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-10 17:59:48 +01:00
Merge pull request #1084 from martinetd/use-after-free
use-after-free fixes (xdg_shell popups, primary selection source, xwm parents)
This commit is contained in:
commit
e51829ff7c
4 changed files with 19 additions and 1 deletions
|
@ -229,9 +229,9 @@ void wlr_seat_set_primary_selection(struct wlr_seat *seat,
|
|||
}
|
||||
|
||||
if (seat->primary_selection_source) {
|
||||
wl_list_remove(&seat->primary_selection_source_destroy.link);
|
||||
seat->primary_selection_source->cancel(seat->primary_selection_source);
|
||||
seat->primary_selection_source = NULL;
|
||||
wl_list_remove(&seat->primary_selection_source_destroy.link);
|
||||
}
|
||||
|
||||
seat->primary_selection_source = source;
|
||||
|
|
|
@ -415,6 +415,12 @@ void destroy_xdg_surface(struct wlr_xdg_surface *surface) {
|
|||
|
||||
wlr_signal_emit_safe(&surface->events.destroy, surface);
|
||||
|
||||
struct wlr_xdg_popup *popup_state, *next;
|
||||
wl_list_for_each_safe(popup_state, next, &surface->popups, link) {
|
||||
xdg_popup_send_popup_done(popup_state->resource);
|
||||
destroy_xdg_popup(popup_state->base);
|
||||
}
|
||||
|
||||
switch (surface->role) {
|
||||
case WLR_XDG_SURFACE_ROLE_TOPLEVEL:
|
||||
destroy_xdg_toplevel(surface);
|
||||
|
|
|
@ -100,6 +100,12 @@ void destroy_xdg_surface_v6(struct wlr_xdg_surface_v6 *surface) {
|
|||
|
||||
wlr_signal_emit_safe(&surface->events.destroy, surface);
|
||||
|
||||
struct wlr_xdg_popup_v6 *popup_state, *next;
|
||||
wl_list_for_each_safe(popup_state, next, &surface->popups, link) {
|
||||
zxdg_popup_v6_send_popup_done(popup_state->resource);
|
||||
destroy_xdg_popup_v6(popup_state->base);
|
||||
}
|
||||
|
||||
switch (surface->role) {
|
||||
case WLR_XDG_SURFACE_V6_ROLE_TOPLEVEL:
|
||||
destroy_xdg_toplevel_v6(surface);
|
||||
|
|
|
@ -294,6 +294,12 @@ static void xwayland_surface_destroy(
|
|||
wl_list_remove(&xsurface->link);
|
||||
wl_list_remove(&xsurface->parent_link);
|
||||
|
||||
struct wlr_xwayland_surface *child, *next;
|
||||
wl_list_for_each_safe(child, next, &xsurface->children, parent_link) {
|
||||
wl_list_remove(&child->parent_link);
|
||||
wl_list_init(&child->parent_link);
|
||||
}
|
||||
|
||||
if (xsurface->surface_id) {
|
||||
wl_list_remove(&xsurface->unpaired_link);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue