aboutsummaryrefslogtreecommitdiff
path: root/tty-keys.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2015-11-14 11:38:52 +0000
committerThomas Adam <thomas@xteddy.org>2015-11-14 11:38:52 +0000
commit7b4b78b41943082663ba75c7dcfb4e2efa86f4c7 (patch)
treed0e771c5dcdc91a455e06a352ca6508e7803e867 /tty-keys.c
parent7b749eff3510ccf173c029a92c266e91454ce600 (diff)
parentdab63b029e94dcabe335abf7f89c66c28486a542 (diff)
downloadrtmux-7b4b78b41943082663ba75c7dcfb4e2efa86f4c7.tar.gz
rtmux-7b4b78b41943082663ba75c7dcfb4e2efa86f4c7.tar.bz2
rtmux-7b4b78b41943082663ba75c7dcfb4e2efa86f4c7.zip
Merge branch 'obsd-master'
Diffstat (limited to 'tty-keys.c')
-rw-r--r--tty-keys.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/tty-keys.c b/tty-keys.c
index 6a64ef15..cc6b934a 100644
--- a/tty-keys.c
+++ b/tty-keys.c
@@ -472,7 +472,7 @@ tty_keys_next(struct tty *tty)
const char *buf;
size_t len, size;
cc_t bspace;
- int delay, expired = 0;
+ int delay, expired = 0, more;
key_code key;
struct utf8_data ud;
u_int i;
@@ -546,8 +546,11 @@ first_key:
goto discard_key;
goto partial_key;
}
+ more = 1;
for (i = 1; i < size; i++)
- utf8_append(&ud, (u_char)buf[i]);
+ more = utf8_append(&ud, (u_char)buf[i]);
+ if (more != 0)
+ goto discard_key;
key = utf8_combine(&ud);
log_debug("UTF-8 key %.*s %#llx", (int)size, buf, key);
goto complete_key;
@@ -653,6 +656,7 @@ tty_keys_mouse(struct tty *tty, const char *buf, size_t len, size_t *size)
struct utf8_data ud;
u_int i, value, x, y, b, sgr_b;
u_char sgr_type, c;
+ int more;
/*
* Standard mouse sequences are \033[M followed by three characters
@@ -699,7 +703,9 @@ tty_keys_mouse(struct tty *tty, const char *buf, size_t len, size_t *size)
(*size)++;
if (len <= *size)
return (1);
- utf8_append(&ud, buf[*size]);
+ more = utf8_append(&ud, buf[*size]);
+ if (more != 0)
+ return (-1);
value = utf8_combine(&ud);
} else
value = (u_char)buf[*size];