jkunstle / rpms / vim

Forked from rpms/vim 3 years ago
Clone
3ef2ca
To: vim_dev@googlegroups.com
3ef2ca
Subject: Patch 7.4.413
3ef2ca
Fcc: outbox
3ef2ca
From: Bram Moolenaar <Bram@moolenaar.net>
3ef2ca
Mime-Version: 1.0
3ef2ca
Content-Type: text/plain; charset=UTF-8
3ef2ca
Content-Transfer-Encoding: 8bit
3ef2ca
------------
3ef2ca
3ef2ca
Patch 7.4.413
3ef2ca
Problem:    MS-Windows: Using US international keyboard layout, inserting dead
3ef2ca
	    key by pressing space does not always work.  Issue 250.
3ef2ca
Solution:   Let MS-Windows translate the message. (John Wellesz)
3ef2ca
Files:	    src/gui_w48.c
3ef2ca
3ef2ca
3ef2ca
*** ../vim-7.4.412/src/gui_w48.c	2014-08-06 14:52:05.043236174 +0200
3ef2ca
--- src/gui_w48.c	2014-08-22 18:41:09.151182571 +0200
3ef2ca
***************
3ef2ca
*** 614,619 ****
3ef2ca
--- 614,621 ----
3ef2ca
      char_u	string[40];
3ef2ca
      int		len = 0;
3ef2ca
  
3ef2ca
+     dead_key = 0;
3ef2ca
+ 
3ef2ca
      len = char_to_string(ch, string, 40, FALSE);
3ef2ca
      if (len == 1 && string[0] == Ctrl_C && ctrl_c_interrupts)
3ef2ca
      {
3ef2ca
***************
3ef2ca
*** 1788,1811 ****
3ef2ca
      if (msg.message == WM_KEYDOWN || msg.message == WM_SYSKEYDOWN)
3ef2ca
      {
3ef2ca
  	vk = (int) msg.wParam;
3ef2ca
! 	/* handle key after dead key, but ignore shift, alt and control */
3ef2ca
! 	if (dead_key && vk != VK_SHIFT && vk != VK_MENU && vk != VK_CONTROL)
3ef2ca
  	{
3ef2ca
  	    dead_key = 0;
3ef2ca
! 	    /* handle non-alphabetic keys (ones that hopefully cannot generate
3ef2ca
! 	     * umlaut-characters), unless when control is down */
3ef2ca
! 	    if (vk < 'A' || vk > 'Z' || (GetKeyState(VK_CONTROL) & 0x8000))
3ef2ca
! 	    {
3ef2ca
! 		MSG dm;
3ef2ca
! 
3ef2ca
! 		dm.message = msg.message;
3ef2ca
! 		dm.hwnd = msg.hwnd;
3ef2ca
! 		dm.wParam = VK_SPACE;
3ef2ca
! 		MyTranslateMessage(&dm;;	/* generate dead character */
3ef2ca
! 		if (vk != VK_SPACE) /* and send current character once more */
3ef2ca
! 		    PostMessage(msg.hwnd, msg.message, msg.wParam, msg.lParam);
3ef2ca
! 		return;
3ef2ca
! 	    }
3ef2ca
  	}
3ef2ca
  
3ef2ca
  	/* Check for CTRL-BREAK */
3ef2ca
--- 1790,1810 ----
3ef2ca
      if (msg.message == WM_KEYDOWN || msg.message == WM_SYSKEYDOWN)
3ef2ca
      {
3ef2ca
  	vk = (int) msg.wParam;
3ef2ca
! 	/*
3ef2ca
! 	 * If a dead key was pressed and the user presses VK_SPACE, VK_BACK, or
3ef2ca
! 	 * VK_ESCAPE it means that he actually wants to deal with the dead char
3ef2ca
! 	 * now, so do nothing special and let Windows handle it.
3ef2ca
! 	 *
3ef2ca
! 	 * Note that VK_SPACE combines with the dead_key's character and only
3ef2ca
! 	 * one WM_CHAR will be generated by TranslateMessage(), in the two
3ef2ca
! 	 * other cases two WM_CHAR will be generated: the dead char and VK_BACK
3ef2ca
! 	 * or VK_ESCAPE.  That is most likely what the user expects.
3ef2ca
! 	 */
3ef2ca
! 	if (dead_key && (vk == VK_SPACE || vk == VK_BACK || vk == VK_ESCAPE))
3ef2ca
  	{
3ef2ca
  	    dead_key = 0;
3ef2ca
! 	    MyTranslateMessage(&msg;;
3ef2ca
! 	    return;
3ef2ca
  	}
3ef2ca
  
3ef2ca
  	/* Check for CTRL-BREAK */
3ef2ca
*** ../vim-7.4.412/src/version.c	2014-08-22 18:12:53.999244049 +0200
3ef2ca
--- src/version.c	2014-08-22 18:39:03.915187113 +0200
3ef2ca
***************
3ef2ca
*** 743,744 ****
3ef2ca
--- 743,746 ----
3ef2ca
  {   /* Add new patch number below this line */
3ef2ca
+ /**/
3ef2ca
+     413,
3ef2ca
  /**/
3ef2ca
3ef2ca
-- 
3ef2ca
hundred-and-one symptoms of being an internet addict:
3ef2ca
43. You tell the kids they can't use the computer because "Daddy's got work to
3ef2ca
    do" and you don't even have a job.
3ef2ca
3ef2ca
 /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net   \\\
3ef2ca
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
3ef2ca
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
3ef2ca
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///