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
*** ../vim-7.3.284/src/misc2.c 2011-08-17 20:33:18.000000000 +0200
--- src/misc2.c 2011-08-19 22:08:37.000000000 +0200
***************
*** 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);
! }
}
/*
*** ../vim-7.3.284/src/testdir/test75.in 2010-10-20 21:22:17.000000000 +0200
--- src/testdir/test75.in 2011-08-19 22:05:13.000000000 +0200
***************
*** 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
*** ../vim-7.3.284/src/testdir/test75.ok 2010-10-20 21:22:17.000000000 +0200
--- src/testdir/test75.ok 2011-08-19 21:53:26.000000000 +0200
***************
*** 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
*** ../vim-7.3.284/src/version.c 2011-08-17 20:33:18.000000000 +0200
--- src/version.c 2011-08-19 22:15:22.000000000 +0200
***************
*** 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 ///