mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2024-11-21 14:42:25 +00:00
xwayland/xwm: listen shell destroy signal
Otherwise we got invaild write in wl_list_remove.
Fixes: e209fe2d0
("Fix memory leak in xwayland.c")
Signed-off-by: zhoulei <zhoulei@kylinos.cn>
This commit is contained in:
parent
e6dbe4580e
commit
2c64f36e88
@ -140,6 +140,7 @@ struct wlr_xwm {
|
||||
struct wl_listener compositor_new_surface;
|
||||
struct wl_listener compositor_destroy;
|
||||
struct wl_listener shell_v1_new_surface;
|
||||
struct wl_listener shell_v1_destroy;
|
||||
struct wl_listener seat_set_selection;
|
||||
struct wl_listener seat_set_primary_selection;
|
||||
struct wl_listener seat_start_drag;
|
||||
|
@ -1859,6 +1859,16 @@ static void handle_shell_v1_new_surface(struct wl_listener *listener,
|
||||
}
|
||||
}
|
||||
|
||||
static void handle_shell_v1_destroy(struct wl_listener *listener,
|
||||
void *data) {
|
||||
struct wlr_xwm *xwm =
|
||||
wl_container_of(listener, xwm, shell_v1_destroy);
|
||||
wl_list_remove(&xwm->shell_v1_new_surface.link);
|
||||
wl_list_remove(&xwm->shell_v1_destroy.link);
|
||||
wl_list_init(&xwm->shell_v1_new_surface.link);
|
||||
wl_list_init(&xwm->shell_v1_destroy.link);
|
||||
}
|
||||
|
||||
void wlr_xwayland_surface_activate(struct wlr_xwayland_surface *xsurface,
|
||||
bool activated) {
|
||||
struct wlr_xwayland_surface *focused = xsurface->xwm->focus_surface;
|
||||
@ -1986,6 +1996,7 @@ void xwm_destroy(struct wlr_xwm *xwm) {
|
||||
wl_list_remove(&xwm->compositor_new_surface.link);
|
||||
wl_list_remove(&xwm->compositor_destroy.link);
|
||||
wl_list_remove(&xwm->shell_v1_new_surface.link);
|
||||
wl_list_remove(&xwm->shell_v1_destroy.link);
|
||||
xcb_disconnect(xwm->xcb_conn);
|
||||
|
||||
struct pending_startup_id *pending, *next;
|
||||
@ -2331,6 +2342,9 @@ struct wlr_xwm *xwm_create(struct wlr_xwayland *xwayland, int wm_fd) {
|
||||
xwm->shell_v1_new_surface.notify = handle_shell_v1_new_surface;
|
||||
wl_signal_add(&xwayland->shell_v1->events.new_surface,
|
||||
&xwm->shell_v1_new_surface);
|
||||
xwm->shell_v1_destroy.notify = handle_shell_v1_destroy;
|
||||
wl_signal_add(&xwayland->shell_v1->events.destroy,
|
||||
&xwm->shell_v1_destroy);
|
||||
|
||||
xwm_create_wm_window(xwm);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user