summaryrefslogtreecommitdiffstats
path: root/sway/desktop/xdg_shell_v6.c
diff options
context:
space:
mode:
Diffstat (limited to 'sway/desktop/xdg_shell_v6.c')
-rw-r--r--sway/desktop/xdg_shell_v6.c26
1 files changed, 26 insertions, 0 deletions
diff --git a/sway/desktop/xdg_shell_v6.c b/sway/desktop/xdg_shell_v6.c
index e4703040..133b60c3 100644
--- a/sway/desktop/xdg_shell_v6.c
+++ b/sway/desktop/xdg_shell_v6.c
@@ -118,6 +118,14 @@ static void set_activated(struct sway_view *view, bool activated) {
118 } 118 }
119} 119}
120 120
121static void set_fullscreen(struct sway_view *view, bool fullscreen) {
122 if (xdg_shell_v6_view_from_view(view) == NULL) {
123 return;
124 }
125 struct wlr_xdg_surface_v6 *surface = view->wlr_xdg_surface_v6;
126 wlr_xdg_toplevel_v6_set_fullscreen(surface, fullscreen);
127}
128
121static void for_each_surface(struct sway_view *view, 129static void for_each_surface(struct sway_view *view,
122 wlr_surface_iterator_func_t iterator, void *user_data) { 130 wlr_surface_iterator_func_t iterator, void *user_data) {
123 if (xdg_shell_v6_view_from_view(view) == NULL) { 131 if (xdg_shell_v6_view_from_view(view) == NULL) {
@@ -146,6 +154,7 @@ static void destroy(struct sway_view *view) {
146 wl_list_remove(&xdg_shell_v6_view->destroy.link); 154 wl_list_remove(&xdg_shell_v6_view->destroy.link);
147 wl_list_remove(&xdg_shell_v6_view->map.link); 155 wl_list_remove(&xdg_shell_v6_view->map.link);
148 wl_list_remove(&xdg_shell_v6_view->unmap.link); 156 wl_list_remove(&xdg_shell_v6_view->unmap.link);
157 wl_list_remove(&xdg_shell_v6_view->request_fullscreen.link);
149 free(xdg_shell_v6_view); 158 free(xdg_shell_v6_view);
150} 159}
151 160
@@ -153,6 +162,7 @@ static const struct sway_view_impl view_impl = {
153 .get_prop = get_prop, 162 .get_prop = get_prop,
154 .configure = configure, 163 .configure = configure,
155 .set_activated = set_activated, 164 .set_activated = set_activated,
165 .set_fullscreen = set_fullscreen,
156 .for_each_surface = for_each_surface, 166 .for_each_surface = for_each_surface,
157 .close = _close, 167 .close = _close,
158 .destroy = destroy, 168 .destroy = destroy,
@@ -210,6 +220,18 @@ static void handle_destroy(struct wl_listener *listener, void *data) {
210 view_destroy(&xdg_shell_v6_view->view); 220 view_destroy(&xdg_shell_v6_view->view);
211} 221}
212 222
223static void handle_request_fullscreen(struct wl_listener *listener, void *data) {
224 struct sway_xdg_shell_v6_view *xdg_shell_v6_view =
225 wl_container_of(listener, xdg_shell_v6_view, request_fullscreen);
226 struct wlr_xdg_toplevel_v6_set_fullscreen_event *e = data;
227
228 if (xdg_shell_v6_view->view.wlr_xdg_surface_v6->role != WLR_XDG_SURFACE_V6_ROLE_TOPLEVEL) {
229 return;
230 }
231
232 view_set_fullscreen(&xdg_shell_v6_view->view, e->fullscreen);
233}
234
213void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data) { 235void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data) {
214 struct sway_server *server = wl_container_of(listener, server, 236 struct sway_server *server = wl_container_of(listener, server,
215 xdg_shell_v6_surface); 237 xdg_shell_v6_surface);
@@ -246,4 +268,8 @@ void handle_xdg_shell_v6_surface(struct wl_listener *listener, void *data) {
246 268
247 xdg_shell_v6_view->destroy.notify = handle_destroy; 269 xdg_shell_v6_view->destroy.notify = handle_destroy;
248 wl_signal_add(&xdg_surface->events.destroy, &xdg_shell_v6_view->destroy); 270 wl_signal_add(&xdg_surface->events.destroy, &xdg_shell_v6_view->destroy);
271
272 xdg_shell_v6_view->request_fullscreen.notify = handle_request_fullscreen;
273 wl_signal_add(&xdg_surface->toplevel->events.request_fullscreen,
274 &xdg_shell_v6_view->request_fullscreen);
249} 275}