aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-08-06 08:11:06 -0400
committerGitHub <noreply@github.com>2018-08-06 08:11:06 -0400
commit28b0a4065b8d37b5301fb75377f1859b1b08af0b (patch)
tree3b51cc558ee9e86699e3b7282592b3ae5e652a48
parent84e87be6df2e43992d5608eb29966d7e0baef4f7 (diff)
parent9d0e37f768f49211eddfeba1abd35c1a2ccaa843 (diff)
Merge pull request #1179 from emersion/rootston-toggle-decoration-mode
rootston: add keybinding to toggle decoration mode
-rw-r--r--include/rootston/view.h4
-rw-r--r--rootston/keyboard.c15
-rw-r--r--rootston/xdg_shell.c2
3 files changed, 21 insertions, 0 deletions
diff --git a/include/rootston/view.h b/include/rootston/view.h
index 69cbc87c..14448fc6 100644
--- a/include/rootston/view.h
+++ b/include/rootston/view.h
@@ -39,6 +39,8 @@ struct roots_xdg_surface_v6 {
uint32_t pending_move_resize_configure_serial;
};
+struct roots_xdg_toplevel_decoration;
+
struct roots_xdg_surface {
struct roots_view *view;
@@ -54,6 +56,8 @@ struct roots_xdg_surface {
struct wl_listener surface_commit;
uint32_t pending_move_resize_configure_serial;
+
+ struct roots_xdg_toplevel_decoration *xdg_toplevel_decoration;
};
struct roots_xwayland_surface {
diff --git a/rootston/keyboard.c b/rootston/keyboard.c
index 6697ca83..40d4a7c7 100644
--- a/rootston/keyboard.c
+++ b/rootston/keyboard.c
@@ -133,6 +133,21 @@ static void keyboard_binding_execute(struct roots_keyboard *keyboard,
wl_list_for_each(output, &keyboard->input->server->desktop->outputs, link) {
wlr_output_enable(output->wlr_output, outputs_enabled);
}
+ } else if (strcmp(command, "toggle_decoration_mode") == 0) {
+ struct roots_view *focus = roots_seat_get_focus(seat);
+ if (focus != NULL && focus->type == ROOTS_XDG_SHELL_VIEW) {
+ struct roots_xdg_toplevel_decoration *decoration =
+ focus->roots_xdg_surface->xdg_toplevel_decoration;
+ if (decoration != NULL) {
+ enum wlr_xdg_toplevel_decoration_v1_mode mode =
+ decoration->wlr_decoration->current_mode;
+ mode = mode == WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE
+ ? WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_CLIENT_SIDE
+ : WLR_XDG_TOPLEVEL_DECORATION_V1_MODE_SERVER_SIDE;
+ wlr_xdg_toplevel_decoration_v1_set_mode(
+ decoration->wlr_decoration, mode);
+ }
+ }
} else {
wlr_log(WLR_ERROR, "unknown binding command: %s", command);
}
diff --git a/rootston/xdg_shell.c b/rootston/xdg_shell.c
index e5ab9efd..fed9afcd 100644
--- a/rootston/xdg_shell.c
+++ b/rootston/xdg_shell.c
@@ -475,6 +475,7 @@ static void decoration_handle_destroy(struct wl_listener *listener,
struct roots_xdg_toplevel_decoration *decoration =
wl_container_of(listener, decoration, destroy);
+ decoration->surface->xdg_toplevel_decoration = NULL;
view_update_decorated(decoration->surface->view, false);
wl_list_remove(&decoration->destroy.link);
wl_list_remove(&decoration->request_mode.link);
@@ -523,6 +524,7 @@ void handle_xdg_toplevel_decoration(struct wl_listener *listener, void *data) {
}
decoration->wlr_decoration = wlr_decoration;
decoration->surface = xdg_surface;
+ xdg_surface->xdg_toplevel_decoration = decoration;
decoration->destroy.notify = decoration_handle_destroy;
wl_signal_add(&wlr_decoration->events.destroy, &decoration->destroy);