mirror of
				https://gitlab.freedesktop.org/wayland/wayland.git
				synced 2025-11-03 09:01:42 -05:00 
			
		
		
		
	terminal: Window size ioctls
Use TIOCSWINSZ ioctl to set window size on terminal resize. This causes applications to be notified of the resize event. Signed-off-by: Callum Lowcay <callum@callumscode.com>
This commit is contained in:
		
							parent
							
								
									30eeae55e0
								
							
						
					
					
						commit
						a0ee21c7dc
					
				
					 1 changed files with 19 additions and 8 deletions
				
			
		| 
						 | 
					@ -268,6 +268,8 @@ terminal_resize(struct terminal *terminal, int width, int height)
 | 
				
			||||||
	struct attr *data_attr;
 | 
						struct attr *data_attr;
 | 
				
			||||||
	int data_pitch, attr_pitch;
 | 
						int data_pitch, attr_pitch;
 | 
				
			||||||
	int i, l, total_rows, start;
 | 
						int i, l, total_rows, start;
 | 
				
			||||||
 | 
						struct rectangle rectangle;
 | 
				
			||||||
 | 
						struct winsize ws;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (terminal->width == width && terminal->height == height)
 | 
						if (terminal->width == width && terminal->height == height)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
| 
						 | 
					@ -318,6 +320,22 @@ terminal_resize(struct terminal *terminal, int width, int height)
 | 
				
			||||||
	if (terminal->column >= terminal->width)
 | 
						if (terminal->column >= terminal->width)
 | 
				
			||||||
		terminal->column = terminal->width - 1;
 | 
							terminal->column = terminal->width - 1;
 | 
				
			||||||
	terminal->start = 0;
 | 
						terminal->start = 0;
 | 
				
			||||||
 | 
						
 | 
				
			||||||
 | 
						if (!terminal->fullscreen) {
 | 
				
			||||||
 | 
							rectangle.width = terminal->width *
 | 
				
			||||||
 | 
								terminal->extents.max_x_advance + 2 * terminal->margin;
 | 
				
			||||||
 | 
							rectangle.height = terminal->height *
 | 
				
			||||||
 | 
								terminal->extents.height + 2 * terminal->margin;
 | 
				
			||||||
 | 
							window_set_child_size(terminal->window, &rectangle);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* Update the window size */
 | 
				
			||||||
 | 
						ws.ws_row = terminal->height;
 | 
				
			||||||
 | 
						ws.ws_col = terminal->width;
 | 
				
			||||||
 | 
						window_get_child_rectangle(terminal->window, &rectangle);
 | 
				
			||||||
 | 
						ws.ws_xpixel = rectangle.width;
 | 
				
			||||||
 | 
						ws.ws_ypixel = rectangle.height;
 | 
				
			||||||
 | 
						ioctl(terminal->master, TIOCSWINSZ, &ws);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct color_scheme DEFAULT_COLORS = {
 | 
					struct color_scheme DEFAULT_COLORS = {
 | 
				
			||||||
| 
						 | 
					@ -480,14 +498,6 @@ terminal_draw(struct terminal *terminal)
 | 
				
			||||||
		(int32_t) terminal->extents.height;
 | 
							(int32_t) terminal->extents.height;
 | 
				
			||||||
	terminal_resize(terminal, width, height);
 | 
						terminal_resize(terminal, width, height);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (!terminal->fullscreen) {
 | 
					 | 
				
			||||||
		rectangle.width = terminal->width *
 | 
					 | 
				
			||||||
			terminal->extents.max_x_advance + 2 * terminal->margin;
 | 
					 | 
				
			||||||
		rectangle.height = terminal->height *
 | 
					 | 
				
			||||||
			terminal->extents.height + 2 * terminal->margin;
 | 
					 | 
				
			||||||
		window_set_child_size(terminal->window, &rectangle);
 | 
					 | 
				
			||||||
	}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	window_draw(terminal->window);
 | 
						window_draw(terminal->window);
 | 
				
			||||||
	terminal_draw_contents(terminal);
 | 
						terminal_draw_contents(terminal);
 | 
				
			||||||
	window_flush(terminal->window);
 | 
						window_flush(terminal->window);
 | 
				
			||||||
| 
						 | 
					@ -893,6 +903,7 @@ terminal_create(struct display *display, int fullscreen)
 | 
				
			||||||
	cairo_destroy(cr);
 | 
						cairo_destroy(cr);
 | 
				
			||||||
	cairo_surface_destroy(surface);
 | 
						cairo_surface_destroy(surface);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						terminal_resize(terminal, 80, 24);
 | 
				
			||||||
	terminal_draw(terminal);
 | 
						terminal_draw(terminal);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	return terminal;
 | 
						return terminal;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue