diff options
author | Thomas Adam <thomas@xteddy.org> | 2015-11-14 11:38:52 +0000 |
---|---|---|
committer | Thomas Adam <thomas@xteddy.org> | 2015-11-14 11:38:52 +0000 |
commit | 7b4b78b41943082663ba75c7dcfb4e2efa86f4c7 (patch) | |
tree | d0e771c5dcdc91a455e06a352ca6508e7803e867 /tty-keys.c | |
parent | 7b749eff3510ccf173c029a92c266e91454ce600 (diff) | |
parent | dab63b029e94dcabe335abf7f89c66c28486a542 (diff) | |
download | rtmux-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.c | 12 |
1 files changed, 9 insertions, 3 deletions
@@ -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]; |