Blob Blame History Raw
To: vim_dev@googlegroups.com
Subject: Patch 7.3.338
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.338
Problem:    Using getchar() in an expression mapping doesn't work well.
Solution:   Don't save and restore the typeahead. (James Vega)
Files:	    src/getchar.c, src/testdir/test34.ok


*** ../vim-7.3.337/src/getchar.c	2011-08-17 20:33:18.000000000 +0200
--- src/getchar.c	2011-10-12 21:53:27.000000000 +0200
***************
*** 2460,2486 ****
  
  			/*
  			 * Handle ":map <expr>": evaluate the {rhs} as an
! 			 * expression.  Save and restore the typeahead so that
! 			 * getchar() can be used.  Also save and restore the
! 			 * command line for "normal :".
  			 */
  			if (mp->m_expr)
  			{
- 			    tasave_T	tabuf;
  			    int		save_vgetc_busy = vgetc_busy;
  
! 			    save_typeahead(&tabuf);
! 			    if (tabuf.typebuf_valid)
! 			    {
! 				vgetc_busy = 0;
! 				save_m_keys = vim_strsave(mp->m_keys);
! 				save_m_str = vim_strsave(mp->m_str);
! 				s = eval_map_expr(save_m_str, NUL);
! 				vgetc_busy = save_vgetc_busy;
! 			    }
! 			    else
! 				s = NULL;
! 			    restore_typeahead(&tabuf);
  			}
  			else
  #endif
--- 2460,2477 ----
  
  			/*
  			 * Handle ":map <expr>": evaluate the {rhs} as an
! 			 * expression.  Also save and restore the command line
! 			 * for "normal :".
  			 */
  			if (mp->m_expr)
  			{
  			    int		save_vgetc_busy = vgetc_busy;
  
! 			    vgetc_busy = 0;
! 			    save_m_keys = vim_strsave(mp->m_keys);
! 			    save_m_str = vim_strsave(mp->m_str);
! 			    s = eval_map_expr(save_m_str, NUL);
! 			    vgetc_busy = save_vgetc_busy;
  			}
  			else
  #endif
*** ../vim-7.3.337/src/testdir/test34.ok	2010-08-15 21:57:29.000000000 +0200
--- src/testdir/test34.ok	2011-10-12 21:59:39.000000000 +0200
***************
*** 1,5 ****
  xxx4asdf fail nop ok 9 333
! XX111XX
  ---222---
  1. one
  2. two
--- 1,5 ----
  xxx4asdf fail nop ok 9 333
! XX111-XX
  ---222---
  1. one
  2. two
*** ../vim-7.3.337/src/version.c	2011-10-12 21:04:15.000000000 +0200
--- src/version.c	2011-10-12 21:20:31.000000000 +0200
***************
*** 711,712 ****
--- 711,714 ----
  {   /* Add new patch number below this line */
+ /**/
+     338,
  /**/

-- 
hundred-and-one symptoms of being an internet addict:
65. The last time you looked at the clock it was 11:30pm, and in what
    seems like only a few seconds later, your sister runs past you to
    catch her 7am school bus.

 /// 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    ///