mirror of
https://github.com/tmate-io/tmate.git
synced 2024-11-27 10:33:09 +01:00
Sync OpenBSD patchset 400:
When backspace is received at the beginning of a line and the previous line was wrapped, move the cursor back up to the end of the previous line. Another one of the forgotten persons requested this quite a while ago (I need to start noting names on todo items...) when it was quite hard to implement. Now it is easy and I don't see it can do any harm, so hey presto...
This commit is contained in:
parent
04db3c6211
commit
cbd3b1bc9b
4
input.c
4
input.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: input.c,v 1.95 2009-08-21 21:07:20 tcunha Exp $ */
|
/* $Id: input.c,v 1.96 2009-10-15 01:39:30 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -646,7 +646,7 @@ input_handle_c0_control(u_char ch, struct input_ctx *ictx)
|
|||||||
ictx->wp->window->flags |= WINDOW_BELL;
|
ictx->wp->window->flags |= WINDOW_BELL;
|
||||||
break;
|
break;
|
||||||
case '\010': /* BS */
|
case '\010': /* BS */
|
||||||
screen_write_cursorleft(&ictx->ctx, 1);
|
screen_write_backspace(&ictx->ctx);
|
||||||
break;
|
break;
|
||||||
case '\011': /* TAB */
|
case '\011': /* TAB */
|
||||||
/* Don't tab beyond the end of the line. */
|
/* Don't tab beyond the end of the line. */
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: screen-write.c,v 1.75 2009-10-15 01:35:35 tcunha Exp $ */
|
/* $Id: screen-write.c,v 1.76 2009-10-15 01:39:30 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -513,6 +513,25 @@ screen_write_cursorleft(struct screen_write_ctx *ctx, u_int nx)
|
|||||||
s->cx -= nx;
|
s->cx -= nx;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Backspace; cursor left unless at start of wrapped line when can move up. */
|
||||||
|
void
|
||||||
|
screen_write_backspace(struct screen_write_ctx *ctx)
|
||||||
|
{
|
||||||
|
struct screen *s = ctx->s;
|
||||||
|
struct grid_line *gl;
|
||||||
|
|
||||||
|
if (s->cx == 0) {
|
||||||
|
if (s->cy == 0)
|
||||||
|
return;
|
||||||
|
gl = &s->grid->linedata[s->grid->hsize + s->cy - 1];
|
||||||
|
if (gl->flags & GRID_LINE_WRAPPED) {
|
||||||
|
s->cy--;
|
||||||
|
s->cx = screen_size_x(s) - 1;
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
s->cx--;
|
||||||
|
}
|
||||||
|
|
||||||
/* VT100 alignment test. */
|
/* VT100 alignment test. */
|
||||||
void
|
void
|
||||||
screen_write_alignmenttest(struct screen_write_ctx *ctx)
|
screen_write_alignmenttest(struct screen_write_ctx *ctx)
|
||||||
@ -536,6 +555,7 @@ screen_write_alignmenttest(struct screen_write_ctx *ctx)
|
|||||||
s->cy = 0;
|
s->cy = 0;
|
||||||
|
|
||||||
s->rupper = 0;
|
s->rupper = 0;
|
||||||
|
|
||||||
s->rlower = screen_size_y(s) - 1;
|
s->rlower = screen_size_y(s) - 1;
|
||||||
|
|
||||||
tty_write(tty_cmd_alignmenttest, &ttyctx);
|
tty_write(tty_cmd_alignmenttest, &ttyctx);
|
||||||
|
3
tmux.h
3
tmux.h
@ -1,4 +1,4 @@
|
|||||||
/* $Id: tmux.h,v 1.473 2009-10-15 01:33:21 tcunha Exp $ */
|
/* $Id: tmux.h,v 1.474 2009-10-15 01:39:30 tcunha Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -1644,6 +1644,7 @@ void screen_write_putc(
|
|||||||
struct screen_write_ctx *, struct grid_cell *, u_char);
|
struct screen_write_ctx *, struct grid_cell *, u_char);
|
||||||
void screen_write_copy(struct screen_write_ctx *,
|
void screen_write_copy(struct screen_write_ctx *,
|
||||||
struct screen *, u_int, u_int, u_int, u_int);
|
struct screen *, u_int, u_int, u_int, u_int);
|
||||||
|
void screen_write_backspace(struct screen_write_ctx *);
|
||||||
void screen_write_cursorup(struct screen_write_ctx *, u_int);
|
void screen_write_cursorup(struct screen_write_ctx *, u_int);
|
||||||
void screen_write_cursordown(struct screen_write_ctx *, u_int);
|
void screen_write_cursordown(struct screen_write_ctx *, u_int);
|
||||||
void screen_write_cursorright(struct screen_write_ctx *, u_int);
|
void screen_write_cursorright(struct screen_write_ctx *, u_int);
|
||||||
|
Loading…
Reference in New Issue
Block a user