diff options
author | nicm <nicm> | 2020-06-04 21:41:31 +0000 |
---|---|---|
committer | nicm <nicm> | 2020-06-04 21:41:31 +0000 |
commit | d9cd493d093f14b934343a2e57998c86fbca2ef7 (patch) | |
tree | f28c1c9ad8dc6a5ed440a6fb64bcbcc91db4747e /grid.c | |
parent | 2154e1f4fbc01a43934b892ca3e6d6ea5bf003a1 (diff) | |
download | rtmux-d9cd493d093f14b934343a2e57998c86fbca2ef7.tar.gz rtmux-d9cd493d093f14b934343a2e57998c86fbca2ef7.tar.bz2 rtmux-d9cd493d093f14b934343a2e57998c86fbca2ef7.zip |
Reset wrapped flag when clearing or moving lines, GitHub issue 2215.
Diffstat (limited to 'grid.c')
-rw-r--r-- | grid.c | 7 |
1 files changed, 7 insertions, 0 deletions
@@ -649,6 +649,8 @@ grid_clear_lines(struct grid *gd, u_int py, u_int ny, u_int bg) grid_free_line(gd, yy); grid_empty_line(gd, yy, bg); } + if (py != 0) + gd->linedata[py - 1].flags &= ~GRID_LINE_WRAPPED; } /* Move a group of lines. */ @@ -675,6 +677,8 @@ grid_move_lines(struct grid *gd, u_int dy, u_int py, u_int ny, u_int bg) continue; grid_free_line(gd, yy); } + if (dy != 0) + gd->linedata[dy - 1].flags &= ~GRID_LINE_WRAPPED; memmove(&gd->linedata[dy], &gd->linedata[py], ny * (sizeof *gd->linedata)); @@ -687,8 +691,11 @@ grid_move_lines(struct grid *gd, u_int dy, u_int py, u_int ny, u_int bg) if (yy < dy || yy >= dy + ny) grid_empty_line(gd, yy, bg); } + if (py != 0 && (py < dy || py >= dy + ny)) + gd->linedata[py - 1].flags &= ~GRID_LINE_WRAPPED; } + /* Move a group of cells. */ void grid_move_cells(struct grid *gd, u_int dx, u_int px, u_int py, u_int nx, |