summaryrefslogtreecommitdiffstats
path: root/tty-keys.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicm@openbsd.org>2009-11-04 21:47:42 +0000
committerNicholas Marriott <nicm@openbsd.org>2009-11-04 21:47:42 +0000
commit7342615c7ddd9b99820bd9c03fda2afe7bc868d3 (patch)
tree4b5ac210a0af55bb3ea1f5d9aebcd91456d397d7 /tty-keys.c
parentabb728684b00c82460ea439c8df16d3f1018c826 (diff)
Switch tty fds over to a bufferevent.
Diffstat (limited to 'tty-keys.c')
-rw-r--r--tty-keys.c23
1 files changed, 13 insertions, 10 deletions
diff --git a/tty-keys.c b/tty-keys.c
index 2b7bae67..995f2994 100644
--- a/tty-keys.c
+++ b/tty-keys.c
@@ -299,18 +299,20 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
struct tty_key *tk;
struct timeval tv;
char *buf;
+ u_char ch;
size_t len, size;
cc_t bspace;
- buf = BUFFER_OUT(tty->in);
- len = BUFFER_USED(tty->in);
+ buf = EVBUFFER_DATA(tty->event->input);
+ len = EVBUFFER_LENGTH(tty->event->input);
if (len == 0)
return (1);
log_debug("keys are %zu (%.*s)", len, (int) len, buf);
/* If a normal key, return it. */
if (*buf != '\033') {
- *key = buffer_read8(tty->in);
+ bufferevent_read(tty->event, &ch, 1);
+ *key = ch;
/*
* Check for backspace key using termios VERASE - the terminfo
@@ -326,7 +328,7 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
/* Look for matching key string and return if found. */
tk = tty_keys_find(tty, buf + 1, len - 1, &size);
if (tk != NULL) {
- buffer_remove(tty->in, size + 1);
+ evbuffer_drain(tty->event->input, size + 1);
*key = tk->key;
goto found;
}
@@ -334,14 +336,14 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
/* Not found. Is this a mouse key press? */
*key = tty_keys_mouse(buf, len, &size, mouse);
if (*key != KEYC_NONE) {
- buffer_remove(tty->in, size);
+ evbuffer_drain(tty->event->input, size);
goto found;
}
/* Not found. Try to parse a key with an xterm-style modifier. */
*key = xterm_keys_find(buf, len, &size);
if (*key != KEYC_NONE) {
- buffer_remove(tty->in, size);
+ evbuffer_drain(tty->event->input, size);
goto found;
}
@@ -363,8 +365,9 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
/* Is there a normal key following? */
if (len != 0 && *buf != '\033') {
- buffer_remove(tty->in, 1);
- *key = buffer_read8(tty->in) | KEYC_ESCAPE;
+ evbuffer_drain(tty->event->input, 1);
+ bufferevent_read(tty->event, &ch, 1);
+ *key = ch | KEYC_ESCAPE;
goto found;
}
@@ -372,7 +375,7 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
if (len > 1) {
tk = tty_keys_find(tty, buf + 1, len - 1, &size);
if (tk != NULL) {
- buffer_remove(tty->in, size + 2);
+ evbuffer_drain(tty->event->input, size + 2);
*key = tk->key | KEYC_ESCAPE;
goto found;
}
@@ -385,7 +388,7 @@ tty_keys_next(struct tty *tty, int *key, struct mouse_event *mouse)
return (1);
/* Give up and return the escape. */
- buffer_remove(tty->in, 1);
+ evbuffer_drain(tty->event->input, 1);
*key = '\033';
found: