mirror of
https://github.com/tmux/tmux.git
synced 2025-01-14 20:58:53 +00:00
vi keys from Will Maier.
This commit is contained in:
parent
04c60283c4
commit
39be570b20
1
TODO
1
TODO
@ -81,3 +81,4 @@
|
|||||||
- show-options
|
- show-options
|
||||||
- let server die when last session does
|
- let server die when last session does
|
||||||
- each command should have a print op as well for list keys
|
- each command should have a print op as well for list keys
|
||||||
|
- fix occasion start server problems
|
||||||
|
7
input.c
7
input.c
@ -1,4 +1,4 @@
|
|||||||
/* $Id: input.c,v 1.47 2008-06-04 16:46:23 nicm Exp $ */
|
/* $Id: input.c,v 1.48 2008-06-04 18:50:34 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -223,8 +223,6 @@ input_parse(struct window *w)
|
|||||||
else
|
else
|
||||||
screen_write_start(&ictx->ctx, &w->base, NULL, NULL);
|
screen_write_start(&ictx->ctx, &w->base, NULL, NULL);
|
||||||
|
|
||||||
if (ictx->off != ictx->len)
|
|
||||||
w->flags |= WINDOW_ACTIVITY;
|
|
||||||
while (ictx->off < ictx->len) {
|
while (ictx->off < ictx->len) {
|
||||||
ch = ictx->buf[ictx->off++];
|
ch = ictx->buf[ictx->off++];
|
||||||
ictx->state(ch, ictx);
|
ictx->state(ch, ictx);
|
||||||
@ -483,7 +481,8 @@ input_handle_character(u_char ch, struct input_ctx *ictx)
|
|||||||
{
|
{
|
||||||
log_debug2("-- ch %zu: %hhu (%c)", ictx->off, ch, ch);
|
log_debug2("-- ch %zu: %hhu (%c)", ictx->off, ch, ch);
|
||||||
|
|
||||||
screen_write_put_character(&ictx->ctx, ch);
|
if (screen_write_put_character(&ictx->ctx, ch))
|
||||||
|
ictx->w->flags |= WINDOW_ACTIVITY;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: screen-display.c,v 1.14 2007-12-06 22:13:14 nicm Exp $ */
|
/* $Id: screen-display.c,v 1.15 2008-06-04 18:50:34 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -22,6 +22,14 @@
|
|||||||
|
|
||||||
#include "tmux.h"
|
#include "tmux.h"
|
||||||
|
|
||||||
|
/* Get a cell. */
|
||||||
|
void
|
||||||
|
screen_display_get_cell(struct screen *s,
|
||||||
|
u_int px, u_int py, u_char *data, u_char *attr, u_char *colr)
|
||||||
|
{
|
||||||
|
screen_get_cell(s, screen_x(s, px), screen_y(s, py), data, attr, colr);
|
||||||
|
}
|
||||||
|
|
||||||
/* Set a cell. */
|
/* Set a cell. */
|
||||||
void
|
void
|
||||||
screen_display_set_cell(
|
screen_display_set_cell(
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: screen-write.c,v 1.5 2007-12-06 19:57:01 nicm Exp $ */
|
/* $Id: screen-write.c,v 1.6 2008-06-04 18:50:34 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -98,10 +98,12 @@ screen_write_set_title(struct screen_write_ctx *ctx, char *title)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Put a character. */
|
/* Put a character. */
|
||||||
void
|
int
|
||||||
screen_write_put_character(struct screen_write_ctx *ctx, u_char ch)
|
screen_write_put_character(struct screen_write_ctx *ctx, u_char ch)
|
||||||
{
|
{
|
||||||
struct screen *s = ctx->s;
|
struct screen *s = ctx->s;
|
||||||
|
u_char data, attr, colr;
|
||||||
|
int n;
|
||||||
|
|
||||||
if (s->cx == screen_size_x(s)) {
|
if (s->cx == screen_size_x(s)) {
|
||||||
s->cx = 0;
|
s->cx = 0;
|
||||||
@ -110,14 +112,20 @@ screen_write_put_character(struct screen_write_ctx *ctx, u_char ch)
|
|||||||
screen_write_cursor_down_scroll(ctx);
|
screen_write_cursor_down_scroll(ctx);
|
||||||
} else if (!screen_in_x(s, s->cx) || !screen_in_y(s, s->cy)) {
|
} else if (!screen_in_x(s, s->cx) || !screen_in_y(s, s->cy)) {
|
||||||
SCREEN_DEBUG(s);
|
SCREEN_DEBUG(s);
|
||||||
return;
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
screen_display_set_cell(s, s->cx, s->cy, ch, s->attr, s->colr);
|
screen_display_get_cell(s, s->cx, s->cy, &data, &attr, &colr);
|
||||||
|
if (ch != data || s->attr != attr || colr != s->colr) {
|
||||||
|
screen_display_set_cell(s, s->cx, s->cy, ch, s->attr, s->colr);
|
||||||
|
n = 1;
|
||||||
|
} else
|
||||||
|
n = 0;
|
||||||
s->cx++;
|
s->cx++;
|
||||||
|
|
||||||
if (ctx->write != NULL)
|
if (ctx->write != NULL)
|
||||||
ctx->write(ctx->data, TTY_CHARACTER, ch);
|
ctx->write(ctx->data, TTY_CHARACTER, ch);
|
||||||
|
return (n);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Put a string right-justified. */
|
/* Put a string right-justified. */
|
||||||
|
6
tmux.h
6
tmux.h
@ -1,4 +1,4 @@
|
|||||||
/* $Id: tmux.h,v 1.129 2008-06-04 17:54:26 nicm Exp $ */
|
/* $Id: tmux.h,v 1.130 2008-06-04 18:50:35 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -919,6 +919,8 @@ void input_parse(struct window *);
|
|||||||
void input_key(struct window *, int);
|
void input_key(struct window *, int);
|
||||||
|
|
||||||
/* screen-display.c */
|
/* screen-display.c */
|
||||||
|
void screen_display_get_cell(
|
||||||
|
struct screen *, u_int, u_int, u_char *, u_char *, u_char *);
|
||||||
void screen_display_set_cell(
|
void screen_display_set_cell(
|
||||||
struct screen *, u_int, u_int, u_char, u_char, u_char);
|
struct screen *, u_int, u_int, u_char, u_char, u_char);
|
||||||
void screen_display_make_lines(struct screen *, u_int, u_int);
|
void screen_display_make_lines(struct screen *, u_int, u_int);
|
||||||
@ -946,7 +948,7 @@ void screen_write_start(struct screen_write_ctx *,
|
|||||||
struct screen *, void (*)(void *, int, ...), void *);
|
struct screen *, void (*)(void *, int, ...), void *);
|
||||||
void screen_write_stop(struct screen_write_ctx *);
|
void screen_write_stop(struct screen_write_ctx *);
|
||||||
void screen_write_set_title(struct screen_write_ctx *, char *);
|
void screen_write_set_title(struct screen_write_ctx *, char *);
|
||||||
void screen_write_put_character(struct screen_write_ctx *, u_char);
|
int screen_write_put_character(struct screen_write_ctx *, u_char);
|
||||||
size_t printflike2 screen_write_put_string_rjust(
|
size_t printflike2 screen_write_put_string_rjust(
|
||||||
struct screen_write_ctx *, const char *, ...);
|
struct screen_write_ctx *, const char *, ...);
|
||||||
void printflike2 screen_write_put_string(
|
void printflike2 screen_write_put_string(
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
/* $Id: window-copy.c,v 1.16 2008-06-03 21:42:37 nicm Exp $ */
|
/* $Id: window-copy.c,v 1.17 2008-06-04 18:50:35 nicm Exp $ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
* Copyright (c) 2007 Nicholas Marriott <nicm@users.sourceforge.net>
|
||||||
@ -184,9 +184,11 @@ window_copy_key(struct window *w, int key)
|
|||||||
window_copy_copy_selection(w);
|
window_copy_copy_selection(w);
|
||||||
window_reset_mode(w);
|
window_reset_mode(w);
|
||||||
break;
|
break;
|
||||||
|
case '0':
|
||||||
case '\001': /* C-a */
|
case '\001': /* C-a */
|
||||||
window_copy_cursor_start_of_line(w);
|
window_copy_cursor_start_of_line(w);
|
||||||
break;
|
break;
|
||||||
|
case '$':
|
||||||
case '\005': /* C-e */
|
case '\005': /* C-e */
|
||||||
window_copy_cursor_end_of_line(w);
|
window_copy_cursor_end_of_line(w);
|
||||||
break;
|
break;
|
||||||
|
Loading…
Reference in New Issue
Block a user