| To: vim_dev@googlegroups.com |
| Subject: Patch 7.3.285 |
| Fcc: outbox |
| From: Bram Moolenaar <Bram@moolenaar.net> |
| Mime-Version: 1.0 |
| Content-Type: text/plain; charset=UTF-8 |
| Content-Transfer-Encoding: 8bit |
| |
| |
| Patch 7.3.285 (after 7.3.284) |
| Problem: Mapping <Char-123> no longer works. |
| Solution: Properly check for "char-". Add a test for it. |
| Files: src/misc2.c, src/testdir/test75.in, src/testdir/test75.ok |
| |
| |
| |
| |
| |
| *** 2781,2786 **** |
| --- 2781,2792 ---- |
| } |
| if (bp[0] == 't' && bp[1] == '_' && bp[2] && bp[3]) |
| bp += 3; /* skip t_xx, xx may be '-' or '>' */ |
| + else if (STRNICMP(bp, "char-", 5) == 0) |
| + { |
| + vim_str2nr(bp + 5, NULL, &l, TRUE, TRUE, NULL, NULL); |
| + bp += l + 5; |
| + break; |
| + } |
| } |
| |
| if (*bp == '>') /* found matching '>' */ |
| |
| *** 2810,2836 **** |
| { |
| /* <Char-123> or <Char-033> or <Char-0x33> */ |
| vim_str2nr(last_dash + 6, NULL, NULL, TRUE, TRUE, NULL, &n); |
| ! *modp = modifiers; |
| ! *srcp = end_of_name; |
| ! return (int)n; |
| } |
| - |
| - /* |
| - * Modifier with single letter, or special key name. |
| - */ |
| - #ifdef FEAT_MBYTE |
| - if (has_mbyte) |
| - l = mb_ptr2len(last_dash + 1); |
| - else |
| - #endif |
| - l = 1; |
| - if (modifiers != 0 && last_dash[l + 1] == '>') |
| - key = PTR2CHAR(last_dash + 1); |
| else |
| { |
| ! key = get_special_key_code(last_dash + 1); |
| ! if (!keep_x_key) |
| ! key = handle_x_keys(key); |
| } |
| |
| /* |
| --- 2816,2842 ---- |
| { |
| /* <Char-123> or <Char-033> or <Char-0x33> */ |
| vim_str2nr(last_dash + 6, NULL, NULL, TRUE, TRUE, NULL, &n); |
| ! key = (int)n; |
| } |
| else |
| { |
| ! /* |
| ! * Modifier with single letter, or special key name. |
| ! */ |
| ! #ifdef FEAT_MBYTE |
| ! if (has_mbyte) |
| ! l = mb_ptr2len(last_dash + 1); |
| ! else |
| ! #endif |
| ! l = 1; |
| ! if (modifiers != 0 && last_dash[l + 1] == '>') |
| ! key = PTR2CHAR(last_dash + 1); |
| ! else |
| ! { |
| ! key = get_special_key_code(last_dash + 1); |
| ! if (!keep_x_key) |
| ! key = handle_x_keys(key); |
| ! } |
| } |
| |
| /* |
| |
| |
| |
| *** 2,7 **** |
| --- 2,8 ---- |
| |
| STARTTEST |
| :so small.vim |
| + :set cpo-=< |
| :" Test maparg() with a string result |
| :map foo<C-V> is<F4>foo |
| :vnoremap <script> <buffer> <expr> <silent> bar isbar |
| |
| *** 9,14 **** |
| --- 10,20 ---- |
| :call append('$', string(maparg('foo<C-V>', '', 0, 1))) |
| :call append('$', string(maparg('bar', '', 0, 1))) |
| :" |
| + :map abc x<char-114>x |
| + :call append('$', maparg('abc')) |
| + :map abc y<S-char-114>y |
| + :call append('$', maparg('abc')) |
| + :" |
| :/^eof/+1,$w! test.out |
| :qa! |
| ENDTEST |
| |
| |
| |
| *** 1,3 **** |
| --- 1,5 ---- |
| is<F4>foo |
| {'silent': 0, 'noremap': 0, 'lhs': 'foo<C-V>', 'mode': ' ', 'expr': 0, 'sid': 0, 'rhs': 'is<F4>foo', 'buffer': 0} |
| {'silent': 1, 'noremap': 1, 'lhs': 'bar', 'mode': 'v', 'expr': 1, 'sid': 0, 'rhs': 'isbar', 'buffer': 1} |
| + xrx |
| + yRy |
| |
| |
| |
| *** 711,712 **** |
| --- 711,714 ---- |
| { /* Add new patch number below this line */ |
| + /**/ |
| + 285, |
| /**/ |
| |
| |
| -- |
| No man may purchase alcohol without written consent from his wife. |
| [real standing law in Pennsylvania, United States of America] |
| |
| /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\ |
| /// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\ |
| \\\ an exciting new programming language -- http://www.Zimbu.org /// |
| \\\ help me help AIDS victims -- http://ICCF-Holland.org /// |