summaryrefslogtreecommitdiffstats
path: root/input-keys.c
diff options
context:
space:
mode:
authorThomas Adam <thomas@xteddy.org>2022-11-02 08:01:11 +0000
committerThomas Adam <thomas@xteddy.org>2022-11-02 08:01:11 +0000
commitdbfbd8a195707a8550d59f9576fbbafe1045556c (patch)
tree892fa43ade8ddc970159855005ca3621a21c028e /input-keys.c
parent36896f6dd0d49d91bcc9c398c68a33818626532c (diff)
parent9614f5156079773b338a13e95ec932cc7c95b031 (diff)
Merge branch 'obsd-master'
Diffstat (limited to 'input-keys.c')
-rw-r--r--input-keys.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/input-keys.c b/input-keys.c
index aa508028..208eb360 100644
--- a/input-keys.c
+++ b/input-keys.c
@@ -430,7 +430,7 @@ input_key_write(const char *from, struct bufferevent *bev, const char *data,
int
input_key(struct screen *s, struct bufferevent *bev, key_code key)
{
- struct input_key_entry *ike;
+ struct input_key_entry *ike = NULL;
key_code justkey, newkey, outkey, modifiers;
struct utf8_data ud;
char tmp[64], modifier;
@@ -482,9 +482,10 @@ input_key(struct screen *s, struct bufferevent *bev, key_code key)
key &= ~KEYC_KEYPAD;
if (~s->mode & MODE_KCURSOR)
key &= ~KEYC_CURSOR;
- if (~s->mode & MODE_KEXTENDED)
- key &= ~KEYC_EXTENDED;
- ike = input_key_get(key);
+ if (s->mode & MODE_KEXTENDED)
+ ike = input_key_get(key|KEYC_EXTENDED);
+ if (ike == NULL)
+ ike = input_key_get(key);
if (ike == NULL && (key & KEYC_META) && (~key & KEYC_IMPLIED_META))
ike = input_key_get(key & ~KEYC_META);
if (ike == NULL && (key & KEYC_CURSOR))