X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Flibsystemd-terminal%2Fidev.h;h=c8c03f3d41be9937182fb184252f46e0f0fda544;hp=c98fb1bfb090a8a54b4304b91d7f7dad1d11ed5f;hb=62d5068d631fd655efe3ae4ad51fffe28e13e27a;hpb=c93e5a62ff599528c3bf2a8656825403aaebe093 diff --git a/src/libsystemd-terminal/idev.h b/src/libsystemd-terminal/idev.h index c98fb1bfb..c8c03f3d4 100644 --- a/src/libsystemd-terminal/idev.h +++ b/src/libsystemd-terminal/idev.h @@ -32,10 +32,12 @@ #include #include #include +#include #include "util.h" typedef struct idev_data idev_data; typedef struct idev_data_evdev idev_data_evdev; +typedef struct idev_data_keyboard idev_data_keyboard; typedef struct idev_event idev_event; typedef struct idev_device idev_device; @@ -52,6 +54,7 @@ enum { }; enum { + IDEV_DEVICE_KEYBOARD, IDEV_DEVICE_CNT }; @@ -63,6 +66,72 @@ struct idev_data_evdev { struct input_event event; }; +/* + * Keyboard Devices + */ + +struct xkb_state; + +enum { + IDEV_KBDMOD_IDX_SHIFT, + IDEV_KBDMOD_IDX_CTRL, + IDEV_KBDMOD_IDX_ALT, + IDEV_KBDMOD_IDX_LINUX, + IDEV_KBDMOD_IDX_CAPS, + IDEV_KBDMOD_CNT, + + IDEV_KBDMOD_SHIFT = 1 << IDEV_KBDMOD_IDX_SHIFT, + IDEV_KBDMOD_CTRL = 1 << IDEV_KBDMOD_IDX_CTRL, + IDEV_KBDMOD_ALT = 1 << IDEV_KBDMOD_IDX_ALT, + IDEV_KBDMOD_LINUX = 1 << IDEV_KBDMOD_IDX_LINUX, + IDEV_KBDMOD_CAPS = 1 << IDEV_KBDMOD_IDX_CAPS, +}; + +enum { + IDEV_KBDLED_IDX_NUM, + IDEV_KBDLED_IDX_CAPS, + IDEV_KBDLED_IDX_SCROLL, + IDEV_KBDLED_CNT, + + IDEV_KBDLED_NUM = 1 << IDEV_KBDLED_IDX_NUM, + IDEV_KBDLED_CAPS = 1 << IDEV_KBDLED_IDX_CAPS, + IDEV_KBDLED_SCROLL = 1 << IDEV_KBDLED_IDX_SCROLL, +}; + +struct idev_data_keyboard { + struct xkb_state *xkb_state; + int8_t ascii; + uint8_t value; + uint16_t keycode; + uint32_t mods; + uint32_t consumed_mods; + uint32_t n_syms; + uint32_t *keysyms; + uint32_t *codepoints; +}; + +static inline bool idev_kbdmatch(idev_data_keyboard *kdata, + uint32_t mods, uint32_t n_syms, + const uint32_t *syms) { + const uint32_t significant = IDEV_KBDMOD_SHIFT | + IDEV_KBDMOD_CTRL | + IDEV_KBDMOD_ALT | + IDEV_KBDMOD_LINUX; + uint32_t real; + + if (n_syms != kdata->n_syms) + return false; + + real = kdata->mods & ~kdata->consumed_mods & significant; + if (real != mods) + return false; + + return !memcmp(syms, kdata->keysyms, n_syms * sizeof(*syms)); +} + +#define IDEV_KBDMATCH(_kdata, _mods, _sym) \ + idev_kbdmatch((_kdata), (_mods), 1, (const uint32_t[]){ (_sym) }) + /* * Data Packets */ @@ -70,6 +139,7 @@ struct idev_data_evdev { enum { IDEV_DATA_RESYNC, IDEV_DATA_EVDEV, + IDEV_DATA_KEYBOARD, IDEV_DATA_CNT }; @@ -79,6 +149,7 @@ struct idev_data { union { idev_data_evdev evdev; + idev_data_keyboard keyboard; }; };