diff options
author | emersion <contact@emersion.fr> | 2017-10-06 16:44:55 +0200 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2017-10-06 16:44:55 +0200 |
commit | b21f783c34f145545b0109b06b135cd1e9fa8b70 (patch) | |
tree | ea17b686a6e28532e83a6d9d34e31c59df6d2c46 /rootston/wl_shell.c | |
parent | ecc0f712af823e1017f000ddf65d79f4e2ecd601 (diff) |
Disconnect wl_shell clients when closing
Diffstat (limited to 'rootston/wl_shell.c')
-rw-r--r-- | rootston/wl_shell.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/rootston/wl_shell.c b/rootston/wl_shell.c index 1991d332..55ffd2eb 100644 --- a/rootston/wl_shell.c +++ b/rootston/wl_shell.c @@ -17,6 +17,12 @@ static void resize(struct roots_view *view, uint32_t width, uint32_t height) { height); } +static void close(struct roots_view *view) { + assert(view->type == ROOTS_WL_SHELL_VIEW); + struct wlr_wl_shell_surface *surf = view->wl_shell_surface; + wl_client_destroy(surf->client); +} + static void handle_request_move(struct wl_listener *listener, void *data) { struct roots_wl_shell_surface *roots_surface = wl_container_of(listener, roots_surface, request_move); @@ -88,6 +94,7 @@ void handle_wl_shell_surface(struct wl_listener *listener, void *data) { view->roots_wl_shell_surface = roots_surface; view->wlr_surface = surface->surface; view->resize = resize; + view->close = close; view->desktop = desktop; roots_surface->view = view; list_add(desktop->views, view); |