2012-01-18 14:39:50 +01:00
|
|
|
#include <stdio.h>
|
2012-03-08 22:31:16 +01:00
|
|
|
#include <errno.h>
|
2012-01-18 14:39:50 +01:00
|
|
|
#include "../termkey.h"
|
|
|
|
#include "taplib.h"
|
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
int
|
|
|
|
main (int argc, char *argv[])
|
2012-01-18 14:39:50 +01:00
|
|
|
{
|
2014-09-28 05:56:13 +02:00
|
|
|
int fd[2];
|
|
|
|
termkey_t *tk;
|
|
|
|
termkey_key_t key;
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
plan_tests (21);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
/* We'll need a real filehandle we can write/read.
|
|
|
|
* pipe () can make us one */
|
|
|
|
pipe (fd);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
/* Sanitise this just in case */
|
|
|
|
putenv ("TERM=vt100");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
tk = termkey_new (fd[0], NULL, TERMKEY_FLAG_NOTERMIOS);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_get_buffer_remaining (tk), 256,
|
|
|
|
"buffer free initially 256");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
|
|
|
|
"getkey yields RES_NONE when empty");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
write (fd[1], "h", 1);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
|
|
|
|
"getkey yields RES_NONE before advisereadable");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_advisereadable (tk), TERMKEY_RES_AGAIN,
|
|
|
|
"advisereadable yields RES_AGAIN after h");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_get_buffer_remaining (tk), 255,
|
|
|
|
"buffer free 255 after advisereadable");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
|
|
|
|
"getkey yields RES_KEY after h");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
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");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_get_buffer_remaining (tk), 256,
|
|
|
|
"buffer free 256 after getkey");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_NONE,
|
|
|
|
"getkey yields RES_NONE a second time");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
write (fd[1], "\033O", 2);
|
|
|
|
termkey_advisereadable (tk);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_get_buffer_remaining (tk), 254,
|
|
|
|
"buffer free 254 after partial write");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_AGAIN,
|
|
|
|
"getkey yields RES_AGAIN after partial write");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
write (fd[1], "C", 1);
|
|
|
|
termkey_advisereadable (tk);
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_KEY,
|
|
|
|
"getkey yields RES_KEY after Right completion");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
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");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_get_buffer_remaining (tk), 256,
|
|
|
|
"buffer free 256 after completion");
|
2012-01-18 14:39:50 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
termkey_stop (tk);
|
2012-03-08 22:31:16 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
is_int (termkey_getkey (tk, &key), TERMKEY_RES_ERROR,
|
|
|
|
"getkey yields RES_ERROR after termkey_stop ()");
|
|
|
|
is_int (errno, EINVAL, "getkey error is EINVAL");
|
2012-03-08 22:31:16 +01:00
|
|
|
|
2014-09-28 05:56:13 +02:00
|
|
|
termkey_destroy (tk);
|
|
|
|
return exit_status ();
|
2012-01-18 14:39:50 +01:00
|
|
|
}
|