summaryrefslogtreecommitdiffstats
path: root/screen-write.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2009-09-15 15:14:09 +0000
committerNicholas Marriott <nicm@openbsd.org>2009-09-15 15:14:09 +0000
commit427819910184a7174391c2e688da6b89634045ec (patch)
tree6a08b4939c09e170574c4a7065da3007ea37ac5b /screen-write.c
parentf39865e8e4aa1a8918c64cfc40fb0acc644861a4 (diff)
Stick line length to what is actually used (removing an optimization that
allowed it to be bigger), and use clear line/EOL sequences rather than spaces in copy/scroll mode. This fixes xterm copy/paste from tmux which treats trailing spaces differently from clearing a line with the escape sequences. Reported by martynas@.
Diffstat (limited to 'screen-write.c')
-rw-r--r--screen-write.c43
1 files changed, 30 insertions, 13 deletions
diff --git a/screen-write.c b/screen-write.c
index dba5f708..507c527b 100644
--- a/screen-write.c
+++ b/screen-write.c
@@ -371,25 +371,42 @@ screen_write_copy(struct screen_write_ctx *ctx,
struct grid_line *gl;
const struct grid_cell *gc;
u_char *udata;
- u_int xx, yy, cx, cy;
+ u_int xx, yy, cx, cy, ax, bx;
cx = s->cx;
cy = s->cy;
for (yy = py; yy < py + ny; yy++) {
gl = &gd->linedata[yy];
- for (xx = px; xx < px + nx; xx++) {
- udata = NULL;
-
- if (xx >= gl->cellsize || yy >= gd->hsize + gd->sy)
- gc = &grid_default_cell;
- else {
- gc = &gl->celldata[xx];
- if (gc->flags & GRID_FLAG_UTF8)
- udata = gl->utf8data[xx].data;
+ if (yy < gd->hsize + gd->sy) {
+ /*
+ * Find start and end position and copy between
+ * them. Limit to the real end of the line then use a
+ * clear EOL only if copying to the end, otherwise
+ * could overwrite whatever is there already.
+ */
+ if (px > gl->cellsize)
+ ax = gl->cellsize;
+ else
+ ax = px;
+ if (px + nx == gd->sx && px + nx > gl->cellsize)
+ bx = gl->cellsize;
+ else
+ bx = px + nx;
+ for (xx = ax; xx < bx; xx++) {
+ udata = NULL;
+ if (xx >= gl->cellsize)
+ gc = &grid_default_cell;
+ else {
+ gc = &gl->celldata[xx];
+ if (gc->flags & GRID_FLAG_UTF8)
+ udata = gl->utf8data[xx].data;
+ }
+ screen_write_cell(ctx, gc, udata);
}
-
- screen_write_cell(ctx, gc, udata);
- }
+ if (px + nx == gd->sx && px + nx > gl->cellsize)
+ screen_write_clearendofline(ctx);
+ } else
+ screen_write_clearline(ctx);
cy++;
screen_write_cursormove(ctx, cx, cy);
}