aboutsummaryrefslogtreecommitdiff
path: root/sway/handlers.c
diff options
context:
space:
mode:
Diffstat (limited to 'sway/handlers.c')
-rw-r--r--sway/handlers.c37
1 files changed, 35 insertions, 2 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index 32b0051d..e57b791b 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -130,6 +130,38 @@ static void handle_view_geometry_request(wlc_handle view, const struct wlc_geome
// deny that shit
}
+static void handle_view_state_request(wlc_handle view, enum wlc_view_state_bit state, bool toggle) {
+ switch(state) {
+ case WLC_BIT_FULLSCREEN:
+ {
+ //I3 just lets it become fullscreen
+ wlc_view_set_state(view,state,toggle);
+ swayc_t *c = get_swayc_for_handle(view, &root_container);
+ sway_log(L_DEBUG, "setting view %ld %s, fullscreen %d",view,c->name,toggle);
+ if (c) {
+ arrange_windows(c->parent, -1, -1);
+ //Set it as focused window for that workspace if its going
+ //fullscreen
+ if (toggle) {
+ swayc_t *ws = c;
+ while (ws->type != C_WORKSPACE) {
+ ws = ws->parent;
+ }
+ //Set ws focus to c
+ focus_view_for(ws, c);
+ }
+ }
+ break;
+ }
+ case WLC_BIT_MAXIMIZED:
+ case WLC_BIT_RESIZING:
+ case WLC_BIT_MOVING:
+ case WLC_BIT_ACTIVATED:
+ break;
+ }
+ return;
+}
+
static bool handle_key(wlc_handle view, uint32_t time, const struct wlc_modifiers
*modifiers, uint32_t key, uint32_t sym, enum wlc_key_state state) {
@@ -239,7 +271,8 @@ struct wlc_interface interface = {
.destroyed = handle_view_destroyed,
.focus = handle_view_focus,
.request = {
- .geometry = handle_view_geometry_request
+ .geometry = handle_view_geometry_request,
+ .state = handle_view_state_request
}
},
.keyboard = {
@@ -250,6 +283,6 @@ struct wlc_interface interface = {
.button = handle_pointer_button
},
.compositor = {
- .ready = handle_wlc_ready
+ .ready = handle_wlc_ready
}
};