mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 00:56:10 +00:00 
			
		
		
		
	Change inserting and deleting lines inside the scroll region to properly clear
lines that should be inserted/deleted but not moved. Fixes problems with mutt reported by Brian Lewis, thanks.
This commit is contained in:
		
							
								
								
									
										16
									
								
								grid-view.c
									
									
									
									
									
								
							
							
						
						
									
										16
									
								
								grid-view.c
									
									
									
									
									
								
							@@ -1,4 +1,4 @@
 | 
			
		||||
/* $Id: grid-view.c,v 1.16 2009-07-09 18:04:17 nicm Exp $ */
 | 
			
		||||
/* $Id: grid-view.c,v 1.17 2009-07-09 18:04:53 nicm Exp $ */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
@@ -134,13 +134,17 @@ grid_view_insert_lines(struct grid *gd, u_int py, u_int ny)
 | 
			
		||||
void
 | 
			
		||||
grid_view_insert_lines_region(struct grid *gd, u_int rlower, u_int py, u_int ny)
 | 
			
		||||
{
 | 
			
		||||
	u_int	ny2;
 | 
			
		||||
 | 
			
		||||
	GRID_DEBUG(gd, "rlower=%u, py=%u, ny=%u", rlower, py, ny);
 | 
			
		||||
 | 
			
		||||
	rlower = grid_view_y(gd, rlower);
 | 
			
		||||
 | 
			
		||||
	py = grid_view_y(gd, py);
 | 
			
		||||
 | 
			
		||||
	grid_move_lines(gd, py + ny, py, (rlower + 1) - py - ny);
 | 
			
		||||
	ny2 = rlower + 1 - py - ny;
 | 
			
		||||
	grid_move_lines(gd, rlower + 1 - ny2, py, ny2);
 | 
			
		||||
 	grid_clear(gd, 0, py + ny2, gd->sx, ny - ny2);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Delete lines. */
 | 
			
		||||
@@ -156,20 +160,24 @@ grid_view_delete_lines(struct grid *gd, u_int py, u_int ny)
 | 
			
		||||
	sy = grid_view_y(gd, gd->sy);
 | 
			
		||||
 | 
			
		||||
	grid_move_lines(gd, py, py + ny, sy - py - ny);
 | 
			
		||||
	grid_clear(gd, 0, sy - ny, gd->sx, py + ny - (sy - ny));
 | 
			
		||||
 	grid_clear(gd, 0, sy - ny, gd->sx, py + ny - (sy - ny));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Delete lines inside scroll region. */
 | 
			
		||||
void
 | 
			
		||||
grid_view_delete_lines_region(struct grid *gd, u_int rlower, u_int py, u_int ny)
 | 
			
		||||
{
 | 
			
		||||
	u_int	ny2;
 | 
			
		||||
 | 
			
		||||
	GRID_DEBUG(gd, "rlower=%u, py=%u, ny=%u", rlower, py, ny);
 | 
			
		||||
 | 
			
		||||
	rlower = grid_view_y(gd, rlower);
 | 
			
		||||
 | 
			
		||||
	py = grid_view_y(gd, py);
 | 
			
		||||
 | 
			
		||||
	grid_move_lines(gd, py, py + ny, (rlower + 1) - py - ny);
 | 
			
		||||
	ny2 = rlower + 1 - py - ny;
 | 
			
		||||
	grid_move_lines(gd, py, py + ny, ny2);
 | 
			
		||||
 	grid_clear(gd, 0, py + ny2, gd->sx, ny - ny2);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Insert characters. */
 | 
			
		||||
 
 | 
			
		||||
@@ -1,4 +1,4 @@
 | 
			
		||||
/* $Id: screen-write.c,v 1.57 2009-07-09 18:04:17 nicm Exp $ */
 | 
			
		||||
/* $Id: screen-write.c,v 1.58 2009-07-09 18:04:53 nicm Exp $ */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
 | 
			
		||||
@@ -369,11 +369,25 @@ screen_write_insertline(struct screen_write_ctx *ctx, u_int ny)
 | 
			
		||||
	if (ny == 0)
 | 
			
		||||
		ny = 1;
 | 
			
		||||
 | 
			
		||||
	if (ny > screen_size_y(s) - s->cy)
 | 
			
		||||
		ny = screen_size_y(s) - s->cy;
 | 
			
		||||
	if (s->cy < s->rupper || s->cy > s->rlower) {
 | 
			
		||||
		if (ny > screen_size_y(s) - s->cy)
 | 
			
		||||
			ny = screen_size_y(s) - s->cy;
 | 
			
		||||
		if (ny == 0)
 | 
			
		||||
			return;
 | 
			
		||||
 | 
			
		||||
		screen_write_save(ctx);
 | 
			
		||||
 | 
			
		||||
		grid_view_insert_lines(s->grid, s->cy, ny);
 | 
			
		||||
 | 
			
		||||
		tty_write_cmd(ctx->wp, TTY_INSERTLINE, ny);
 | 
			
		||||
		return;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if (ny > s->rlower + 1 - s->cy)
 | 
			
		||||
		ny = s->rlower + 1 - s->cy;
 | 
			
		||||
	if (ny == 0)
 | 
			
		||||
		return;
 | 
			
		||||
 | 
			
		||||
	
 | 
			
		||||
	screen_write_save(ctx);
 | 
			
		||||
 | 
			
		||||
	if (s->cy < s->rupper || s->cy > s->rlower)
 | 
			
		||||
@@ -393,8 +407,22 @@ screen_write_deleteline(struct screen_write_ctx *ctx, u_int ny)
 | 
			
		||||
	if (ny == 0)
 | 
			
		||||
		ny = 1;
 | 
			
		||||
 | 
			
		||||
	if (ny > screen_size_y(s) - s->cy)
 | 
			
		||||
		ny = screen_size_y(s) - s->cy;
 | 
			
		||||
	if (s->cy < s->rupper || s->cy > s->rlower) {
 | 
			
		||||
		if (ny > screen_size_y(s) - s->cy)
 | 
			
		||||
			ny = screen_size_y(s) - s->cy;
 | 
			
		||||
		if (ny == 0)
 | 
			
		||||
			return;
 | 
			
		||||
 | 
			
		||||
		screen_write_save(ctx);
 | 
			
		||||
 | 
			
		||||
		grid_view_delete_lines(s->grid, s->cy, ny);
 | 
			
		||||
 | 
			
		||||
		tty_write_cmd(ctx->wp, TTY_DELETELINE, ny);
 | 
			
		||||
		return;
 | 
			
		||||
	}
 | 
			
		||||
	
 | 
			
		||||
	if (ny > s->rlower + 1 - s->cy)
 | 
			
		||||
		ny = s->rlower + 1 - s->cy;
 | 
			
		||||
	if (ny == 0)
 | 
			
		||||
		return;
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user