diff options
author | Nicholas Marriott <nicm@cvs.openbsd.org> | 2009-09-15 15:14:10 +0000 |
---|---|---|
committer | Nicholas Marriott <nicm@cvs.openbsd.org> | 2009-09-15 15:14:10 +0000 |
commit | 553a033acd979a450a93109308fd265b2753b86d (patch) | |
tree | 4ae47ada2bfee5508bf6536935df9edd09499cf9 /usr.bin/tmux/grid.c | |
parent | 855d89da1259857648f3ba9af55c7a58a97e7231 (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 'usr.bin/tmux/grid.c')
-rw-r--r-- | usr.bin/tmux/grid.c | 26 |
1 files changed, 11 insertions, 15 deletions
diff --git a/usr.bin/tmux/grid.c b/usr.bin/tmux/grid.c index 25f6acb0f56..0e6b00797e9 100644 --- a/usr.bin/tmux/grid.c +++ b/usr.bin/tmux/grid.c @@ -1,4 +1,4 @@ -/* $OpenBSD: grid.c,v 1.13 2009/08/21 07:29:37 nicm Exp $ */ +/* $OpenBSD: grid.c,v 1.14 2009/09/15 15:14:09 nicm Exp $ */ /* * Copyright (c) 2008 Nicholas Marriott <nicm@users.sourceforge.net> @@ -189,22 +189,15 @@ grid_scroll_line(struct grid *gd) /* Expand line to fit to cell. */ void -grid_expand_line(struct grid *gd, u_int py, u_int wantx) +grid_expand_line(struct grid *gd, u_int py, u_int sx) { struct grid_line *gl; - u_int xx, sx; + u_int xx; gl = &gd->linedata[py]; - if (wantx <= gl->cellsize) + if (sx <= gl->cellsize) return; - if (gl->cellsize > gd->sx / 2) - sx = gd->sx; - else { - sx = gl->cellsize + 1; - while (sx < wantx) - sx *= 2; - } gl->celldata = xrealloc(gl->celldata, sx, sizeof *gl->celldata); for (xx = gl->cellsize; xx < sx; xx++) grid_put_cell(gd, xx, py, &grid_default_cell); @@ -307,10 +300,7 @@ grid_set_utf8( grid_put_utf8(gd, px, py, gc); } -/* - * Clear area. Note this is different from a fill as it just omits unallocated - * cells. - */ +/* Clear area. */ void grid_clear(struct grid *gd, u_int px, u_int py, u_int nx, u_int ny) { @@ -336,6 +326,12 @@ grid_clear(struct grid *gd, u_int px, u_int py, u_int nx, u_int ny) return; for (yy = py; yy < py + ny; yy++) { + if (px >= gd->linedata[yy].cellsize) + continue; + if (px + nx >= gd->linedata[yy].cellsize) { + gd->linedata[yy].cellsize = px; + continue; + } for (xx = px; xx < px + nx; xx++) { if (xx >= gd->linedata[yy].cellsize) break; |