Make the tests work again

Our UTF-8 parsing now behaves differently, though.
This commit is contained in:
Přemysl Eric Janouch 2014-09-28 05:56:13 +02:00
parent 36bc6cd095
commit 3465d5553f
17 changed files with 961 additions and 767 deletions

View File

@ -2,30 +2,28 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
termkey_t *tk;
plan_tests (6);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
ok (!!tk, "termkey_new_abstract");
is_int (termkey_get_buffer_size (tk), 256, "termkey_get_buffer_size");
ok (termkey_is_started (tk), "termkey_is_started true after construction");
termkey_stop (tk);
ok(!termkey_is_started(tk), "termkey_is_started false after termkey_stop()");
ok (!termkey_is_started (tk),
"termkey_is_started false after termkey_stop()");
termkey_start (tk);
ok(termkey_is_started(tk), "termkey_is_started true after termkey_start()");
ok (termkey_is_started (tk),
"termkey_is_started true after termkey_start()");
termkey_destroy (tk);
ok (1, "termkey_free");
return exit_status ();
}

View File

@ -1,45 +1,54 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
plan_tests (31);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
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");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
"getkey yields RES_NONE when empty");
is_int (termkey_push_bytes (tk, "h", 1), 1, "push_bytes returns 1");
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after push_bytes");
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");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY after h");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type after h");
is_int (key.code.codepoint, 'h', "key.code.codepoint after h");
is_int (key.modifiers, 0, "key.modifiers after h");
is_str (key.multibyte, "h", "key.multibyte after h");
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after getkey");
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");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
"getkey yields RES_NONE a second time");
termkey_push_bytes (tk, "\x01", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after C-a");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY after C-a");
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type after C-a");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type after C-a");
is_int (key.code.codepoint, 'a', "key.code.codepoint after C-a");
is_int (key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers after C-a");
termkey_push_bytes (tk, "\033OA", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Up");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY after Up");
is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type after Up");
is_int (key.code.sym, TERMKEY_SYM_UP, "key.code.sym after Up");
@ -47,27 +56,35 @@ int main(int argc, char *argv[])
is_int (termkey_push_bytes (tk, "\033O", 2), 2, "push_bytes returns 2");
is_int(termkey_get_buffer_remaining(tk), 254, "buffer free 254 after partial write");
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");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN after partial write");
termkey_push_bytes (tk, "C", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Right completion");
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");
is_int (termkey_get_buffer_remaining (tk), 256,
"buffer free 256 after completion");
termkey_push_bytes (tk, "\033[27;5u", 7);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Ctrl-Escape");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY after Ctrl-Escape");
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type after Ctrl-Escape");
is_int(key.code.sym, TERMKEY_SYM_ESCAPE, "key.code.sym after Ctrl-Escape");
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers after Ctrl-Escape");
is_int (key.type, TERMKEY_TYPE_KEYSYM,
"key.type after Ctrl-Escape");
is_int (key.code.sym, TERMKEY_SYM_ESCAPE,
"key.code.sym after Ctrl-Escape");
is_int (key.modifiers, TERMKEY_KEYMOD_CTRL,
"key.modifiers after Ctrl-Escape");
termkey_destroy (tk);

View File

