aboutsummaryrefslogtreecommitdiff
path: root/tests/20canon.c
diff options
context:
space:
mode:
authorPřemysl Janouch <p.janouch@gmail.com>2014-10-09 23:47:24 +0200
committerPřemysl Janouch <p.janouch@gmail.com>2014-10-09 23:47:24 +0200
commit5692f32bcfa049fc2b5555b5a883045b217349b9 (patch)
tree512eaa1bece48291ffdf7cf4865a085e6ee0b2cc /tests/20canon.c
parent3465d5553fbe88a75320d1da3f7228619492b036 (diff)
downloadtermo-5692f32bcfa049fc2b5555b5a883045b217349b9.tar.gz
termo-5692f32bcfa049fc2b5555b5a883045b217349b9.tar.xz
termo-5692f32bcfa049fc2b5555b5a883045b217349b9.zip
CMake-ify, rename to termkey2 for the time being
Diffstat (limited to 'tests/20canon.c')
-rw-r--r--tests/20canon.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/tests/20canon.c b/tests/20canon.c
new file mode 100644
index 0000000..a60c2ef
--- /dev/null
+++ b/tests/20canon.c
@@ -0,0 +1,74 @@
+#include "../termkey.h"
+#include "taplib.h"
+
+int
+main (int argc, char *argv[])
+{
+ 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 (26);
+
+ tk = termkey_new_abstract ("vt100", NULL, 0);
+
+ CLEAR_KEY;
+ endp = termkey_strpkey (tk, " ", &key, 0);
+ 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.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_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.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);
+
+ 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.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.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.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);
+
+ 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.modifiers, 0, "key.modifiers for Del/as-backspace");
+ is_str (endp, "", "consumed entire input for Del/as-backspace");
+
+ termkey_destroy (tk);
+ return exit_status ();
+}