From 7609c88eedc113bc80ccf74050b03a2e0c1a3c5e Mon Sep 17 00:00:00 2001 From: Bram Moolenaar Date: Wed, 19 Oct 2022 20:07:09 +0100 Subject: [PATCH] patch 9.0.0801: the modifyOtherKeys flag is set when it should not Problem: The modifyOtherKeys flag is set when it should not. Solution: Do not handle special key codes with a modifer value above 16 as a modifyOtherKeys value. (issue #11403) --- src/term.c | 7 +++++-- src/version.c | 2 ++ 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/term.c b/src/term.c index 088f6c79e..5b8c020a3 100644 --- a/src/term.c +++ b/src/term.c @@ -5045,8 +5045,11 @@ handle_csi( // Key with modifier: // {lead}27;{modifier};{key}~ // {lead}{key};{modifier}u - else if ((arg[0] == 27 && argc == 3 && trail == '~') - || (argc == 2 && trail == 'u')) + // Only handles four modifiers, this won't work if the modifier value is + // more than 16. + else if (((arg[0] == 27 && argc == 3 && trail == '~') + || (argc == 2 && trail == 'u')) + && arg[1] <= 16) { return len + handle_key_with_modifier(arg, trail, csi_len, offset, buf, bufsize, buflen); diff --git a/src/version.c b/src/version.c index 3ce579f02..983fa0c99 100644 --- a/src/version.c +++ b/src/version.c @@ -695,6 +695,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 801, /**/ 800, /**/ -- 2.40.0