-/* $OpenBSD: screen-write.c,v 1.117 2017/04/22 10:30:56 nicm Exp $ */
+/* $OpenBSD: screen-write.c,v 1.118 2017/04/25 18:30:29 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
struct screen_write_collect_item {
u_int x;
+ int wrapped;
u_int used;
char data[256];
screen_write_cursormove(ctx, ci->x, y);
screen_write_initctx(ctx, &ttyctx);
ttyctx.cell = &ci->gc;
+ ttyctx.wrapped = ci->wrapped;
ttyctx.ptr = ci->data;
ttyctx.num = ci->used;
tty_write(tty_cmd_cells, &ttyctx);
if (s->cx > sx - 1 || ctx->item->used > sx - 1 - s->cx)
screen_write_collect_end(ctx);
+ ci = ctx->item; /* may have changed */
+
if (s->cx > sx - 1) {
log_debug("%s: wrapped at %u,%u", __func__, s->cx, s->cy);
+ ci->wrapped = 1;
screen_write_linefeed(ctx, 1);
s->cx = 0;
}
- ci = ctx->item; /* may have changed */
if (ci->used == 0)
memcpy(&ci->gc, gc, sizeof ci->gc);
ci->data[ci->used++] = gc->data.data[0];
-/* $OpenBSD: tty.c,v 1.267 2017/04/23 18:13:24 nicm Exp $ */
+/* $OpenBSD: tty.c,v 1.268 2017/04/25 18:30:29 nicm Exp $ */
/*
* Copyright (c) 2007 Nicholas Marriott <nicholas.marriott@gmail.com>
tty_putn(struct tty *tty, const void *buf, size_t len, u_int width)
{
tty_add(tty, buf, len);
- if (tty->cx + width > tty->sx)
- tty->cx = tty->cy = UINT_MAX;
- else
+ if (tty->cx + width > tty->sx) {
+ tty->cx = (tty->cx + width) - tty->sx;
+ if (tty->cx <= tty->sx)
+ tty->cy++;
+ else
+ tty->cx = tty->cy = UINT_MAX;
+ } else
tty->cx += width;
}
if (sx > tty->sx)
sx = tty->sx;
- if (screen_size_x(s) < tty->sx &&
- ox == 0 &&
- sx != screen_size_x(s) &&
- tty_term_has(tty->term, TTYC_EL1) &&
- !tty_fake_bce(tty, wp, 8)) {
- tty_default_attributes(tty, wp, 8);
- tty_cursor(tty, screen_size_x(s) - 1, oy + py);
- tty_putcode(tty, TTYC_EL1);
- cleared = 1;
- }
- if (sx != 0)
- tty_cursor(tty, ox, oy + py);
+ if (wp == NULL ||
+ py == 0 ||
+ (~s->grid->linedata[s->grid->hsize + py - 1].flags & GRID_LINE_WRAPPED) ||
+ ox != 0 ||
+ tty->cx < tty->sx ||
+ screen_size_x(s) < tty->sx) {
+ if (screen_size_x(s) < tty->sx &&
+ ox == 0 &&
+ sx != screen_size_x(s) &&
+ tty_term_has(tty->term, TTYC_EL1) &&
+ !tty_fake_bce(tty, wp, 8)) {
+ tty_default_attributes(tty, wp, 8);
+ tty_cursor(tty, screen_size_x(s) - 1, oy + py);
+ tty_putcode(tty, TTYC_EL1);
+ cleared = 1;
+ }
+ if (sx != 0)
+ tty_cursor(tty, ox, oy + py);
+ } else
+ log_debug("%s: wrapped line %u", __func__, oy + py);
memcpy(&last, &grid_default_cell, sizeof last);
len = 0;
tty_cursor_pane_unless_wrap(struct tty *tty, const struct tty_ctx *ctx,
u_int cx, u_int cy)
{
- if (!tty_pane_full_width(tty, ctx) ||
+ if (!ctx->wrapped ||
+ !tty_pane_full_width(tty, ctx) ||
(tty->term->flags & TERM_EARLYWRAP) ||
ctx->xoff + cx != 0 ||
ctx->yoff + cy != tty->cy + 1 ||