From: Bram Moolenaar Date: Sun, 20 Oct 2019 14:00:47 +0000 (+0200) Subject: patch 8.1.2191: when using modifyOtherKeys CTRL-X mode may not work X-Git-Tag: v8.1.2191 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=88d3d09e07dbe0e3ea450bc554e2aadc451450d2;p=vim patch 8.1.2191: when using modifyOtherKeys CTRL-X mode may not work Problem: When using modifyOtherKeys CTRL-X mode may not work. Solution: Recognize a control character also in the form with a modifier. --- diff --git a/src/getchar.c b/src/getchar.c index 03a67be34..f9bfab829 100644 --- a/src/getchar.c +++ b/src/getchar.c @@ -2142,6 +2142,24 @@ typedef enum { map_result_nomatch // no matching mapping, get char } map_result_T; +/* + * Check if the bytes at the start of the typeahead buffer are a character used + * in CTRL-X mode. This includes the form with a CTRL modifier. + */ + static int +at_ctrl_x_key(void) +{ + char_u *p = typebuf.tb_buf + typebuf.tb_off; + int c = *p; + + if (typebuf.tb_len > 3 + && c == K_SPECIAL + && p[1] == KS_MODIFIER + && (p[2] & MOD_MASK_CTRL)) + c = p[3] & 0x1f; + return vim_is_ctrl_x_key(c); +} + /* * Handle mappings in the typeahead buffer. * - When something was mapped, return map_result_retry for recursive mappings. @@ -2193,7 +2211,7 @@ handle_mapping( && !(State == HITRETURN && (tb_c1 == CAR || tb_c1 == ' ')) && State != ASKMORE && State != CONFIRM - && !((ctrl_x_mode_not_default() && vim_is_ctrl_x_key(tb_c1)) + && !((ctrl_x_mode_not_default() && at_ctrl_x_key()) || ((compl_cont_status & CONT_LOCAL) && (tb_c1 == Ctrl_N || tb_c1 == Ctrl_P)))) { diff --git a/src/version.c b/src/version.c index caf8ccf2b..c9c0943e1 100644 --- a/src/version.c +++ b/src/version.c @@ -741,6 +741,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 2191, /**/ 2190, /**/