mirror of
https://github.com/tmux/tmux.git
synced 2025-01-05 23:38:48 +00:00
Do not force line width to grid width because it may need to be larger
to accomodate a wide character. GitHub issue 2336.
This commit is contained in:
parent
df7fbcd7a5
commit
212c0c1f72
21
grid.c
21
grid.c
@ -463,7 +463,7 @@ grid_expand_line(struct grid *gd, u_int py, u_int sx, u_int bg)
|
|||||||
sx = gd->sx / 4;
|
sx = gd->sx / 4;
|
||||||
else if (sx < gd->sx / 2)
|
else if (sx < gd->sx / 2)
|
||||||
sx = gd->sx / 2;
|
sx = gd->sx / 2;
|
||||||
else
|
else if (gd->sx > sx)
|
||||||
sx = gd->sx;
|
sx = gd->sx;
|
||||||
|
|
||||||
gl->celldata = xreallocarray(gl->celldata, sx, sizeof *gl->celldata);
|
gl->celldata = xreallocarray(gl->celldata, sx, sizeof *gl->celldata);
|
||||||
@ -1277,7 +1277,7 @@ grid_reflow(struct grid *gd, u_int sx)
|
|||||||
struct grid *target;
|
struct grid *target;
|
||||||
struct grid_line *gl;
|
struct grid_line *gl;
|
||||||
struct grid_cell gc;
|
struct grid_cell gc;
|
||||||
u_int yy, width, i, at, first;
|
u_int yy, width, i, at;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a destination grid. This is just used as a container for the
|
* Create a destination grid. This is just used as a container for the
|
||||||
@ -1294,13 +1294,12 @@ grid_reflow(struct grid *gd, u_int sx)
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Work out the width of this line. first is the width of the
|
* Work out the width of this line. at is the point at which
|
||||||
* first character, at is the point at which the available
|
* the available width is hit, and width is the full line
|
||||||
* width is hit, and width is the full line width.
|
* width.
|
||||||
*/
|
*/
|
||||||
first = at = width = 0;
|
at = width = 0;
|
||||||
if (~gl->flags & GRID_LINE_EXTENDED) {
|
if (~gl->flags & GRID_LINE_EXTENDED) {
|
||||||
first = 1;
|
|
||||||
width = gl->cellused;
|
width = gl->cellused;
|
||||||
if (width > sx)
|
if (width > sx)
|
||||||
at = sx;
|
at = sx;
|
||||||
@ -1309,8 +1308,6 @@ grid_reflow(struct grid *gd, u_int sx)
|
|||||||
} else {
|
} else {
|
||||||
for (i = 0; i < gl->cellused; i++) {
|
for (i = 0; i < gl->cellused; i++) {
|
||||||
grid_get_cell1(gl, i, &gc);
|
grid_get_cell1(gl, i, &gc);
|
||||||
if (i == 0)
|
|
||||||
first = gc.data.width;
|
|
||||||
if (at == 0 && width + gc.data.width > sx)
|
if (at == 0 && width + gc.data.width > sx)
|
||||||
at = i;
|
at = i;
|
||||||
width += gc.data.width;
|
width += gc.data.width;
|
||||||
@ -1318,10 +1315,10 @@ grid_reflow(struct grid *gd, u_int sx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If the line is exactly right or the first character is wider
|
* If the line is exactly right, just move it across
|
||||||
* than the target width, just move it across unchanged.
|
* unchanged.
|
||||||
*/
|
*/
|
||||||
if (width == sx || first > sx) {
|
if (width == sx) {
|
||||||
grid_reflow_move(target, gl);
|
grid_reflow_move(target, gl);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user