Added termkey_push_bytes(), a new API for providing input bytes
This commit is contained in:
29
t/02getkey.c
29
t/02getkey.c
@@ -4,30 +4,23 @@
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
int fd[2];
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
|
||||
plan_tests(29);
|
||||
|
||||
pipe(fd);
|
||||
plan_tests(27);
|
||||
|
||||
/* Sanitise this just in case */
|
||||
putenv("TERM=vt100");
|
||||
|
||||
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS);
|
||||
tk = termkey_new(0, TERMKEY_FLAG_NOTERMIOS);
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE when empty");
|
||||
|
||||
write(fd[1], "h", 1);
|
||||
is_int(termkey_push_bytes(tk, "h", 1), 1, "push_bytes returns 1");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE before advisereadable");
|
||||
|
||||
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after h");
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after advisereadable");
|
||||
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after push_bytes");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after h");
|
||||
|
||||
@@ -40,9 +33,7 @@ int main(int argc, char *argv[])
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE a second time");
|
||||
|
||||
write(fd[1], "\x01", 1);
|
||||
|
||||
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after C-a");
|
||||
termkey_push_bytes(tk, "\x01", 1);
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after C-a");
|
||||
|
||||
@@ -50,9 +41,7 @@ int main(int argc, char *argv[])
|
||||
is_int(key.code.number, 'a', "key.code.number after C-a");
|
||||
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers after C-a");
|
||||
|
||||
write(fd[1], "\eOA", 3);
|
||||
|
||||
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after Up");
|
||||
termkey_push_bytes(tk, "\eOA", 3);
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Up");
|
||||
|
||||
@@ -60,15 +49,13 @@ int main(int argc, char *argv[])
|
||||
is_int(key.code.sym, TERMKEY_SYM_UP, "key.code.sym after Up");
|
||||
is_int(key.modifiers, 0, "key.modifiers after Up");
|
||||
|
||||
write(fd[1], "\eO", 2);
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_push_bytes(tk, "\eO", 2), 2, "push_bytes returns 2");
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 254, "buffer free 254 after partial write");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN after partial write");
|
||||
|
||||
write(fd[1], "C", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "C", 1);
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Right completion");
|
||||
|
||||
|
||||
71
t/03utf8.c
71
t/03utf8.c
@@ -3,22 +3,18 @@
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
int fd[2];
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
|
||||
plan_tests(57);
|
||||
|
||||
pipe(fd);
|
||||
|
||||
/* Sanitise this just in case */
|
||||
putenv("TERM=vt100");
|
||||
|
||||
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS|TERMKEY_FLAG_UTF8);
|
||||
tk = termkey_new(0, TERMKEY_FLAG_NOTERMIOS|TERMKEY_FLAG_UTF8);
|
||||
|
||||
write(fd[1], "a", 1);
|
||||
termkey_push_bytes(tk, "a", 1);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY low ASCII");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type low ASCII");
|
||||
is_int(key.code.number, 'a', "key.code.number low ASCII");
|
||||
@@ -26,97 +22,85 @@ int main(int argc, char *argv[])
|
||||
/* 2-byte UTF-8 range is U+0080 to U+07FF (0xDF 0xBF) */
|
||||
/* However, we'd best avoid the C1 range, so we'll start at U+00A0 (0xC2 0xA0) */
|
||||
|
||||
write(fd[1], "\xC2\xA0", 2);
|
||||
termkey_push_bytes(tk, "\xC2\xA0", 2);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 low");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 2 low");
|
||||
is_int(key.code.number, 0x00A0, "key.code.number UTF-8 2 low");
|
||||
|
||||
write(fd[1], "\xDF\xBF", 2);
|
||||
termkey_push_bytes(tk, "\xDF\xBF", 2);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 high");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 2 high");
|
||||
is_int(key.code.number, 0x07FF, "key.code.number UTF-8 2 high");
|
||||
|
||||
/* 3-byte UTF-8 range is U+0800 (0xE0 0xA0 0x80) to U+FFFD (0xEF 0xBF 0xBD) */
|
||||
|
||||
write(fd[1], "\xE0\xA0\x80", 3);
|
||||
termkey_push_bytes(tk, "\xE0\xA0\x80", 3);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 low");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 3 low");
|
||||
is_int(key.code.number, 0x0800, "key.code.number UTF-8 3 low");
|
||||
|
||||
write(fd[1], "\xEF\xBF\xBD", 3);
|
||||
termkey_push_bytes(tk, "\xEF\xBF\xBD", 3);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 high");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 3 high");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 3 high");
|
||||
|
||||
/* 4-byte UTF-8 range is U+10000 (0xF0 0x90 0x80 0x80) to U+10FFFF (0xF4 0x8F 0xBF 0xBF) */
|
||||
|
||||
write(fd[1], "\xF0\x90\x80\x80", 4);
|
||||
termkey_push_bytes(tk, "\xF0\x90\x80\x80", 4);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 low");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 4 low");
|
||||
is_int(key.code.number, 0x10000, "key.code.number UTF-8 4 low");
|
||||
|
||||
write(fd[1], "\xF4\x8F\xBF\xBF", 4);
|
||||
termkey_push_bytes(tk, "\xF4\x8F\xBF\xBF", 4);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 high");
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type UTF-8 4 high");
|
||||
is_int(key.code.number, 0x10FFFF, "key.code.number UTF-8 4 high");
|
||||
|
||||
/* Invalid continuations */
|
||||
|
||||
write(fd[1], "\xC2!", 2);
|
||||
termkey_push_bytes(tk, "\xC2!", 2);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 invalid cont");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 2 invalid cont");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 invalid after");
|
||||
is_int(key.code.number, '!', "key.code.number UTF-8 2 invalid after");
|
||||
|
||||
write(fd[1], "\xE0!", 2);
|
||||
termkey_push_bytes(tk, "\xE0!", 2);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid cont");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 3 invalid cont");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid after");
|
||||
is_int(key.code.number, '!', "key.code.number UTF-8 3 invalid after");
|
||||
|
||||
write(fd[1], "\xE0\xA0!", 3);
|
||||
termkey_push_bytes(tk, "\xE0\xA0!", 3);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid cont 2");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 3 invalid cont 2");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid after");
|
||||
is_int(key.code.number, '!', "key.code.number UTF-8 3 invalid after");
|
||||
|
||||
write(fd[1], "\xF0!", 2);
|
||||
termkey_push_bytes(tk, "\xF0!", 2);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 4 invalid cont");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid after");
|
||||
is_int(key.code.number, '!', "key.code.number UTF-8 4 invalid after");
|
||||
|
||||
write(fd[1], "\xF0\x90!", 3);
|
||||
termkey_push_bytes(tk, "\xF0\x90!", 3);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont 2");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 4 invalid cont 2");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid after");
|
||||
is_int(key.code.number, '!', "key.code.number UTF-8 4 invalid after");
|
||||
|
||||
write(fd[1], "\xF0\x90\x80!", 4);
|
||||
termkey_push_bytes(tk, "\xF0\x90\x80!", 4);
|
||||
|
||||
termkey_advisereadable(tk);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont 3");
|
||||
is_int(key.code.number, 0xFFFD, "key.code.number UTF-8 4 invalid cont 3");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid after");
|
||||
@@ -124,42 +108,33 @@ int main(int argc, char *argv[])
|
||||
|
||||
/* Partials */
|
||||
|
||||
write(fd[1], "\xC2", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\xC2", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 2 partial");
|
||||
|
||||
write(fd[1], "\xA0", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\xA0", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 partial");
|
||||
is_int(key.code.number, 0x00A0, "key.code.number UTF-8 2 partial");
|
||||
|
||||
write(fd[1], "\xE0", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\xE0", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 3 partial");
|
||||
|
||||
write(fd[1], "\xA0", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\xA0", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 3 partial");
|
||||
|
||||
write(fd[1], "\x80", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\x80", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 partial");
|
||||
is_int(key.code.number, 0x0800, "key.code.number UTF-8 3 partial");
|
||||
|
||||
write(fd[1], "\xF0", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\xF0", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
|
||||
|
||||
write(fd[1], "\x90", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\x90", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
|
||||
|
||||
write(fd[1], "\x80", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\x80", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
|
||||
|
||||
write(fd[1], "\x80", 1);
|
||||
termkey_advisereadable(tk);
|
||||
termkey_push_bytes(tk, "\x80", 1);
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 partial");
|
||||
is_int(key.code.number, 0x10000, "key.code.number UTF-8 4 partial");
|
||||
|
||||
|
||||
13
t/04flags.c
13
t/04flags.c
@@ -4,22 +4,19 @@
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
int fd[2];
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
|
||||
plan_tests(8);
|
||||
|
||||
pipe(fd);
|
||||
|
||||
/* Sanitise this just in case */
|
||||
putenv("TERM=vt100");
|
||||
|
||||
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS);
|
||||
tk = termkey_new(0, TERMKEY_FLAG_NOTERMIOS);
|
||||
|
||||
write(fd[1], " ", 1);
|
||||
termkey_push_bytes(tk, " ", 1);
|
||||
|
||||
is_int(termkey_waitkey(tk, &key), TERMKEY_RES_KEY, "waitkey yields RES_KEY after space");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after space");
|
||||
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type after space");
|
||||
is_int(key.code.number, ' ', "key.code.number after space");
|
||||
@@ -27,9 +24,9 @@ int main(int argc, char *argv[])
|
||||
|
||||
termkey_set_flags(tk, TERMKEY_FLAG_SPACESYMBOL);
|
||||
|
||||
write(fd[1], " ", 1);
|
||||
termkey_push_bytes(tk, " ", 1);
|
||||
|
||||
is_int(termkey_waitkey(tk, &key), TERMKEY_RES_KEY, "waitkey yields RES_KEY after space");
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after space");
|
||||
|
||||
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type after space with FLAG_SPACESYMBOL");
|
||||
is_int(key.code.number, TERMKEY_SYM_SPACE, "key.code.sym after space with FLAG_SPACESYMBOL");
|
||||
|
||||
66
t/05read.c
Normal file
66
t/05read.c
Normal file
@@ -0,0 +1,66 @@
|
||||
#include <stdio.h>
|
||||
#include "../termkey.h"
|
||||
#include "taplib.h"
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
int fd[2];
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
|
||||
plan_tests(19);
|
||||
|
||||
/* We'll need a real filehandle we can write/read.
|
||||
* pipe() can make us one */
|
||||
pipe(fd);
|
||||
|
||||
/* Sanitise this just in case */
|
||||
putenv("TERM=vt100");
|
||||
|
||||
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS);
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE when empty");
|
||||
|
||||
write(fd[1], "h", 1);
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE before advisereadable");
|
||||
|
||||
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after h");
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after advisereadable");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after h");
|
||||
|
||||
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type after h");
|
||||
is_int(key.code.number, 'h', "key.code.number after h");
|
||||
is_int(key.modifiers, 0, "key.modifiers after h");
|
||||
is_str(key.utf8, "h", "key.utf8 after h");
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after getkey");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE a second time");
|
||||
|
||||
write(fd[1], "\eO", 2);
|
||||
termkey_advisereadable(tk);
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 254, "buffer free 254 after partial write");
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN after partial write");
|
||||
|
||||
write(fd[1], "C", 1);
|
||||
termkey_advisereadable(tk);
|
||||
|
||||
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Right completion");
|
||||
|
||||
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type after Right");
|
||||
is_int(key.code.sym, TERMKEY_SYM_RIGHT, "key.code.sym after Right");
|
||||
is_int(key.modifiers, 0, "key.modifiers after Right");
|
||||
|
||||
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after completion");
|
||||
|
||||
termkey_destroy(tk);
|
||||
|
||||
return exit_status();
|
||||
}
|
||||
Reference in New Issue
Block a user