From 5692f32bcfa049fc2b5555b5a883045b217349b9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C5=99emysl=20Janouch?= Date: Thu, 9 Oct 2014 23:47:24 +0200 Subject: CMake-ify, rename to termkey2 for the time being --- tests/31position.c | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 tests/31position.c (limited to 'tests/31position.c') diff --git a/tests/31position.c b/tests/31position.c new file mode 100644 index 0000000..a62be7a --- /dev/null +++ b/tests/31position.c @@ -0,0 +1,38 @@ +#include "../termkey.h" +#include "taplib.h" + +int main (int argc, char *argv[]) +{ + termkey_t *tk; + termkey_key_t key; + int line, col; + + plan_tests (8); + + 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 (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 (line, 15, "line for position report"); + is_int (col, 7, "column for position report"); + + /* A plain CSI R is likely to be 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 "); + + is_int (key.type, TERMKEY_TYPE_FUNCTION, "key.type for "); + is_int (key.code.number, 3, "key.code.number for "); + + termkey_destroy (tk); + return exit_status (); +} -- cgit v1.2.3