2011-03-31 13:47:09 +02:00
|
|
|
#include <stdio.h>
|
2011-03-31 14:51:21 +02:00
|
|
|
#include "../termkey.h"
|
2011-03-31 13:47:09 +02:00
|
|
|
#include "taplib.h"
|
|
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
|
|
{
|
|
|
|
int fd[2];
|
|
|
|
TermKey *tk;
|
|
|
|
TermKeyKey key;
|
|
|
|
|
2012-01-18 11:04:15 +01:00
|
|
|
plan_tests(29);
|
2011-03-31 13:47:09 +02:00
|
|
|
|
|
|
|
pipe(fd);
|
|
|
|
|
|
|
|
/* Sanitise this just in case */
|
|
|
|
putenv("TERM=vt100");
|
|
|
|
|
|
|
|
tk = termkey_new(fd[0], TERMKEY_FLAG_NOTERMIOS);
|
|
|
|
|
2012-01-18 11:04:15 +01:00
|
|
|
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free initially 256");
|
|
|
|
|
2011-03-31 13:47:09 +02:00
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE when empty");
|
|
|
|
|
|
|
|
write(fd[1], "h", 1);
|
|
|
|
|
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE before advisereadable");
|
|
|
|
|
|
|
|
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after h");
|
|
|
|
|
2012-01-18 11:04:15 +01:00
|
|
|
is_int(termkey_get_buffer_remaining(tk), 255, "buffer free 255 after advisereadable");
|
|
|
|
|
2011-03-31 13:47:09 +02:00
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after h");
|
|
|
|
|
|
|
|
is_int(key.type, TERMKEY_TYPE_UNICODE, "key.type after h");
|
|
|
|
is_int(key.code.number, 'h', "key.code.number after h");
|
|
|
|
is_int(key.modifiers, 0, "key.modifiers after h");
|
|
|
|
is_str(key.utf8, "h", "key.utf8 after h");
|
|
|
|
|
2012-01-18 11:04:15 +01:00
|
|
|
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after getkey");
|
|
|
|
|
2011-03-31 13:47:09 +02:00
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_NONE, "getkey yields RES_NONE a second time");
|
|
|
|
|
|
|
|
write(fd[1], "\x01", 1);
|
|
|
|
|
|
|
|
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after C-a");
|
|
|
|
|
|
|
|
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.number, 'a', "key.code.number after C-a");
|
|
|
|
is_int(key.modifiers, TERMKEY_KEYMOD_CTRL, "key.modifiers after C-a");
|
|
|
|
|
|
|
|
write(fd[1], "\eOA", 3);
|
|
|
|
|
|
|
|
is_int(termkey_advisereadable(tk), TERMKEY_RES_AGAIN, "advisereadable yields RES_AGAIN after Up");
|
|
|
|
|
|
|
|
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");
|
|
|
|
|
2012-01-18 11:04:15 +01:00
|
|
|
write(fd[1], "\eO", 2);
|
|
|
|
termkey_advisereadable(tk);
|
|
|
|
|
|
|
|
is_int(termkey_get_buffer_remaining(tk), 254, "buffer free 254 after partial write");
|
|
|
|
|
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_AGAIN, "getkey yields RES_AGAIN after partial write");
|
|
|
|
|
|
|
|
write(fd[1], "C", 1);
|
|
|
|
termkey_advisereadable(tk);
|
|
|
|
|
|
|
|
is_int(termkey_getkey(tk, &key), TERMKEY_RES_KEY, "getkey yields RES_KEY after Right completion");
|
|
|
|
|
|
|
|
is_int(key.type, TERMKEY_TYPE_KEYSYM, "key.type after Right");
|
|
|
|
is_int(key.code.sym, TERMKEY_SYM_RIGHT, "key.code.sym after Right");
|
|
|
|
is_int(key.modifiers, 0, "key.modifiers after Right");
|
|
|
|
|
|
|
|
is_int(termkey_get_buffer_remaining(tk), 256, "buffer free 256 after completion");
|
|
|
|
|
2011-03-31 13:47:09 +02:00
|
|
|
termkey_destroy(tk);
|
|
|
|
|
|
|
|
return exit_status();
|
|
|
|
}
|