diff options
author | emersion <contact@emersion.fr> | 2017-10-06 15:58:49 +0200 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2017-10-06 16:03:35 +0200 |
commit | 69aff9b35e0e5ce1031aaa65a0166423bc95d192 (patch) | |
tree | 43c935a7253bccbc32bc2d432eca2c94983a414f /rootston | |
parent | 972e9dbd1b2eb2853a60632d279bd754daf7c440 (diff) |
Implement wlr_xdg_toplevel_v6_send_close
Diffstat (limited to 'rootston')
-rw-r--r-- | rootston/xdg_shell_v6.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/rootston/xdg_shell_v6.c b/rootston/xdg_shell_v6.c index ab34f52a..c7072354 100644 --- a/rootston/xdg_shell_v6.c +++ b/rootston/xdg_shell_v6.c @@ -33,6 +33,14 @@ static void resize(struct roots_view *view, uint32_t width, uint32_t height) { } } +static void close(struct roots_view *view) { + assert(view->type == ROOTS_XDG_SHELL_V6_VIEW); + struct wlr_xdg_surface_v6 *surf = view->xdg_surface_v6; + if (surf->role == WLR_XDG_SURFACE_V6_ROLE_TOPLEVEL) { + wlr_xdg_toplevel_v6_send_close(surf); + } +} + static void handle_request_move(struct wl_listener *listener, void *data) { struct roots_xdg_surface_v6 *roots_xdg_surface = wl_container_of(listener, roots_xdg_surface, request_move); @@ -107,6 +115,7 @@ void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data) { view->get_size = get_size; view->activate = activate; view->resize = resize; + view->close = close; view->desktop = desktop; roots_surface->view = view; list_add(desktop->views, view); |