diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-05-31 22:06:51 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-05-31 22:06:51 +0200 |
commit | fccd93f0917234b962ce07d1df3adf9d7105936f (patch) | |
tree | 9b5b01cb09c6fc7c445e7f59cecb12d237e4057e /src/misc2.c | |
parent | 494e9069cb32620f7688a7cb128a3feff827639e (diff) | |
download | vim-git-fccd93f0917234b962ce07d1df3adf9d7105936f.tar.gz |
patch 8.2.0867: using \{xxx} for encoding a modifier is not nicev8.2.0867
Problem: Using \{xxx} for encoding a modifier is not nice.
Solution: Use \<*xxx> instead, since it's the same as \<xxx> but producing a
different code.
Diffstat (limited to 'src/misc2.c')
-rw-r--r-- | src/misc2.c | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/misc2.c b/src/misc2.c index 61c997d82..02fd4187c 100644 --- a/src/misc2.c +++ b/src/misc2.c @@ -2772,13 +2772,14 @@ find_special_key( int modifiers; int bit; int key; - int endchar = (flags & FSK_CURLY) ? '}' : '>'; uvarnumber_T n; int l; src = *srcp; - if (src[0] != ((flags & FSK_CURLY) ? '{' : '<')) + if (src[0] != '<') return 0; + if (src[1] == '*') // <*xxx>: do not simplify + ++src; // Find end of modifier list last_dash = src; @@ -2796,15 +2797,15 @@ find_special_key( // Anything accepted, like <C-?>. // <C-"> or <M-"> are not special in strings as " is // the string delimiter. With a backslash it works: <M-\"> - if (!(in_string && bp[1] == '"') && bp[l + 1] == endchar) + if (!(in_string && bp[1] == '"') && bp[l + 1] == '>') bp += l; else if (in_string && bp[1] == '\\' && bp[2] == '"' - && bp[3] == endchar) + && bp[3] == '>') bp += 2; } } if (bp[0] == 't' && bp[1] == '_' && bp[2] && bp[3]) - bp += 3; // skip t_xx, xx may be '-' or '>'/'}' + bp += 3; // skip t_xx, xx may be '-' or '>' else if (STRNICMP(bp, "char-", 5) == 0) { vim_str2nr(bp + 5, NULL, &l, STR2NR_ALL, NULL, NULL, 0, TRUE); @@ -2818,7 +2819,7 @@ find_special_key( } } - if (*bp == endchar) // found matching '>' or '}' + if (*bp == '>') // found matching '>' { end_of_name = bp + 1; @@ -2864,7 +2865,7 @@ find_special_key( l = mb_ptr2len(last_dash + off); else l = 1; - if (modifiers != 0 && last_dash[l + off] == endchar) + if (modifiers != 0 && last_dash[l + off] == '>') key = PTR2CHAR(last_dash + off); else { |