Blob Blame History Raw
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    ///