From: Bram Moolenaar Date: Wed, 19 Oct 2022 19:07:09 +0000 (+0100) Subject: patch 9.0.0801: the modifyOtherKeys flag is set when it should not X-Git-Tag: v9.0.0801 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=7609c88eedc113bc80ccf74050b03a2e0c1a3c5e;p=vim 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) --- 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, /**/