diff options
author | Nicholas Marriott <nicholas.marriott@gmail.com> | 2009-07-09 18:04:53 +0000 |
---|---|---|
committer | Nicholas Marriott <nicholas.marriott@gmail.com> | 2009-07-09 18:04:53 +0000 |
commit | 295879cced7fc430c751b6d3b2c9d7d253cb0dc0 (patch) | |
tree | ffaa2bbbf57c045631e0fd891b042170f941432c | |
parent | e073441c36b4cc22e0a750f4d3e539c41893a65d (diff) | |
download | rtmux-295879cced7fc430c751b6d3b2c9d7d253cb0dc0.tar.gz rtmux-295879cced7fc430c751b6d3b2c9d7d253cb0dc0.tar.bz2 rtmux-295879cced7fc430c751b6d3b2c9d7d253cb0dc0.zip |
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.
-rw-r--r-- | grid-view.c | 16 | ||||
-rw-r--r-- | screen-write.c | 40 |
2 files changed, 46 insertions, 10 deletions
diff --git a/grid-view.c b/grid-view.c index 9ec9772d..705918ac 100644 --- a/grid-view.c +++ b/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. */ diff --git a/screen-write.c b/screen-write.c index 2e71c738..9f37561f 100644 --- a/screen-write.c +++ b/screen-write.c @@ -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 (ny == 0) + 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; |