mirror of
				https://gitlab.freedesktop.org/wlroots/wlroots.git
				synced 2025-11-03 09:01:40 -05:00 
			
		
		
		
	rootston: add keybinding to toggle decoration mode
This commit is contained in:
		
							parent
							
								
									eb9c9d8852
								
							
						
					
					
						commit
						9d0e37f768
					
				
					 3 changed files with 21 additions and 0 deletions
				
			
		| 
						 | 
					@ -39,6 +39,8 @@ struct roots_xdg_surface_v6 {
 | 
				
			||||||
	uint32_t pending_move_resize_configure_serial;
 | 
						uint32_t pending_move_resize_configure_serial;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					struct roots_xdg_toplevel_decoration;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct roots_xdg_surface {
 | 
					struct roots_xdg_surface {
 | 
				
			||||||
	struct roots_view *view;
 | 
						struct roots_view *view;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -54,6 +56,8 @@ struct roots_xdg_surface {
 | 
				
			||||||
	struct wl_listener surface_commit;
 | 
						struct wl_listener surface_commit;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	uint32_t pending_move_resize_configure_serial;
 | 
						uint32_t pending_move_resize_configure_serial;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						struct roots_xdg_toplevel_decoration *xdg_toplevel_decoration;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct roots_xwayland_surface {
 | 
					struct roots_xwayland_surface {
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -133,6 +133,21 @@ static void keyboard_binding_execute(struct roots_keyboard *keyboard,
 | 
				
			||||||
		wl_list_for_each(output, &keyboard->input->server->desktop->outputs, link) {
 | 
							wl_list_for_each(output, &keyboard->input->server->desktop->outputs, link) {
 | 
				
			||||||
			wlr_output_enable(output->wlr_output, outputs_enabled);
 | 
								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 {
 | 
						} else {
 | 
				
			||||||
		wlr_log(WLR_ERROR, "unknown binding command: %s", command);
 | 
							wlr_log(WLR_ERROR, "unknown binding command: %s", command);
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -475,6 +475,7 @@ static void decoration_handle_destroy(struct wl_listener *listener,
 | 
				
			||||||
	struct roots_xdg_toplevel_decoration *decoration =
 | 
						struct roots_xdg_toplevel_decoration *decoration =
 | 
				
			||||||
		wl_container_of(listener, decoration, destroy);
 | 
							wl_container_of(listener, decoration, destroy);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						decoration->surface->xdg_toplevel_decoration = NULL;
 | 
				
			||||||
	view_update_decorated(decoration->surface->view, false);
 | 
						view_update_decorated(decoration->surface->view, false);
 | 
				
			||||||
	wl_list_remove(&decoration->destroy.link);
 | 
						wl_list_remove(&decoration->destroy.link);
 | 
				
			||||||
	wl_list_remove(&decoration->request_mode.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->wlr_decoration = wlr_decoration;
 | 
				
			||||||
	decoration->surface = xdg_surface;
 | 
						decoration->surface = xdg_surface;
 | 
				
			||||||
 | 
						xdg_surface->xdg_toplevel_decoration = decoration;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	decoration->destroy.notify = decoration_handle_destroy;
 | 
						decoration->destroy.notify = decoration_handle_destroy;
 | 
				
			||||||
	wl_signal_add(&wlr_decoration->events.destroy, &decoration->destroy);
 | 
						wl_signal_add(&wlr_decoration->events.destroy, &decoration->destroy);
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue