diff options
author | nicm <nicm> | 2020-05-19 10:59:09 +0000 |
---|---|---|
committer | nicm <nicm> | 2020-05-19 10:59:09 +0000 |
commit | 8425084b8ada98f6465d99d8bc8cad91612e50c5 (patch) | |
tree | 2c16a5b5da9aaa0c15503d846f2a0cd85d10acaa /input-keys.c | |
parent | 574a9e4b6c7a419b60668c30916327aa7e65d2c8 (diff) | |
download | rtmux-8425084b8ada98f6465d99d8bc8cad91612e50c5.tar.gz rtmux-8425084b8ada98f6465d99d8bc8cad91612e50c5.tar.bz2 rtmux-8425084b8ada98f6465d99d8bc8cad91612e50c5.zip |
Some other ctrl keys need to be translated with extended keys on.
Diffstat (limited to 'input-keys.c')
-rw-r--r-- | input-keys.c | 33 |
1 files changed, 29 insertions, 4 deletions
diff --git a/input-keys.c b/input-keys.c index 19134c1a..7a922ab8 100644 --- a/input-keys.c +++ b/input-keys.c @@ -498,10 +498,35 @@ input_key(struct screen *s, struct bufferevent *bev, key_code key) /* No builtin key sequence; construct an extended key sequence. */ if (~s->mode & MODE_KEXTENDED) { - if ((key & KEYC_MASK_MODIFIERS) == KEYC_CTRL && - (key & KEYC_MASK_KEY) < KEYC_BASE) - return (input_key(s, bev, key & ~KEYC_CTRL)); - goto missing; + justkey = (key & KEYC_MASK_KEY); + if ((key & KEYC_MASK_MODIFIERS) != KEYC_CTRL) + goto missing; + switch (justkey) { + case ' ': + case '2': + key = 0||(key & ~KEYC_MASK_KEY); + break; + case '|': + key = 28|(key & ~KEYC_MASK_KEY); + break; + case '6': + key = 30|(key & ~KEYC_MASK_KEY); + break; + case '-': + case '/': + key = 31|(key & ~KEYC_MASK_KEY); + break; + case '?': + key = 127|(key & ~KEYC_MASK_KEY); + break; + default: + if (justkey >= 'A' && justkey <= '_') + key = (justkey - 'A')|(key & ~KEYC_MASK_KEY); + else if (justkey >= 'a' && justkey <= '~') + key = (justkey - 96)|(key & ~KEYC_MASK_KEY); + break; + } + return (input_key(s, bev, key & ~KEYC_CTRL)); } outkey = (key & KEYC_MASK_KEY); switch (key & KEYC_MASK_MODIFIERS) { |