mirror of
				https://github.com/tmux/tmux.git
				synced 2025-10-26 12:27:15 +00:00 
			
		
		
		
	Move lines into the history when scrolling even if the scroll region is not
the entire screen. Allows ircII users to see history, prompted by naddy.
This commit is contained in:
		
							
								
								
									
										21
									
								
								grid-view.c
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								grid-view.c
									
									
									
									
									
								
							| @@ -92,15 +92,20 @@ grid_view_scroll_region_up(struct grid *gd, u_int rupper, u_int rlower) | |||||||
| { | { | ||||||
| 	GRID_DEBUG(gd, "rupper=%u, rlower=%u", rupper, rlower); | 	GRID_DEBUG(gd, "rupper=%u, rlower=%u", rupper, rlower); | ||||||
|  |  | ||||||
| 	if (gd->flags & GRID_HISTORY && rupper == 0 && rlower == gd->sy - 1) { | 	if (gd->flags & GRID_HISTORY) { | ||||||
| 		grid_scroll_line(gd); | 		grid_collect_history(gd); | ||||||
| 		return; | 		if (rupper == 0 && rlower == gd->sy - 1) | ||||||
|  | 			grid_scroll_history(gd); | ||||||
|  | 		else { | ||||||
|  | 			rupper = grid_view_y(gd, rupper); | ||||||
|  | 			rlower = grid_view_y(gd, rlower); | ||||||
|  | 			grid_scroll_history_region(gd, rupper, rlower); | ||||||
|  | 		} | ||||||
|  | 	} else { | ||||||
|  | 		rupper = grid_view_y(gd, rupper); | ||||||
|  | 		rlower = grid_view_y(gd, rlower); | ||||||
|  | 		grid_move_lines(gd, rupper, rupper + 1, rlower - rupper); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	rupper = grid_view_y(gd, rupper); |  | ||||||
| 	rlower = grid_view_y(gd, rlower); |  | ||||||
|  |  | ||||||
| 	grid_move_lines(gd, rupper, rupper + 1, rlower - rupper); |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Scroll region down. */ | /* Scroll region down. */ | ||||||
|   | |||||||
							
								
								
									
										70
									
								
								grid.c
									
									
									
									
									
								
							
							
						
						
									
										70
									
								
								grid.c
									
									
									
									
									
								
							| @@ -161,29 +161,77 @@ grid_compare(struct grid *ga, struct grid *gb) | |||||||
| 	return (0); | 	return (0); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* Scroll a line into the history. */ | /* | ||||||
|  |  * Collect lines from the history if at the limit. Free the top (oldest) 10% | ||||||
|  |  * and shift up. | ||||||
|  |  */ | ||||||
| void | void | ||||||
| grid_scroll_line(struct grid *gd) | grid_collect_history(struct grid *gd) | ||||||
| { | { | ||||||
| 	u_int	yy; | 	u_int	yy; | ||||||
|  |  | ||||||
|  	GRID_DEBUG(gd, ""); |  	GRID_DEBUG(gd, ""); | ||||||
|  |  | ||||||
| 	if (gd->hsize >= gd->hlimit) { | 	if (gd->hsize < gd->hlimit) | ||||||
| 		/* If the limit is hit, free the bottom 10% and shift up. */ | 		return; | ||||||
| 		yy = gd->hlimit / 10; |  | ||||||
| 		if (yy < 1) |  | ||||||
| 			yy = 1; |  | ||||||
|  |  | ||||||
| 		grid_move_lines(gd, 0, yy, gd->hsize + gd->sy - yy); | 	yy = gd->hlimit / 10; | ||||||
| 		gd->hsize -= yy; | 	if (yy < 1) | ||||||
| 	} | 		yy = 1; | ||||||
|  |  | ||||||
|  | 	grid_move_lines(gd, 0, yy, gd->hsize + gd->sy - yy); | ||||||
|  | 	gd->hsize -= yy; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /*  | ||||||
|  |  * Scroll the entire visible screen, moving one line into the history. Just | ||||||
|  |  * allocate a new line at the bottom and move the history size indicator. | ||||||
|  |  */ | ||||||
|  | void | ||||||
|  | grid_scroll_history(struct grid *gd) | ||||||
|  | { | ||||||
|  | 	u_int	yy; | ||||||
|  |  | ||||||
|  |  	GRID_DEBUG(gd, ""); | ||||||
|  |  | ||||||
| 	yy = gd->hsize + gd->sy; | 	yy = gd->hsize + gd->sy; | ||||||
|  |  | ||||||
| 	gd->linedata = xrealloc(gd->linedata, yy + 1, sizeof *gd->linedata); | 	gd->linedata = xrealloc(gd->linedata, yy + 1, sizeof *gd->linedata); | ||||||
| 	memset(&gd->linedata[yy], 0, sizeof gd->linedata[yy]); | 	memset(&gd->linedata[yy], 0, sizeof gd->linedata[yy]); | ||||||
|  | 	 | ||||||
|  | 	gd->hsize++; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* Scroll a region up, moving the top line into the history. */ | ||||||
|  | void | ||||||
|  | grid_scroll_history_region(struct grid *gd, u_int upper, u_int lower) | ||||||
|  | { | ||||||
|  | 	struct grid_line	*gl_history, *gl_upper, *gl_lower; | ||||||
|  | 	u_int			 yy; | ||||||
|  |  | ||||||
|  |  	GRID_DEBUG(gd, "upper=%u, lower=%u", upper, lower); | ||||||
|  |  | ||||||
|  | 	/* Create a space for a new line. */ | ||||||
|  | 	yy = gd->hsize + gd->sy; | ||||||
|  | 	gd->linedata = xrealloc(gd->linedata, yy + 1, sizeof *gd->linedata); | ||||||
|  |  | ||||||
|  | 	/* Move the entire screen down to free a space for this line. */ | ||||||
|  | 	gl_history = &gd->linedata[gd->hsize]; | ||||||
|  | 	memmove(gl_history + 1, gl_history, gd->sy * sizeof *gl_history); | ||||||
|  |  | ||||||
|  | 	/* Adjust the region and find its start and end. */ | ||||||
|  | 	upper++; | ||||||
|  | 	gl_upper = &gd->linedata[upper]; | ||||||
|  | 	lower++; | ||||||
|  | 	gl_lower = &gd->linedata[lower]; | ||||||
|  |  | ||||||
|  | 	/* Move the line into the history. */ | ||||||
|  | 	memcpy(gl_history, gl_upper, sizeof *gl_history); | ||||||
|  |  | ||||||
|  | 	/* Then move the region up and clear the bottom line. */ | ||||||
|  | 	memmove(gl_upper, gl_upper + 1, (lower - upper) * sizeof *gl_upper); | ||||||
|  | 	memset(gl_lower, 0, sizeof *gl_lower); | ||||||
|  |  | ||||||
|  | 	/* Move the history offset down over the line. */ | ||||||
| 	gd->hsize++; | 	gd->hsize++; | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								tmux.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								tmux.h
									
									
									
									
									
								
							| @@ -1592,9 +1592,11 @@ extern const struct grid_cell grid_default_cell; | |||||||
| struct grid *grid_create(u_int, u_int, u_int); | struct grid *grid_create(u_int, u_int, u_int); | ||||||
| void	 grid_destroy(struct grid *); | void	 grid_destroy(struct grid *); | ||||||
| int	 grid_compare(struct grid *, struct grid *); | int	 grid_compare(struct grid *, struct grid *); | ||||||
|  | void	 grid_collect_history(struct grid *); | ||||||
|  | void	 grid_scroll_history(struct grid *); | ||||||
|  | void	 grid_scroll_history_region(struct grid *, u_int, u_int); | ||||||
| void	 grid_expand_line(struct grid *, u_int, u_int); | void	 grid_expand_line(struct grid *, u_int, u_int); | ||||||
| void	 grid_expand_line_utf8(struct grid *, u_int, u_int); | void	 grid_expand_line_utf8(struct grid *, u_int, u_int); | ||||||
| void	 grid_scroll_line(struct grid *); |  | ||||||
| const struct grid_cell *grid_peek_cell(struct grid *, u_int, u_int); | const struct grid_cell *grid_peek_cell(struct grid *, u_int, u_int); | ||||||
| struct grid_cell *grid_get_cell(struct grid *, u_int, u_int); | struct grid_cell *grid_get_cell(struct grid *, u_int, u_int); | ||||||
| void	 grid_set_cell(struct grid *, u_int, u_int, const struct grid_cell *); | void	 grid_set_cell(struct grid *, u_int, u_int, const struct grid_cell *); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Nicholas Marriott
					Nicholas Marriott