parent
36bc6cd095
commit
3465d5553f
@ -1,75 +1,92 @@
|
||||
#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);
|
||||
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_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 (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);
|
||||
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.code.codepoint, 'a', "key.code.codepoint after C-a");
|
||||
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers 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);
|
||||
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");
|
||||
is_int(key.modifiers, 0, "key.modifiers 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");
|
||||
is_int (key.modifiers, 0, "key.modifiers after Up");
|
||||
|
||||
is_int(termkey_push_bytes(tk, "\033O", 2), 2, "push_bytes returns 2");
|
||||
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);
|
||||
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 (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);
|
||||
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);
|
||||
termkey_destroy (tk);
|
||||
|
||||
return exit_status();
|
||||
return exit_status ();
|
||||
}
|
||||
|
@ -1,141 +1,188 @@
|
||||
#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);
|
||||
tk = termkey_new_abstract ("vt100", "UTF-8", 0);
|
||||
|
||||
termkey_push_bytes(tk, "a", 1);
|
||||
termkey_push_bytes (tk, "a", 1);
|
||||
|
||||
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");
|
||||
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");
|
||||
|
||||
/* 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) */
|
||||
/* 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) */
|
||||
|
||||
termkey_push_bytes(tk, "\xC2\xA0", 2);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 2 low");
|
||||
is_int(key.code.codepoint, 0x00A0, "key.code.codepoint 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);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 2 high");
|
||||
is_int(key.code.codepoint, 0x07FF, "key.code.codepoint 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");
|
||||
|
||||
/* 3-byte UTF-8 range is U+0800 (0xE0 0xA0 0x80) to U+FFFD (0xEF 0xBF 0xBD) */
|
||||
/* 3-byte UTF-8 range is U+0800 (0xE0 0xA0 0x80) to U+FFFD (0xEF 0xBF 0xBD) */
|
||||
|
||||
termkey_push_bytes(tk, "\xE0\xA0\x80", 3);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 3 low");
|
||||
is_int(key.code.codepoint, 0x0800, "key.code.codepoint 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);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 3 high");
|
||||
is_int(key.code.codepoint, 0xFFFD, "key.code.codepoint 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");
|
||||
|
||||
/* 4-byte UTF-8 range is U+10000 (0xF0 0x90 0x80 0x80) to U+10FFFF (0xF4 0x8F 0xBF 0xBF) */
|
||||
/* 4-byte UTF-8 range is U+10000 (0xF0 0x90 0x80 0x80) to U+10FFFF (0xF4 0x8F 0xBF 0xBF) */
|
||||
|
||||
termkey_push_bytes(tk, "\xF0\x90\x80\x80", 4);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 4 low");
|
||||
is_int(key.code.codepoint, 0x10000, "key.code.codepoint 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);
|
||||
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(key.type, TERMKEY_TYPE_KEY, "key.type UTF-8 4 high");
|
||||
is_int(key.code.codepoint, 0x10FFFF, "key.code.codepoint 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");
|
||||
|
||||
/* Invalid continuations */
|
||||
#if 0
|
||||
/* XXX: With the move to iconv, this has changed significantly. */
|
||||
|
||||
termkey_push_bytes(tk, "\xC2!", 2);
|
||||
/* 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);
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
termkey_push_bytes (tk, "\xF0!", 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");
|
||||
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
/* Partials */
|
||||
|
||||
termkey_push_bytes(tk, "\xC2", 1);
|
||||
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");
|
||||
|
||||
termkey_push_bytes(tk, "\xE0", 1);
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
termkey_push_bytes(tk, "\xF0", 1);
|
||||
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");
|
||||
|
||||
termkey_push_bytes(tk, "\x80", 1);
|
||||
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");
|
||||
|
||||
termkey_destroy(tk);
|
||||
|
||||
return exit_status();
|
||||
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");
|
||||
|
||||
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");
|
||||
#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");
|
||||
|
||||
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");
|
||||
|
||||
termkey_push_bytes (tk, "\xE0", 1);
|
||||
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");
|
||||
|
||||
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");
|
||||
|
||||
termkey_push_bytes (tk, "\xF0", 1);
|
||||
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");
|
||||
|
||||
termkey_push_bytes (tk, "\x80", 1);
|
||||
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");
|
||||
|
||||
termkey_destroy (tk);
|
||||
return exit_status ();
|
||||
}
|
||||
|
@ -1,38 +1,40 @@
|
||||
#include "../termkey.h"
|
||||
#include "taplib.h"
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
int
|
||||
main (int argc, char *argv[])
|
||||
{
|
||||
TermKey *tk;
|
||||
TermKeySym sym;
|
||||
const char *end;
|
||||
termkey_t *tk;
|
||||
termkey_sym_t sym;
|
||||
const char *end;
|
||||
|
||||
plan_tests(10);
|
||||
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");
|
||||
sym = termkey_keyname2sym (tk, "Space");
|
||||
is_int (sym, TERMKEY_SYM_SPACE, "keyname2sym Space");
|
||||
|
||||
sym = termkey_keyname2sym(tk, "SomeUnknownKey");
|
||||
is_int(sym, TERMKEY_SYM_UNKNOWN, "keyname2sym SomeUnknownKey");
|
||||
sym = termkey_keyname2sym (tk, "SomeUnknownKey");
|
||||
is_int (sym, TERMKEY_SYM_UNKNOWN, "keyname2sym SomeUnknownKey");
|
||||
|
||||
end = termkey_lookup_keyname(tk, "Up", &sym);
|
||||
ok(!!end, "termkey_get_keyname Up returns non-NULL");
|
||||
is_str(end, "", "termkey_get_keyname Up return points at endofstring");
|
||||
is_int(sym, TERMKEY_SYM_UP, "termkey_get_keyname Up yields Up symbol");
|
||||
end = termkey_lookup_keyname (tk, "Up", &sym);
|
||||
ok (!!end, "termkey_get_keyname Up returns non-NULL");
|
||||
is_str (end, "", "termkey_get_keyname Up return points at endofstring");
|
||||
is_int (sym, TERMKEY_SYM_UP, "termkey_get_keyname Up yields Up symbol");
|
||||
|
||||
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");
|
||||
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");
|
||||
|
||||
end = termkey_lookup_keyname(tk, "SomeUnknownKey", &sym);
|
||||
ok(!end, "termkey_get_keyname SomeUnknownKey returns NULL");
|
||||
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();
|
||||
termkey_destroy (tk);
|
||||
return exit_status ();
|
||||
}
|
||||
|
@ -1,137 +1,151 @@
|
||||
#include "../termkey.h"
|
||||
#include "taplib.h"
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
int
|
||||
main (int argc, char *argv[])
|
||||
{
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
char buffer[16];
|
||||
size_t len;
|
||||
|
||||
plan_tests(44);
|
||||
|
||||
tk = termkey_new_abstract("vt100", 0);
|
||||
|
||||
key.type = TERMKEY_TYPE_UNICODE;
|
||||
key.code.codepoint = 'A';
|
||||
key.modifiers = 0;
|
||||
key.utf8[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);
|
||||
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.code.codepoint = 'b';
|
||||
key.modifiers = TERMKEY_KEYMOD_CTRL;
|
||||
key.utf8[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);
|
||||
is_int(len, 6, "length for unicode/b/CTRL longmod");
|
||||
is_str(buffer, "Ctrl-b", "buffer for unicode/b/CTRL longmod");
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key,
|
||||
TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_SPACEMOD);
|
||||
is_int(len, 6, "length for unicode/b/CTRL longmod|spacemod");
|
||||
is_str(buffer, "Ctrl b", "buffer for unicode/b/CTRL longmod|spacemod");
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key,
|
||||
TERMKEY_FORMAT_LONGMOD|TERMKEY_FORMAT_LOWERMOD);
|
||||
is_int(len, 6, "length for unicode/b/CTRL longmod|lowermod");
|
||||
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);
|
||||
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");
|
||||
|
||||
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);
|
||||
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.code.codepoint = 'c';
|
||||
key.modifiers = TERMKEY_KEYMOD_ALT;
|
||||
key.utf8[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);
|
||||
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);
|
||||
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);
|
||||
is_int(len, 6, "length for unicode/c/ALT longmod|altismeta");
|
||||
is_str(buffer, "Meta-c", "buffer for unicode/c/ALT longmod|altismeta");
|
||||
|
||||
key.type = TERMKEY_TYPE_KEYSYM;
|
||||
key.code.sym = TERMKEY_SYM_UP;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
is_int(len, 4, "length for sym/Up/0 wrapbracket");
|
||||
is_str(buffer, "<Up>", "buffer for sym/Up/0 wrapbracket");
|
||||
|
||||
key.type = TERMKEY_TYPE_KEYSYM;
|
||||
key.code.sym = TERMKEY_SYM_PAGEUP;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
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 */
|
||||
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");
|
||||
|
||||
len = termkey_strfkey(tk, buffer, 4, &key, TERMKEY_FORMAT_LOWERSPACE);
|
||||
is_int(len, 7, "length for sym/PageUp/0 lowerspace");
|
||||
is_str(buffer, "pag", "buffer of len 4 for sym/PageUp/0 lowerspace");
|
||||
|
||||
key.type = TERMKEY_TYPE_FUNCTION;
|
||||
key.code.number = 5;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
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);
|
||||
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();
|
||||
termkey_t *tk;
|
||||
termkey_key_t key;
|
||||
char buffer[16];
|
||||
size_t len;
|
||||
|
||||
plan_tests (44);
|
||||
|
||||
tk = termkey_new_abstract ("vt100", NULL, 0);
|
||||
|
||||
key.type = TERMKEY_TYPE_KEY;
|
||||
key.code.codepoint = 'A';
|
||||
key.modifiers = 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);
|
||||
is_int (len, 1, "length for unicode/A/0 wrapbracket");
|
||||
is_str (buffer, "A", "buffer for unicode/A/0 wrapbracket");
|
||||
|
||||
key.type = TERMKEY_TYPE_KEY;
|
||||
key.code.codepoint = 'b';
|
||||
key.modifiers = TERMKEY_KEYMOD_CTRL;
|
||||
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);
|
||||
is_int (len, 6, "length for unicode/b/CTRL longmod");
|
||||
is_str (buffer, "Ctrl-b", "buffer for unicode/b/CTRL longmod");
|
||||
|
||||
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
|
||||
TERMKEY_FORMAT_LONGMOD | TERMKEY_FORMAT_SPACEMOD);
|
||||
is_int (len, 6, "length for unicode/b/CTRL longmod|spacemod");
|
||||
is_str (buffer, "Ctrl b", "buffer for unicode/b/CTRL longmod|spacemod");
|
||||
|
||||
len = termkey_strfkey (tk, buffer, sizeof buffer, &key,
|
||||
TERMKEY_FORMAT_LONGMOD | TERMKEY_FORMAT_LOWERMOD);
|
||||
is_int (len, 6, "length for unicode/b/CTRL longmod|lowermod");
|
||||
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);
|
||||
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");
|
||||
|
||||
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);
|
||||
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_KEY;
|
||||
key.code.codepoint = 'c';
|
||||
key.modifiers = TERMKEY_KEYMOD_ALT;
|
||||
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);
|
||||
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);
|
||||
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);
|
||||
is_int (len, 6, "length for unicode/c/ALT longmod|altismeta");
|
||||
is_str (buffer, "Meta-c", "buffer for unicode/c/ALT longmod|altismeta");
|
||||
|
||||
key.type = TERMKEY_TYPE_KEYSYM;
|
||||
key.code.sym = TERMKEY_SYM_UP;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
is_int (len, 4, "length for sym/Up/0 wrapbracket");
|
||||
is_str (buffer, "<Up>", "buffer for sym/Up/0 wrapbracket");
|
||||
|
||||
key.type = TERMKEY_TYPE_KEYSYM;
|
||||
key.code.sym = TERMKEY_SYM_PAGEUP;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
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 */
|
||||
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");
|
||||
|
||||
len = termkey_strfkey (tk, buffer, 4, &key, TERMKEY_FORMAT_LOWERSPACE);
|
||||
is_int (len, 7, "length for sym/PageUp/0 lowerspace");
|
||||
is_str (buffer, "pag", "buffer of len 4 for sym/PageUp/0 lowerspace");
|
||||
|
||||
key.type = TERMKEY_TYPE_FUNCTION;
|
||||
key.code.number = 5;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey (tk, buffer, sizeof buffer, &key, 0);
|
||||
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);
|
||||
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);
|
||||
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 ();
|
||||
}
|
||||
|
@ -1,121 +1,157 @@
|
||||
#include "../termkey.h"
|
||||
#include "taplib.h"
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
int
|
||||
main (int argc, char *argv[])
|
||||
{
|
||||
TermKey *tk;
|
||||
TermKeyKey key;
|
||||
const char *endp;
|
||||
|
||||
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; key.modifiers = -1; key.utf8[0] = 0; } while(0)
|
||||
|
||||
plan_tests(62);
|
||||
|
||||
tk = termkey_new_abstract("vt100", 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.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(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.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");
|
||||
|
||||
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.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_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_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_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.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_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_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_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");
|
||||
|
||||
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");
|
||||
|
||||
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");
|
||||
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");
|
||||
|
||||
CLEAR_KEY;
|
||||
endp = termkey_strpkey(tk, "Up", &key, 0);
|
||||
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type for sym/Up/0");
|
||||
is_int(key.code.sym, TERMKEY_SYM_UP, "key.code.codepoint for sym/Up/0");
|
||||
is_int(key.modifiers, 0, "key.modifiers for sym/Up/0");
|
||||
is_str(endp, "", "consumed entire input for sym/Up/0");
|
||||
|
||||
CLEAR_KEY;
|
||||
endp = termkey_strpkey(tk, "F5", &key, 0);
|
||||
is_int(key.type, TERMKEY_TYPE_FUNCTION, "key.type for func/5/0");
|
||||
is_int(key.code.number, 5, "key.code.number for func/5/0");
|
||||
is_int(key.modifiers, 0, "key.modifiers for func/5/0");
|
||||
is_str(endp, "", "consumed entire input for func/5/0");
|
||||
|
||||
termkey_destroy(tk);
|
||||
|
||||
return exit_status();
|
||||
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.multibyte[0] = 0; } while (0)
|
||||
|
||||
plan_tests (62);
|
||||
|
||||
tk = termkey_new_abstract ("vt100", NULL, 0);
|
||||
|
||||
CLEAR_KEY;
|
||||
endp = termkey_strpkey (tk, "A", &key, 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.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_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.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_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.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_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_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_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.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_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_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_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_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 |