tty_clamp_* need to use wp->xoff and wp->yoff for the check (which

don't include status line, line ox and oy), but ctx->xoff and yp->off
to calculate the position (which do have the statu line).
This commit is contained in:
Nicholas Marriott 2018-08-26 14:10:39 +01:00
parent d64daf874f
commit 79a9472dbc

30
tty.c
View File

@ -910,7 +910,8 @@ static int
tty_clamp_line(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py, tty_clamp_line(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
u_int nx, u_int *i, u_int *x, u_int *rx, u_int *ry) u_int nx, u_int *i, u_int *x, u_int *rx, u_int *ry)
{ {
u_int xoff = ctx->xoff + px; struct window_pane *wp = ctx->wp;
u_int xoff = wp->xoff + px;
if (!tty_is_visible(tty, ctx, px, py, nx, 1)) if (!tty_is_visible(tty, ctx, px, py, nx, 1))
return (0); return (0);
@ -919,7 +920,7 @@ tty_clamp_line(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) { if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) {
/* All visible. */ /* All visible. */
*i = 0; *i = 0;
*x = xoff - ctx->ox; *x = ctx->xoff + px - ctx->ox;
*rx = nx; *rx = nx;
} else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) { } else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) {
/* Both left and right not visible. */ /* Both left and right not visible. */
@ -928,14 +929,14 @@ tty_clamp_line(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
*rx = ctx->sx; *rx = ctx->sx;
} else if (xoff < ctx->ox) { } else if (xoff < ctx->ox) {
/* Left not visible. */ /* Left not visible. */
*i = ctx->ox - xoff; *i = ctx->ox - (ctx->xoff + px);
*x = 0; *x = 0;
*rx = nx - *i; *rx = nx - *i;
} else { } else {
/* Right not visible. */ /* Right not visible. */
*i = 0; *i = 0;
*x = xoff - ctx->ox; *x = (ctx->xoff + px) - ctx->ox;
*rx = nx - (xoff + nx - ctx->sx); *rx = nx - ((ctx->xoff + px) + nx - ctx->sx);
} }
return (1); return (1);
} }
@ -1002,7 +1003,8 @@ tty_clamp_area(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
u_int nx, u_int ny, u_int *i, u_int *j, u_int *x, u_int *y, u_int *rx, u_int nx, u_int ny, u_int *i, u_int *j, u_int *x, u_int *y, u_int *rx,
u_int *ry) u_int *ry)
{ {
u_int xoff = ctx->xoff + px, yoff = ctx->yoff + py; struct window_pane *wp = ctx->wp;
u_int xoff = wp->xoff + px, yoff = wp->yoff + py;
if (!tty_is_visible(tty, ctx, px, py, nx, ny)) if (!tty_is_visible(tty, ctx, px, py, nx, ny))
return (0); return (0);
@ -1010,7 +1012,7 @@ tty_clamp_area(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) { if (xoff >= ctx->ox && xoff + nx <= ctx->ox + ctx->sx) {
/* All visible. */ /* All visible. */
*i = 0; *i = 0;
*x = xoff - ctx->ox; *x = ctx->xoff + px - ctx->ox;
*rx = nx; *rx = nx;
} else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) { } else if (xoff < ctx->ox && xoff + nx > ctx->ox + ctx->sx) {
/* Both left and right not visible. */ /* Both left and right not visible. */
@ -1019,19 +1021,19 @@ tty_clamp_area(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
*rx = ctx->sx; *rx = ctx->sx;
} else if (xoff < ctx->ox) { } else if (xoff < ctx->ox) {
/* Left not visible. */ /* Left not visible. */
*i = ctx->ox - xoff; *i = ctx->ox - (ctx->xoff + px);
*x = 0; *x = 0;
*rx = nx - *i; *rx = nx - *i;
} else { } else {
/* Right not visible. */ /* Right not visible. */
*i = 0; *i = 0;
*x = xoff - ctx->ox; *x = (ctx->xoff + px) - ctx->ox;
*rx = nx - (xoff + nx - ctx->sx); *rx = nx - ((ctx->xoff + px) + nx - ctx->sx);
} }
if (yoff >= ctx->oy && yoff + ny <= ctx->oy + ctx->sy) { if (yoff >= ctx->oy && yoff + ny <= ctx->oy + ctx->sy) {
/* All visible. */ /* All visible. */
*j = 0; *j = 0;
*y = yoff - ctx->oy; *y = ctx->yoff + py - ctx->oy;
*ry = ny; *ry = ny;
} else if (yoff < ctx->oy && yoff + ny > ctx->oy + ctx->sy) { } else if (yoff < ctx->oy && yoff + ny > ctx->oy + ctx->sy) {
/* Both left and right not visible. */ /* Both left and right not visible. */
@ -1040,14 +1042,14 @@ tty_clamp_area(struct tty *tty, const struct tty_ctx *ctx, u_int px, u_int py,
*ry = ctx->sy; *ry = ctx->sy;
} else if (yoff < ctx->oy) { } else if (yoff < ctx->oy) {
/* Left not visible. */ /* Left not visible. */
*j = ctx->oy - yoff; *j = ctx->oy - (ctx->yoff + py);
*y = 0; *y = 0;
*ry = ny - *j; *ry = ny - *j;
} else { } else {
/* Right not visible. */ /* Right not visible. */
*j = 0; *j = 0;
*y = yoff - ctx->oy; *y = (ctx->yoff + py) - ctx->oy;
*ry = ny - (yoff + ny - ctx->sy); *ry = ny - ((ctx->yoff + py) + ny - ctx->sy);
} }
return (1); return (1);
} }