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 | |
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.
-rw-r--r-- | input-keys.c | 33 | ||||
-rw-r--r-- | tty-features.c | 2 |
2 files changed, 30 insertions, 5 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) { diff --git a/tty-features.c b/tty-features.c index 26344b90..8f712f64 100644 --- a/tty-features.c +++ b/tty-features.c @@ -343,7 +343,7 @@ tty_default_features(int *feat, const char *name, u_int version) .features = "256,bpaste,ccolour,cstyle,title" }, { .name = "iTerm2", - .features = TTY_FEATURES_BASE_MODERN_XTERM ",cstyle,margins,sync" + .features = TTY_FEATURES_BASE_MODERN_XTERM ",cstyle,extkeys,margins,sync" }, { .name = "XTerm", .features = TTY_FEATURES_BASE_MODERN_XTERM ",ccolour,cstyle,extkeys,focus,margins,rectfill" |