aboutsummaryrefslogtreecommitdiff
path: root/termkey.h
diff options
context:
space:
mode:
authorPaul LeoNerd Evans <leonerd@leonerd.org.uk>2008-02-07 00:58:41 +0000
committerPaul LeoNerd Evans <leonerd@leonerd.org.uk>2008-02-07 00:58:41 +0000
commita503403226e4e2a929efddd4a2d0daad9c33c596 (patch)
tree032aa941ca6153c2e61fd01711e623d487aecfbe /termkey.h
downloadtermo-a503403226e4e2a929efddd4a2d0daad9c33c596.tar.gz
termo-a503403226e4e2a929efddd4a2d0daad9c33c596.tar.xz
termo-a503403226e4e2a929efddd4a2d0daad9c33c596.zip
Initial attempt
Diffstat (limited to 'termkey.h')
-rw-r--r--termkey.h113
1 files changed, 113 insertions, 0 deletions
diff --git a/termkey.h b/termkey.h
new file mode 100644
index 0000000..a99e428
--- /dev/null
+++ b/termkey.h
@@ -0,0 +1,113 @@
+#ifndef __TERMKEY_H__
+#define __TERMKEY_H__
+
+#include <stdint.h>
+#include <stdlib.h>
+
+typedef enum {
+ TERMKEY_SYM_EOF = -1, // Stream closed
+ TERMKEY_SYM_UNKNOWN = -2,
+ TERMKEY_SYM_NONE = 0, // Did not find a key
+
+ // Special names in C0
+ TERMKEY_SYM_BACKSPACE,
+ TERMKEY_SYM_TAB,
+ TERMKEY_SYM_ENTER,
+ TERMKEY_SYM_ESCAPE,
+
+ // Special names in G0
+ TERMKEY_SYM_SPACE,
+ TERMKEY_SYM_DEL,
+
+ // CSI keys
+ TERMKEY_SYM_UP,
+ TERMKEY_SYM_DOWN,
+ TERMKEY_SYM_LEFT,
+ TERMKEY_SYM_RIGHT,
+ TERMKEY_SYM_BEGIN,
+
+ // CSI function keys
+ TERMKEY_SYM_INSERT,
+ TERMKEY_SYM_DELETE,
+ TERMKEY_SYM_HOME,
+ TERMKEY_SYM_END,
+ TERMKEY_SYM_PAGEUP,
+ TERMKEY_SYM_PAGEDOWN,
+
+ TERMKEY_SYM_F1,
+ TERMKEY_SYM_F2,
+ TERMKEY_SYM_F3,
+ TERMKEY_SYM_F4,
+ TERMKEY_SYM_F5,
+ TERMKEY_SYM_F6,
+ TERMKEY_SYM_F7,
+ TERMKEY_SYM_F8,
+ TERMKEY_SYM_F9,
+ TERMKEY_SYM_F10,
+ TERMKEY_SYM_F11,
+ TERMKEY_SYM_F12,
+
+ // Numeric keypad special keys
+ TERMKEY_SYM_KP0,
+ TERMKEY_SYM_KP1,
+ TERMKEY_SYM_KP2,
+ TERMKEY_SYM_KP3,
+ TERMKEY_SYM_KP4,
+ TERMKEY_SYM_KP5,
+ TERMKEY_SYM_KP6,
+ TERMKEY_SYM_KP7,
+ TERMKEY_SYM_KP8,
+ TERMKEY_SYM_KP9,
+ TERMKEY_SYM_KPENTER,
+ TERMKEY_SYM_KPPLUS,
+ TERMKEY_SYM_KPMINUS,
+ TERMKEY_SYM_KPMULT,
+ TERMKEY_SYM_KPDIV,
+ TERMKEY_SYM_KPCOMMA,
+ TERMKEY_SYM_KPPERIOD,
+ TERMKEY_SYM_KPEQUALS,
+
+ // et cetera ad nauseum
+} termkey_sym_e;
+
+enum {
+ TERMKEY_KEYFLAG_SPECIAL = 0x01, // 'code' is a special keycode, not a unicode codepoint
+};
+
+enum {
+ TERMKEY_KEYMOD_SHIFT = 0x01,
+ TERMKEY_KEYMOD_ALT = 0x02,
+ TERMKEY_KEYMOD_CTRL = 0x04,
+};
+
+typedef struct {
+ int modifiers;
+ int code;
+ int flags;
+
+ /* Any Unicode character can be UTF-8 encoded in no more than 5 bytes, plus
+ * terminating NUL */
+ char utf8[6];
+} termkey_key;
+
+typedef struct termkey termkey_t;
+
+enum {
+ TERMKEY_FLAG_NOINTERPRET = 0x01, // Do not interpret C0//G1 codes if possible
+ TERMKEY_FLAG_CONVERTKP = 0x02, // Convert KP codes to regular keypresses
+};
+
+termkey_t *termkey_new(int fd, int flags);
+void termkey_free(termkey_t *tk);
+
+int termkey_getkey(termkey_t *tk, termkey_key *key);
+int termkey_waitkey(termkey_t *tk, termkey_key *key);
+
+void termkey_pushinput(termkey_t *tk, unsigned char *input, size_t inputlen);
+
+void termkey_advisereadable(termkey_t *tk);
+
+
+const char *termkey_describe_sym(int code);
+
+#endif