@ -1,18 +1,20 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
plan_tests(57);
plan_tests (33 /* 57 */);
tk = termkey_new_abstract ("vt100", "UTF-8", 0);
termkey_push_bytes (tk, "a", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY low ASCII");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY low ASCII");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type low ASCII");
is_int (key.code.codepoint, 'a', "key.code.codepoint low ASCII");
@ -21,13 +23,15 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\xC2\xA0", 2);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 low");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 2 low");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 2 low");
is_int (key.code.codepoint, 0x00A0, "key.code.codepoint UTF-8 2 low");
termkey_push_bytes (tk, "\xDF\xBF", 2);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 high");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 2 high");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 2 high");
is_int (key.code.codepoint, 0x07FF, "key.code.codepoint UTF-8 2 high");
@ -35,13 +39,15 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\xE0\xA0\x80", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 low");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 3 low");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 3 low");
is_int (key.code.codepoint, 0x0800, "key.code.codepoint UTF-8 3 low");
termkey_push_bytes (tk, "\xEF\xBF\xBD", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 high");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 3 high");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 3 high");
is_int (key.code.codepoint, 0xFFFD, "key.code.codepoint UTF-8 3 high");
@ -49,93 +55,134 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\xF0\x90\x80\x80", 4);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 low");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 low");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 4 low");
is_int (key.code.codepoint, 0x10000, "key.code.codepoint UTF-8 4 low");
termkey_push_bytes (tk, "\xF4\x8F\xBF\xBF", 4);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 high");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 high");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 4 high");
is_int (key.code.codepoint, 0x10FFFF, "key.code.codepoint UTF-8 4 high");
#if 0
/* XXX: With the move to iconv, this has changed significantly. */
/* Invalid continuations */
termkey_push_bytes (tk, "\xC2!", 2);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 2 invalid cont");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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.codepoint, '!', "key.code.codepoint UTF-8 2 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 2 invalid cont");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint 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.codepoint, '!',
"key.code.codepoint UTF-8 2 invalid after");
termkey_push_bytes (tk, "\xE0!", 2);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid cont");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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.codepoint, '!', "key.code.codepoint UTF-8 3 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 3 invalid cont");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint 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.codepoint, '!',
"key.code.codepoint UTF-8 3 invalid after");
termkey_push_bytes (tk, "\xE0\xA0!", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 3 invalid cont 2");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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.codepoint, '!', "key.code.codepoint UTF-8 3 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 3 invalid cont 2");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint 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.codepoint, '!',
"key.code.codepoint UTF-8 3 invalid after");
termkey_push_bytes (tk, "\xF0!", 2);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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.codepoint, '!', "key.code.codepoint UTF-8 4 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 invalid cont");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint 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.codepoint, '!',
"key.code.codepoint UTF-8 4 invalid after");
termkey_push_bytes (tk, "\xF0\x90!", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont 2");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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.codepoint, '!', "key.code.codepoint UTF-8 4 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 invalid cont 2");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint 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.codepoint, '!',
"key.code.codepoint UTF-8 4 invalid after");
termkey_push_bytes (tk, "\xF0\x90\x80!", 4);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid cont 3");
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint UTF-8 4 invalid cont 3");
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY UTF-8 4 invalid after");
is_int(key.code.codepoint, '!', "key.code.codepoint UTF-8 4 invalid after");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 invalid cont 3");
is_int (key.code.codepoint, 0xFFFD,
"key.code.codepoint UTF-8 4 invalid cont 3");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 invalid after");
is_int (key.code.codepoint, '!',
"key.code.codepoint UTF-8 4 invalid after");
#endif
/* Partials */
termkey_push_bytes (tk, "\xC2", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 2 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 2 partial");
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.codepoint, 0x00A0, "key.code.codepoint UTF-8 2 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 2 partial");
is_int (key.code.codepoint, 0x00A0,
"key.code.codepoint UTF-8 2 partial");
termkey_push_bytes (tk, "\xE0", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 3 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 3 partial");
termkey_push_bytes (tk, "\xA0", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 3 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 3 partial");
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.codepoint, 0x0800, "key.code.codepoint UTF-8 3 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 3 partial");
is_int (key.code.codepoint, 0x0800,
"key.code.codepoint UTF-8 3 partial");
termkey_push_bytes (tk, "\xF0", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 4 partial");
termkey_push_bytes (tk, "\x90", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 4 partial");
termkey_push_bytes (tk, "\x80", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN UTF-8 4 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
"getkey yields RES_AGAIN UTF-8 4 partial");
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.codepoint, 0x10000, "key.code.codepoint UTF-8 4 partial");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY UTF-8 4 partial");
is_int (key.code.codepoint, 0x10000,
"key.code.codepoint UTF-8 4 partial");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -2,20 +2,22 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
plan_tests (8);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
termkey_push_bytes (tk, " ", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey 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.type, TERMKEY_TYPE_KEY, "key.type after space");
is_int (key.code.codepoint, ' ', "key.code.codepoint after space");
is_int (key.modifiers, 0, "key.modifiers after space");
@ -23,13 +25,16 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, " ", 1);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey 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.sym, TERMKEY_SYM_SPACE, "key.code.sym after space with FLAG_SPACESYMBOL");
is_int(key.modifiers, 0, "key.modifiers after space with FLAG_SPACESYMBOL");
is_int (key.type, TERMKEY_TYPE_KEYSYM,
"key.type after space with FLAG_SPACESYMBOL");
is_int (key.code.sym, TERMKEY_SYM_SPACE,
"key.code.sym after space with FLAG_SPACESYMBOL");
is_int (key.modifiers, 0,
"key.modifiers after space with FLAG_SPACESYMBOL");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -3,11 +3,12 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
int fd[2];
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
plan_tests (21);
@ -18,55 +19,67 @@ int main(int argc, char *argv[])
/* Sanitise this just in case */
putenv ("TERM=vt100");
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS);
tk = termkey_new (fd[0], NULL, TERMKEY_FLAG_NOTERMIOS);
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
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");
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_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_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 advisereadable");
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after h");
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.type, TERMKEY_TYPE_KEY, "key.type after h");
is_int (key.code.codepoint, 'h', "key.code.codepoint after h");
is_int (key.modifiers, 0, "key.modifiers after h");
is_str(key.utf8, "h", "key.utf8 after h");
is_str (key.multibyte, "h", "key.multibyte after h");
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after getkey");
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");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
"getkey yields RES_NONE a second time");
write (fd[1], "\033O", 2);
termkey_advisereadable (tk);
is_int(termkey_get_buffer_remaining(tk), 254, "buffer free 254 after partial write");
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");
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 (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");
is_int (termkey_get_buffer_remaining (tk), 256,
"buffer free 256 after completion");
termkey_stop (tk);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_ERROR, "getkey yields RES_ERROR after termkey_stop()");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_ERROR,
"getkey yields RES_ERROR after termkey_stop ()");
is_int (errno, EINVAL, "getkey error is EINVAL");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -4,29 +4,35 @@
int main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
plan_tests (9);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
is_int(termkey_get_buffer_size(tk), 256, "buffer size initially 256");
is_int (termkey_get_buffer_remaining (tk), 256,
"buffer free initially 256");
is_int (termkey_get_buffer_size (tk), 256,
"buffer size initially 256");
is_int (termkey_push_bytes (tk, "h", 1), 1, "push_bytes returns 1");
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after push_bytes");
is_int(termkey_get_buffer_size(tk), 256, "buffer size 256 after push_bytes");
is_int (termkey_get_buffer_remaining (tk), 255,
"buffer free 255 after push_bytes");
is_int (termkey_get_buffer_size (tk), 256,
"buffer size 256 after push_bytes");
ok (!!termkey_set_buffer_size (tk, 512), "buffer set size OK");
is_int(termkey_get_buffer_remaining(tk), 511, "buffer free 511 after push_bytes");
is_int(termkey_get_buffer_size(tk), 512, "buffer size 512 after push_bytes");
is_int (termkey_get_buffer_remaining (tk), 511,
"buffer free 511 after push_bytes");
is_int (termkey_get_buffer_size (tk), 512,
"buffer size 512 after push_bytes");
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "buffered key still useable after resize");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"buffered key still useable after resize");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,15 +1,16 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeySym sym;
termkey_t *tk;
termkey_sym_t sym;
const char *end;
plan_tests (10);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
sym = termkey_keyname2sym (tk, "Space");
is_int (sym, TERMKEY_SYM_SPACE, "keyname2sym Space");
@ -25,14 +26,15 @@ int main(int argc, char *argv[])
end = termkey_lookup_keyname (tk, "DownMore", &sym);
ok (!!end, "termkey_get_keyname DownMore returns non-NULL");
is_str (end, "More", "termkey_get_keyname DownMore return points at More");
is_int(sym, TERMKEY_SYM_DOWN, "termkey_get_keyname DownMore yields Down symbol");
is_int (sym, TERMKEY_SYM_DOWN,
"termkey_get_keyname DownMore yields Down symbol");
end = termkey_lookup_keyname (tk, "SomeUnknownKey", &sym);
ok (!end, "termkey_get_keyname SomeUnknownKey returns NULL");
is_str(termkey_get_keyname(tk, TERMKEY_SYM_SPACE), "Space", "get_keyname SPACE");
is_str (termkey_get_keyname (tk, TERMKEY_SYM_SPACE), "Space",
"get_keyname SPACE");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,40 +1,43 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
char buffer[16];
size_t len;
plan_tests (44);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
key.type = TERMKEY_TYPE_UNICODE;
key.type = TERMKEY_TYPE_KEY;
key.code.codepoint = 'A';
key.modifiers = 0;
key.utf8[0] = 0;
key.multibyte[0] = 0;
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
is_int (len, 1, "length for unicode/A/0");
is_str (buffer, "A", "buffer for unicode/A/0");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_WRAPBRACKET);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_WRAPBRACKET);
is_int (len, 1, "length for unicode/A/0 wrapbracket");
is_str (buffer, "A", "buffer for unicode/A/0 wrapbracket");
key.type = TERMKEY_TYPE_UNICODE;
key.type = TERMKEY_TYPE_KEY;
key.code.codepoint = 'b';
key.modifiers = TERMKEY_KEYMOD_CTRL;
key.utf8[0] = 0;
key.multibyte[0] = 0;
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
is_int (len, 3, "length for unicode/b/CTRL");
is_str (buffer, "C-b", "buffer for unicode/b/CTRL");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_LONGMOD);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LONGMOD);
is_int (len, 6, "length for unicode/b/CTRL longmod");
is_str (buffer, "Ctrl-b", "buffer for unicode/b/CTRL longmod");
@ -49,36 +52,43 @@ int main(int argc, char *argv[])
is_str (buffer, "ctrl-b", "buffer for unicode/b/CTRL longmod|lowermod");
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_SPACEMOD|TERMKEY_FORMAT_LOWERMOD);
TERMKEY_FORMAT_LONGMOD | TERMKEY_FORMAT_SPACEMOD
| TERMKEY_FORMAT_LOWERMOD);
is_int (len, 6, "length for unicode/b/CTRL longmod|spacemod|lowermode");
is_str(buffer, "ctrl b", "buffer for unicode/b/CTRL longmod|spacemod|lowermode");
is_str (buffer, "ctrl b",
"buffer for unicode/b/CTRL longmod|spacemod|lowermode");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_CARETCTRL);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_CARETCTRL);
is_int (len, 2, "length for unicode/b/CTRL caretctrl");
is_str (buffer, "^B", "buffer for unicode/b/CTRL caretctrl");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_WRAPBRACKET);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_WRAPBRACKET);
is_int (len, 5, "length for unicode/b/CTRL wrapbracket");
is_str (buffer, "<C-b>", "buffer for unicode/b/CTRL wrapbracket");
key.type = TERMKEY_TYPE_UNICODE;
key.type = TERMKEY_TYPE_KEY;
key.code.codepoint = 'c';
key.modifiers = TERMKEY_KEYMOD_ALT;
key.utf8[0] = 0;
key.multibyte[0] = 0;
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
is_int (len, 3, "length for unicode/c/ALT");
is_str (buffer, "A-c", "buffer for unicode/c/ALT");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_LONGMOD);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LONGMOD);
is_int (len, 5, "length for unicode/c/ALT longmod");
is_str (buffer, "Alt-c", "buffer for unicode/c/ALT longmod");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_ALTISMETA);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_ALTISMETA);
is_int (len, 3, "length for unicode/c/ALT altismeta");
is_str (buffer, "M-c", "buffer for unicode/c/ALT altismeta");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_ALTISMETA);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_ALTISMETA);
is_int (len, 6, "length for unicode/c/ALT longmod|altismeta");
is_str (buffer, "Meta-c", "buffer for unicode/c/ALT longmod|altismeta");
@ -90,7 +100,8 @@ int main(int argc, char *argv[])
is_int (len, 2, "length for sym/Up/0");
is_str (buffer, "Up", "buffer for sym/Up/0");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_WRAPBRACKET);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_WRAPBRACKET);
is_int (len, 4, "length for sym/Up/0 wrapbracket");
is_str (buffer, "<Up>", "buffer for sym/Up/0 wrapbracket");
@ -102,11 +113,13 @@ int main(int argc, char *argv[])
is_int (len, 6, "length for sym/PageUp/0");
is_str (buffer, "PageUp", "buffer for sym/PageUp/0");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_LOWERSPACE);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LOWERSPACE);
is_int (len, 7, "length for sym/PageUp/0 lowerspace");
is_str (buffer, "page up", "buffer for sym/PageUp/0 lowerspace");
/* If size of buffer is too small, strfkey should return something consistent */
/* If size of buffer is too small,
* strfkey should return something consistent */
len = termkey_strfkey (tk, buffer, 4, &key, 0);
is_int (len, 6, "length for sym/PageUp/0");
is_str (buffer, "Pag", "buffer of len 4 for sym/PageUp/0");
@ -123,15 +136,16 @@ int main(int argc, char *argv[])
is_int (len, 2, "length for func/5/0");
is_str (buffer, "F5", "buffer for func/5/0");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_WRAPBRACKET);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_WRAPBRACKET);
is_int (len, 4, "length for func/5/0 wrapbracket");
is_str (buffer, "<F5>", "buffer for func/5/0 wrapbracket");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_LOWERSPACE);
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
TERMKEY_FORMAT_LOWERSPACE);
is_int (len, 2, "length for func/5/0 lowerspace");
is_str (buffer, "f5", "buffer for func/5/0 lowerspace");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,105 +1,142 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
const char *endp;
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; key.modifiers = -1; key.utf8[0] = 0; } while(0)
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; \
key.modifiers = -1; key.multibyte[0] = 0; } while (0)
plan_tests (62);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
CLEAR_KEY;
endp = termkey_strpkey (tk, "A", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/A/0");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type for unicode/A/0");
is_int (key.code.codepoint, 'A', "key.code.codepoint for unicode/A/0");
is_int (key.modifiers, 0, "key.modifiers for unicode/A/0");
is_str(key.utf8, "A", "key.utf8 for unicode/A/0");
is_str (key.multibyte, "A", "key.multibyte for unicode/A/0");
is_str (endp, "", "consumed entire input for unicode/A/0");
CLEAR_KEY;
endp = termkey_strpkey (tk, "A and more", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/A/0 trailing");
is_int(key.code.codepoint, 'A', "key.code.codepoint for unicode/A/0 trailing");
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/A/0 trailing");
is_int (key.code.codepoint, 'A',
"key.code.codepoint for unicode/A/0 trailing");
is_int (key.modifiers, 0, "key.modifiers for unicode/A/0 trailing");
is_str(key.utf8, "A", "key.utf8 for unicode/A/0 trailing");
is_str(endp, " and more", "points at string tail for unicode/A/0 trailing");
is_str (key.multibyte, "A", "key.multibyte for unicode/A/0 trailing");
is_str (endp, " and more",
"points at string tail for unicode/A/0 trailing");
CLEAR_KEY;
endp = termkey_strpkey (tk, "C-b", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/b/CTRL");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type for unicode/b/CTRL");
is_int (key.code.codepoint, 'b', "key.code.codepoint for unicode/b/CTRL");
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers for unicode/b/CTRL");
is_str(key.utf8, "b", "key.utf8 for unicode/b/CTRL");
is_int (key.modifiers, TERMKEY_KEYMOD_CTRL,
"key.modifiers for unicode/b/CTRL");
is_str (key.multibyte, "b", "key.multibyte for unicode/b/CTRL");
is_str (endp, "", "consumed entire input for unicode/b/CTRL");
CLEAR_KEY;
endp = termkey_strpkey (tk, "Ctrl-b", &key, TERMKEY_FORMAT_LONGMOD);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/b/CTRL longmod");
is_int(key.code.codepoint, 'b', "key.code.codepoint for unicode/b/CTRL longmod");
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers for unicode/b/CTRL longmod");
is_str(key.utf8, "b", "key.utf8 for unicode/b/CTRL longmod");
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/b/CTRL longmod");
is_int (key.code.codepoint, 'b',
"key.code.codepoint for unicode/b/CTRL longmod");
is_int (key.modifiers, TERMKEY_KEYMOD_CTRL,
"key.modifiers for unicode/b/CTRL longmod");
is_str (key.multibyte, "b", "key.multibyte for unicode/b/CTRL longmod");
is_str (endp, "", "consumed entire input for unicode/b/CTRL longmod");
CLEAR_KEY;
endp = termkey_strpkey (tk, "^B", &key, TERMKEY_FORMAT_CARETCTRL);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/b/CTRL caretctrl");
is_int(key.code.codepoint, 'b', "key.code.codepoint for unicode/b/CTRL caretctrl");
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers for unicode/b/CTRL caretctrl");
is_str(key.utf8, "b", "key.utf8 for unicode/b/CTRL caretctrl");
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/b/CTRL caretctrl");
is_int (key.code.codepoint, 'b',
"key.code.codepoint for unicode/b/CTRL caretctrl");
is_int (key.modifiers, TERMKEY_KEYMOD_CTRL,
"key.modifiers for unicode/b/CTRL caretctrl");
is_str (key.multibyte, "b", "key.multibyte for unicode/b/CTRL caretctrl");
is_str (endp, "", "consumed entire input for unicode/b/CTRL caretctrl");
CLEAR_KEY;
endp = termkey_strpkey (tk, "A-c", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/c/ALT");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type for unicode/c/ALT");
is_int (key.code.codepoint, 'c', "key.code.codepoint for unicode/c/ALT");
is_int(key.modifiers, TERMKEY_KEYMOD_ALT, "key.modifiers for unicode/c/ALT");
is_str(key.utf8, "c", "key.utf8 for unicode/c/ALT");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT,
"key.modifiers for unicode/c/ALT");
is_str (key.multibyte, "c", "key.multibyte for unicode/c/ALT");
is_str (endp, "", "consumed entire input for unicode/c/ALT");
CLEAR_KEY;
endp = termkey_strpkey (tk, "Alt-c", &key, TERMKEY_FORMAT_LONGMOD);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/c/ALT longmod");
is_int(key.code.codepoint, 'c', "key.code.codepoint for unicode/c/ALT longmod");
is_int(key.modifiers, TERMKEY_KEYMOD_ALT, "key.modifiers for unicode/c/ALT longmod");
is_str(key.utf8, "c", "key.utf8 for unicode/c/ALT longmod");
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/c/ALT longmod");
is_int (key.code.codepoint, 'c',
"key.code.codepoint for unicode/c/ALT longmod");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT,
"key.modifiers for unicode/c/ALT longmod");
is_str (key.multibyte, "c", "key.multibyte for unicode/c/ALT longmod");
is_str (endp, "", "consumed entire input for unicode/c/ALT longmod");
CLEAR_KEY;
endp = termkey_strpkey (tk, "M-c", &key, TERMKEY_FORMAT_ALTISMETA);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/c/ALT altismeta");
is_int(key.code.codepoint, 'c', "key.code.codepoint for unicode/c/ALT altismeta");
is_int(key.modifiers, TERMKEY_KEYMOD_ALT, "key.modifiers for unicode/c/ALT altismeta");
is_str(key.utf8, "c", "key.utf8 for unicode/c/ALT altismeta");
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/c/ALT altismeta");
is_int (key.code.codepoint, 'c',
"key.code.codepoint for unicode/c/ALT altismeta");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT,
"key.modifiers for unicode/c/ALT altismeta");
is_str (key.multibyte, "c", "key.multibyte for unicode/c/ALT altismeta");
is_str (endp, "", "consumed entire input for unicode/c/ALT altismeta");
CLEAR_KEY;
endp = termkey_strpkey(tk, "Meta-c", &key, TERMKEY_FORMAT_ALTISMETA|TERMKEY_FORMAT_LONGMOD);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/c/ALT altismeta+longmod");
is_int(key.code.codepoint, 'c', "key.code.codepoint for unicode/c/ALT altismeta+longmod");
is_int(key.modifiers, TERMKEY_KEYMOD_ALT, "key.modifiers for unicode/c/ALT altismeta+longmod");
is_str(key.utf8, "c", "key.utf8 for unicode/c/ALT altismeta+longmod");
is_str(endp, "", "consumed entire input for unicode/c/ALT altismeta+longmod");
endp = termkey_strpkey (tk, "Meta-c", &key,
TERMKEY_FORMAT_ALTISMETA | TERMKEY_FORMAT_LONGMOD);
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/c/ALT altismeta+longmod");
is_int (key.code.codepoint, 'c',
"key.code.codepoint for unicode/c/ALT altismeta+longmod");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT,
"key.modifiers for unicode/c/ALT altismeta+longmod");
is_str (key.multibyte, "c", "key.multibyte for unicode/c/ALT altismeta+longmod");
is_str (endp, "",
"consumed entire input for unicode/c/ALT altismeta+longmod");
CLEAR_KEY;
endp = termkey_strpkey(tk, "meta c", &key, TERMKEY_FORMAT_ALTISMETA|TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_SPACEMOD|TERMKEY_FORMAT_LOWERMOD);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for unicode/c/ALT altismeta+long/space+lowermod");
is_int(key.code.codepoint, 'c', "key.code.codepoint for unicode/c/ALT altismeta+long/space+lowermod");
is_int(key.modifiers, TERMKEY_KEYMOD_ALT, "key.modifiers for unicode/c/ALT altismeta+long/space+lowermod");
is_str(key.utf8, "c", "key.utf8 for unicode/c/ALT altismeta+long/space_lowermod");
is_str(endp, "", "consumed entire input for unicode/c/ALT altismeta+long/space+lowermod");
endp = termkey_strpkey (tk, "meta c", &key,
TERMKEY_FORMAT_ALTISMETA | TERMKEY_FORMAT_LONGMOD
| TERMKEY_FORMAT_SPACEMOD | TERMKEY_FORMAT_LOWERMOD);
is_int (key.type, TERMKEY_TYPE_KEY,
"key.type for unicode/c/ALT altismeta+long/space+lowermod");
is_int (key.code.codepoint, 'c',
"key.code.codepoint for unicode/c/ALT altismeta+long/space+lowermod");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT,
"key.modifiers for unicode/c/ALT altismeta+long/space+lowermod");
is_str (key.multibyte, "c",
"key.multibyte for unicode/c/ALT altismeta+long/space_lowermod");
is_str (endp, "",
"consumed entire input for unicode/c/ALT altismeta+long/space+lowermod");
CLEAR_KEY;
endp = termkey_strpkey(tk, "ctrl alt page up", &key, TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_SPACEMOD|TERMKEY_FORMAT_LOWERMOD|TERMKEY_FORMAT_LOWERSPACE);
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
is_int(key.code.sym, TERMKEY_SYM_PAGEUP, "key.code.codepoint for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
endp = termkey_strpkey (tk, "ctrl alt page up", &key,
TERMKEY_FORMAT_LONGMOD | TERMKEY_FORMAT_SPACEMOD
| TERMKEY_FORMAT_LOWERMOD | TERMKEY_FORMAT_LOWERSPACE);
is_int (key.type, TERMKEY_TYPE_KEYSYM,
"key.type for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
is_int (key.code.sym, TERMKEY_SYM_PAGEUP,
"key.code.codepoint for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
is_int (key.modifiers, TERMKEY_KEYMOD_ALT | TERMKEY_KEYMOD_CTRL,
"key.modifiers for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
is_str(endp, "", "consumed entire input for sym/PageUp/CTRL+ALT long/space/lowermod+lowerspace");
is_str (endp, "",
"consumed entire input for sym/PageUp/CTRL+ALT"
" long/space/lowermod+lowerspace");
CLEAR_KEY;
endp = termkey_strpkey (tk, "Up", &key, 0);
@ -116,6 +153,5 @@ int main(int argc, char *argv[])
is_str (endp, "", "consumed entire input for func/5/0");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,22 +1,23 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key1, key2;
termkey_t *tk;
termkey_key_t key1, key2;
plan_tests (12);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
key1.type = TERMKEY_TYPE_UNICODE;
key1.type = TERMKEY_TYPE_KEY;
key1.code.codepoint = 'A';
key1.modifiers = 0;
is_int (termkey_keycmp (tk, &key1, &key1), 0, "cmpkey same structure");
key2.type = TERMKEY_TYPE_UNICODE;
key2.type = TERMKEY_TYPE_KEY;
key2.code.codepoint = 'A';
key2.modifiers = 0;
@ -24,8 +25,10 @@ int main(int argc, char *argv[])
key2.modifiers = TERMKEY_KEYMOD_CTRL;
ok(termkey_keycmp(tk, &key1, &key2) < 0, "cmpkey orders CTRL after nomod");
ok(termkey_keycmp(tk, &key2, &key1) > 0, "cmpkey orders nomod before CTRL");
ok (termkey_keycmp (tk, &key1, &key2) < 0,
"cmpkey orders CTRL after nomod");
ok (termkey_keycmp (tk, &key2, &key1) > 0,
"cmpkey orders nomod before CTRL");
key2.code.codepoint = 'B';
key2.modifiers = 0;
@ -35,28 +38,35 @@ int main(int argc, char *argv[])
key1.modifiers = TERMKEY_KEYMOD_CTRL;
ok(termkey_keycmp(tk, &key1, &key2) < 0, "cmpkey orders nomod 'B' after CTRL 'A'");
ok(termkey_keycmp(tk, &key2, &key1) > 0, "cmpkey orders CTRL 'A' before nomod 'B'");
ok (termkey_keycmp (tk, &key1, &key2) < 0,
"cmpkey orders nomod 'B' after CTRL 'A'");
ok (termkey_keycmp (tk, &key2, &key1) > 0,
"cmpkey orders CTRL 'A' before nomod 'B'");
key2.type = TERMKEY_TYPE_KEYSYM;
key2.code.sym = TERMKEY_SYM_UP;
ok(termkey_keycmp(tk, &key1, &key2) < 0, "cmpkey orders KEYSYM after UNICODE");
ok(termkey_keycmp(tk, &key2, &key1) > 0, "cmpkey orders UNICODE before KEYSYM");
ok (termkey_keycmp (tk, &key1, &key2) < 0,
"cmpkey orders KEYSYM after KEY");
ok (termkey_keycmp (tk, &key2, &key1) > 0,
"cmpkey orders KEY before KEYSYM");
key1.type = TERMKEY_TYPE_KEYSYM;
key1.code.sym = TERMKEY_SYM_SPACE;
key1.modifiers = 0;
key2.type = TERMKEY_TYPE_UNICODE;
key2.type = TERMKEY_TYPE_KEY;
key2.code.codepoint = ' ';
key2.modifiers = 0;
is_int(termkey_keycmp(tk, &key1, &key2), 0, "cmpkey considers KEYSYM/SPACE and UNICODE/SP identical");
is_int (termkey_keycmp (tk, &key1, &key2), 0,
"cmpkey considers KEYSYM/SPACE and KEY/SP identical");
termkey_set_canonflags(tk, termkey_get_canonflags(tk) | TERMKEY_CANON_SPACESYMBOL);
is_int(termkey_keycmp(tk, &key1, &key2), 0, "cmpkey considers KEYSYM/SPACE and UNICODE/SP identical under SPACESYMBOL");
termkey_set_canonflags (tk,
termkey_get_canonflags (tk) | TERMKEY_CANON_SPACESYMBOL);
is_int (termkey_keycmp (tk, &key1, &key2), 0,
"cmpkey considers KEYSYM/SPACE and KEY/SP"
" identical under SPACESYMBOL");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,67 +1,74 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
const char *endp;
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; key.modifiers = -1; key.utf8[0] = 0; } while(0)
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; \
key.modifiers = -1; key.multibyte[0] = 0; } while (0)
plan_tests (26);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
CLEAR_KEY;
endp = termkey_strpkey (tk, " ", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for SP/unicode");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type for SP/unicode");
is_int (key.code.codepoint, ' ', "key.code.codepoint for SP/unicode");
is_int (key.modifiers, 0, "key.modifiers for SP/unicode");
is_str(key.utf8, " ", "key.utf8 for SP/unicode");
is_str (key.multibyte, " ", "key.multibyte for SP/unicode");
is_str (endp, "", "consumed entire input for SP/unicode");
CLEAR_KEY;
endp = termkey_strpkey (tk, "Space", &key, 0);
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type for Space/unicode");
is_int (key.type, TERMKEY_TYPE_KEY, "key.type for Space/unicode");
is_int (key.code.codepoint, ' ', "key.code.codepoint for Space/unicode");
is_int (key.modifiers, 0, "key.modifiers for Space/unicode");
is_str(key.utf8, " ", "key.utf8 for Space/unicode");
is_str (key.multibyte, " ", "key.multibyte for Space/unicode");
is_str (endp, "", "consumed entire input for Space/unicode");
termkey_set_canonflags(tk, termkey_get_canonflags(tk) | TERMKEY_CANON_SPACESYMBOL);
termkey_set_canonflags (tk,
termkey_get_canonflags (tk) | TERMKEY_CANON_SPACESYMBOL);
CLEAR_KEY;
endp = termkey_strpkey (tk, " ", &key, 0);
is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type for SP/symbol");
is_int(key.code.sym, TERMKEY_SYM_SPACE, "key.code.codepoint for SP/symbol");
is_int (key.code.sym, TERMKEY_SYM_SPACE,
"key.code.codepoint for SP/symbol");
is_int (key.modifiers, 0, "key.modifiers for SP/symbol");
is_str (endp, "", "consumed entire input for SP/symbol");
CLEAR_KEY;
endp = termkey_strpkey (tk, "Space", &key, 0);
is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type for Space/symbol");
is_int(key.code.sym, TERMKEY_SYM_SPACE, "key.code.codepoint for Space/symbol");
is_int (key.code.sym, TERMKEY_SYM_SPACE,
"key.code.codepoint for Space/symbol");
is_int (key.modifiers, 0, "key.modifiers for Space/symbol");
is_str (endp, "", "consumed entire input for Space/symbol");
CLEAR_KEY;
endp = termkey_strpkey (tk, "DEL", &key, 0);
is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type for Del/unconverted");
is_int(key.code.sym, TERMKEY_SYM_DEL, "key.code.codepoint for Del/unconverted");
is_int (key.code.sym, TERMKEY_SYM_DEL,
"key.code.codepoint for Del/unconverted");
is_int (key.modifiers, 0, "key.modifiers for Del/unconverted");
is_str (endp, "", "consumed entire input for Del/unconverted");
termkey_set_canonflags(tk, termkey_get_canonflags(tk) | TERMKEY_CANON_DELBS);
termkey_set_canonflags (tk,
termkey_get_canonflags (tk) | TERMKEY_CANON_DELBS);
CLEAR_KEY;
endp = termkey_strpkey (tk, "DEL", &key, 0);
is_int (key.type, TERMKEY_TYPE_KEYSYM, "key.type for Del/as-backspace");
is_int(key.code.sym, TERMKEY_SYM_BACKSPACE, "key.code.codepoint for Del/as-backspace");
is_int (key.code.sym, TERMKEY_SYM_BACKSPACE,
"key.code.codepoint for Del/as-backspace");
is_int (key.modifiers, 0, "key.modifiers for Del/as-backspace");
is_str (endp, "", "consumed entire input for Del/as-backspace");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,28 +1,31 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
TermKeyMouseEvent ev;
termkey_t *tk;
termkey_key_t key;
termkey_mouse_event_t ev;
int button, line, col;
char buffer[32];
size_t len;
plan_tests (60);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
termkey_push_bytes (tk, "\e[M !!", 6);
key.type = -1;
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mouse press");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mouse press");
is_int (key.type, TERMKEY_TYPE_MOUSE, "key.type for mouse press");
ev = -1; button = -1; line = -1; col = -1;
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_PRESS, "mouse event for press");
is_int (button, 1, "mouse button for press");
@ -34,7 +37,8 @@ int main(int argc, char *argv[])
is_int (len, 13, "string length for press");
is_str (buffer, "MousePress(1)", "string buffer for press");
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_MOUSE_POS);
len = termkey_strfkey (tk, buffer, sizeof buffer,
&key, TERMKEY_FORMAT_MOUSE_POS);
is_int (len, 21, "string length for press");
is_str (buffer, "MousePress(1) @ (1,1)", "string buffer for press");
@ -43,7 +47,8 @@ int main(int argc, char *argv[])
key.type = -1;
ev = -1; button = -1; line = -1; col = -1;
termkey_getkey (tk, &key);
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_DRAG, "mouse event for drag");
is_int (button, 1, "mouse button for drag");
@ -56,7 +61,8 @@ int main(int argc, char *argv[])
key.type = -1;
ev = -1; button = -1; line = -1; col = -1;
termkey_getkey (tk, &key);
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_RELEASE, "mouse event for release");
is_int (line, 1, "mouse line for release");
@ -68,7 +74,8 @@ int main(int argc, char *argv[])
key.type = -1;
ev = -1; button = -1; line = -1; col = -1;
termkey_getkey (tk, &key);
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_PRESS, "mouse event for Ctrl-press");
is_int (button, 1, "mouse button for Ctrl-press");
@ -84,11 +91,14 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[0;20;20M", 10);
key.type = -1;
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mouse press rxvt protocol");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mouse press rxvt protocol");
is_int(key.type, TERMKEY_TYPE_MOUSE, "key.type for mouse press rxvt protocol");
is_int (key.type, TERMKEY_TYPE_MOUSE,
"key.type for mouse press rxvt protocol");
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_PRESS, "mouse event for press rxvt protocol");
is_int (button, 1, "mouse button for press rxvt protocol");
@ -98,12 +108,15 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[3;20;20M", 10);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mouse release rxvt protocol");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mouse release rxvt protocol");
is_int(key.type, TERMKEY_TYPE_MOUSE, "key.type for mouse release rxvt protocol");
is_int (key.type, TERMKEY_TYPE_MOUSE,
"key.type for mouse release rxvt protocol");
ev = -1; button = -1; line = -1; col = -1;
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_RELEASE, "mouse event for release rxvt protocol");
is_int (line, 20, "mouse line for release rxvt protocol");
@ -114,12 +127,15 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[<0;30;30M", 11);
key.type = -1;
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mouse press SGR encoding");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mouse press SGR encoding");
is_int(key.type, TERMKEY_TYPE_MOUSE, "key.type for mouse press SGR encoding");
is_int (key.type, TERMKEY_TYPE_MOUSE,
"key.type for mouse press SGR encoding");
ev = -1; button = -1; line = -1; col = -1;
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_PRESS, "mouse event for press SGR");
is_int (button, 1, "mouse button for press SGR");
@ -130,12 +146,15 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[<0;30;30m", 11);
key.type = -1;
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mouse release SGR encoding");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mouse release SGR encoding");
is_int(key.type, TERMKEY_TYPE_MOUSE, "key.type for mouse release SGR encoding");
is_int (key.type, TERMKEY_TYPE_MOUSE,
"key.type for mouse release SGR encoding");
ev = -1; button = -1; line = -1; col = -1;
is_int(termkey_interpret_mouse(tk, &key, &ev, &button, &line, &col), TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (termkey_interpret_mouse (tk, &key, &ev, &button, &line, &col),
TERMKEY_RES_KEY, "interpret_mouse yields RES_KEY");
is_int (ev, TERMKEY_MOUSE_RELEASE, "mouse event for release SGR");

View File

@ -3,36 +3,36 @@
int main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
int line, col;
plan_tests (8);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
termkey_push_bytes (tk, "\e[?15;7R", 8);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for position report");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for position report");
is_int (key.type, TERMKEY_TYPE_POSITION, "key.type for position report");
is_int(termkey_interpret_position(tk, &key, &line, &col), TERMKEY_RES_KEY, "interpret_position yields RES_KEY");
is_int (termkey_interpret_position (tk, &key, &line, &col), TERMKEY_RES_KEY,
"interpret_position yields RES_KEY");
is_int (line, 15, "line for position report");
is_int (col, 7, "column for position report");
/* A plain CSI R is likely to be <F3> though.
* This is tricky :/
*/
/* A plain CSI R is likely to be <F3> though. This is tricky :/ */
termkey_push_bytes (tk, "\e[R", 3);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for <F3>");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for <F3>");
is_int (key.type, TERMKEY_TYPE_FUNCTION, "key.type for <F3>");
is_int (key.code.number, 3, "key.code.number for <F3>");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,23 +1,26 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
int initial, mode, value;
plan_tests (12);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
termkey_push_bytes (tk, "\e[?1;2$y", 8);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mode report");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mode report");
is_int (key.type, TERMKEY_TYPE_MODEREPORT, "key.type for mode report");
is_int(termkey_interpret_modereport(tk, &key, &initial, &mode, &value), TERMKEY_RES_KEY, "interpret_modereoprt yields RES_KEY");
is_int (termkey_interpret_modereport (tk, &key, &initial, &mode, &value),
TERMKEY_RES_KEY, "interpret_modereoprt yields RES_KEY");
is_int (initial, '?', "initial indicator from mode report");
is_int (mode, 1, "mode number from mode report");
@ -25,17 +28,18 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[4;1$y", 7);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for mode report");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for mode report");
is_int (key.type, TERMKEY_TYPE_MODEREPORT, "key.type for mode report");
is_int(termkey_interpret_modereport(tk, &key, &initial, &mode, &value), TERMKEY_RES_KEY, "interpret_modereoprt yields RES_KEY");
is_int (termkey_interpret_modereport (tk, &key, &initial, &mode, &value),
TERMKEY_RES_KEY, "interpret_modereoprt yields RES_KEY");
is_int (initial, 0, "initial indicator from mode report");
is_int (mode, 4, "mode number from mode report");
is_int (value, 1, "mode value from mode report");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -1,25 +1,28 @@
#include "../termkey.h"
#include "taplib.h"
int main(int argc, char *argv[])
int
main (int argc, char *argv[])
{
TermKey *tk;
TermKeyKey key;
termkey_t *tk;
termkey_key_t key;
long args[16];
size_t nargs = 16;
unsigned long command;
plan_tests (15);
tk = termkey_new_abstract("vt100", 0);
tk = termkey_new_abstract ("vt100", NULL, 0);
termkey_push_bytes (tk, "\e[5;25v", 7);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for CSI v");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for CSI v");
is_int (key.type, TERMKEY_TYPE_UNKNOWN_CSI, "key.type for unknown CSI");
is_int(termkey_interpret_csi(tk, &key, args, &nargs, &command), TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int (termkey_interpret_csi (tk, &key, args, &nargs, &command),
TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int (nargs, 2, "nargs for unknown CSI");
is_int (args[0], 5, "args[0] for unknown CSI");
@ -28,19 +31,22 @@ int main(int argc, char *argv[])
termkey_push_bytes (tk, "\e[?w", 4);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for CSI ? w");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for CSI ? w");
is_int (key.type, TERMKEY_TYPE_UNKNOWN_CSI, "key.type for unknown CSI");
is_int(termkey_interpret_csi(tk, &key, args, &nargs, &command), TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int(command, '?'<<8 | 'w', "command for unknown CSI");
is_int (termkey_interpret_csi (tk, &key, args, &nargs, &command),
TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int (command, ('?' << 8) | 'w', "command for unknown CSI");
termkey_push_bytes (tk, "\e[?$x", 5);
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY for CSI ? $x");
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
"getkey yields RES_KEY for CSI ? $x");
is_int (key.type, TERMKEY_TYPE_UNKNOWN_CSI, "key.type for unknown CSI");
is_int(termkey_interpret_csi(tk, &key, args, &nargs, &command), TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int(command, '$'<<16 | '?'<<8 | 'x', "command for unknown CSI");
is_int (termkey_interpret_csi (tk, &key, args, &nargs, &command),
TERMKEY_RES_KEY, "interpret_csi yields RES_KEY");
is_int (command, ('$' << 16) | ('?' << 8) | 'x', "command for unknown CSI");
termkey_destroy (tk);
return exit_status ();
}

View File

@ -4,26 +4,30 @@
#include <stdarg.h>
#include <string.h>
static int nexttest = 1;
static int _exit_status = 0;
static int g_nexttest = 1;
static int g_exit_status = 0;
void plan_tests(int n)
void
plan_tests (int n)
{
printf ("1..%d\n", n);
}
void pass(char *name)
void
pass (char *name)
{
printf("ok %d - %s\n", nexttest++, name);
printf ("ok %d - %s\n", g_nexttest++, name);
}
void fail(char *name)
void
fail (char *name)
{
printf("not ok %d - %s\n", nexttest++, name);
_exit_status = 1;
printf ("not ok %d - %s\n", g_nexttest++, name);
g_exit_status = 1;
}
void ok(int cmp, char *name)
void
ok (int cmp, char *name)
{
if (cmp)
pass (name);
@ -31,7 +35,8 @@ void ok(int cmp, char *name)
fail (name);
}
void diag(char *fmt, ...)
void
diag (char *fmt, ...)
{
va_list args;
va_start (args, fmt);
@ -43,27 +48,32 @@ void diag(char *fmt, ...)
va_end (args);
}
void is_int(int got, int expect, char *name)
void
is_int (int got, int expect, char *name)
{
if (got == expect)
ok (1, name);
else {
else
{
ok (0, name);
diag ("got %d expected %d", got, expect);
}
}
void is_str(const char *got, const char *expect, char *name)
void
is_str (const char *got, const char *expect, char *name)
{
if (strcmp (got, expect) == 0)
ok (1, name);
else {
else
{
ok (0, name);
diag ("got '%s' expected '%s'", got, expect);
}
}
int exit_status(void)
int
exit_status(void)
{
return _exit_status;
return g_exit_status;
}