3ef2ca
To: vim_dev@googlegroups.com
3ef2ca
Subject: Patch 7.4.142
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.142 (after 7.4.137)
3ef2ca
Problem:    On MS-Windows 8 IME input doen't work correctly.
3ef2ca
Solution:   Work around the problem. (Nobuhiro Takasaki)
3ef2ca
Files:	    src/os_win32.c
3ef2ca
3ef2ca
3ef2ca
*** ../vim-7.4.141/src/os_win32.c	2014-01-10 18:16:00.000000000 +0100
3ef2ca
--- src/os_win32.c	2014-01-12 13:23:24.000000000 +0100
3ef2ca
***************
3ef2ca
*** 234,289 ****
3ef2ca
  
3ef2ca
  /*
3ef2ca
   * Version of ReadConsoleInput() that works with IME.
3ef2ca
   */
3ef2ca
      static BOOL
3ef2ca
  read_console_input(
3ef2ca
!     HANDLE hConsoleInput,
3ef2ca
!     PINPUT_RECORD lpBuffer,
3ef2ca
!     DWORD nLength,
3ef2ca
!     LPDWORD lpNumberOfEventsRead)
3ef2ca
  {
3ef2ca
      enum
3ef2ca
      {
3ef2ca
! 	IRSIZE = 10, /* rough value */
3ef2ca
      };
3ef2ca
!     static INPUT_RECORD irCache[IRSIZE];
3ef2ca
      static DWORD s_dwIndex = 0;
3ef2ca
      static DWORD s_dwMax = 0;
3ef2ca
! 
3ef2ca
!     if (hConsoleInput == NULL || lpBuffer == NULL)
3ef2ca
! 	return ReadConsoleInput(hConsoleInput, lpBuffer, nLength,
3ef2ca
! 							lpNumberOfEventsRead);
3ef2ca
! 
3ef2ca
!     if (nLength == -1)
3ef2ca
!     {
3ef2ca
! 	if (s_dwMax == 0)
3ef2ca
! 	{
3ef2ca
! 	    PeekConsoleInput(hConsoleInput, lpBuffer, 1, lpNumberOfEventsRead);
3ef2ca
! 	    if (*lpNumberOfEventsRead == 0)
3ef2ca
! 		return FALSE;
3ef2ca
! 	    ReadConsoleInput(hConsoleInput, irCache, IRSIZE, &s_dwMax);
3ef2ca
! 	    s_dwIndex = 0;
3ef2ca
! 	}
3ef2ca
! 	((PINPUT_RECORD)lpBuffer)[0] = irCache[s_dwIndex];
3ef2ca
! 	*lpNumberOfEventsRead = 1;
3ef2ca
! 	return TRUE;
3ef2ca
!     }
3ef2ca
  
3ef2ca
      if (s_dwMax == 0)
3ef2ca
      {
3ef2ca
! 	ReadConsoleInput(hConsoleInput, irCache, IRSIZE, &s_dwMax);
3ef2ca
  	s_dwIndex = 0;
3ef2ca
! 	if (s_dwMax == 0)
3ef2ca
  	{
3ef2ca
! 	    *lpNumberOfEventsRead = 0;
3ef2ca
! 	    return FALSE;
3ef2ca
  	}
3ef2ca
      }
3ef2ca
! 
3ef2ca
!     ((PINPUT_RECORD)lpBuffer)[0] = irCache[s_dwIndex];
3ef2ca
!     if (++s_dwIndex == s_dwMax)
3ef2ca
  	s_dwMax = 0;
3ef2ca
!     *lpNumberOfEventsRead = 1;
3ef2ca
      return TRUE;
3ef2ca
  }
3ef2ca
  
3ef2ca
--- 234,275 ----
3ef2ca
  
3ef2ca
  /*
3ef2ca
   * Version of ReadConsoleInput() that works with IME.
3ef2ca
+  * Works around problems on Windows 8.
3ef2ca
   */
3ef2ca
      static BOOL
3ef2ca
  read_console_input(
3ef2ca
!     HANDLE	    hInput,
3ef2ca
!     INPUT_RECORD    *lpBuffer,
3ef2ca
!     DWORD	    nLength,
3ef2ca
!     LPDWORD	    lpEvents)
3ef2ca
  {
3ef2ca
      enum
3ef2ca
      {
3ef2ca
! 	IRSIZE = 10
3ef2ca
      };
3ef2ca
!     static INPUT_RECORD s_irCache[IRSIZE];
3ef2ca
      static DWORD s_dwIndex = 0;
3ef2ca
      static DWORD s_dwMax = 0;
3ef2ca
!     DWORD dwEvents;
3ef2ca
  
3ef2ca
      if (s_dwMax == 0)
3ef2ca
      {
3ef2ca
! 	if (nLength == -1)
3ef2ca
! 	    return PeekConsoleInput(hInput, lpBuffer, 1, lpEvents);
3ef2ca
! 	if (!ReadConsoleInput(hInput, s_irCache, IRSIZE, &dwEvents))
3ef2ca
! 	    return FALSE;
3ef2ca
  	s_dwIndex = 0;
3ef2ca
! 	s_dwMax = dwEvents;
3ef2ca
! 	if (dwEvents == 0)
3ef2ca
  	{
3ef2ca
! 	    *lpEvents = 0;
3ef2ca
! 	    return TRUE;
3ef2ca
  	}
3ef2ca
      }
3ef2ca
!     *lpBuffer = s_irCache[s_dwIndex];
3ef2ca
!     if (nLength != -1 && ++s_dwIndex >= s_dwMax)
3ef2ca
  	s_dwMax = 0;
3ef2ca
!     *lpEvents = 1;
3ef2ca
      return TRUE;
3ef2ca
  }
3ef2ca
  
3ef2ca
***************
3ef2ca
*** 292,304 ****
3ef2ca
   */
3ef2ca
      static BOOL
3ef2ca
  peek_console_input(
3ef2ca
!     HANDLE hConsoleInput,
3ef2ca
!     PINPUT_RECORD lpBuffer,
3ef2ca
!     DWORD nLength,
3ef2ca
!     LPDWORD lpNumberOfEventsRead)
3ef2ca
  {
3ef2ca
!     return read_console_input(hConsoleInput, lpBuffer, -1,
3ef2ca
! 							lpNumberOfEventsRead);
3ef2ca
  }
3ef2ca
  
3ef2ca
      static void
3ef2ca
--- 278,289 ----
3ef2ca
   */
3ef2ca
      static BOOL
3ef2ca
  peek_console_input(
3ef2ca
!     HANDLE	    hInput,
3ef2ca
!     INPUT_RECORD    *lpBuffer,
3ef2ca
!     DWORD	    nLength,
3ef2ca
!     LPDWORD	    lpEvents)
3ef2ca
  {
3ef2ca
!     return read_console_input(hInput, lpBuffer, -1, lpEvents);
3ef2ca
  }
3ef2ca
  
3ef2ca
      static void
3ef2ca
***************
3ef2ca
*** 585,594 ****
3ef2ca
      static BOOL
3ef2ca
  win32_enable_privilege(LPTSTR lpszPrivilege, BOOL bEnable)
3ef2ca
  {
3ef2ca
!     BOOL             bResult;
3ef2ca
!     LUID             luid;
3ef2ca
!     HANDLE           hToken;
3ef2ca
!     TOKEN_PRIVILEGES tokenPrivileges;
3ef2ca
  
3ef2ca
      if (!OpenProcessToken(GetCurrentProcess(),
3ef2ca
  		TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
3ef2ca
--- 570,579 ----
3ef2ca
      static BOOL
3ef2ca
  win32_enable_privilege(LPTSTR lpszPrivilege, BOOL bEnable)
3ef2ca
  {
3ef2ca
!     BOOL		bResult;
3ef2ca
!     LUID		luid;
3ef2ca
!     HANDLE		hToken;
3ef2ca
!     TOKEN_PRIVILEGES	tokenPrivileges;
3ef2ca
  
3ef2ca
      if (!OpenProcessToken(GetCurrentProcess(),
3ef2ca
  		TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY, &hToken))
3ef2ca
*** ../vim-7.4.141/src/version.c	2014-01-10 18:16:00.000000000 +0100
3ef2ca
--- src/version.c	2014-01-12 13:17:47.000000000 +0100
3ef2ca
***************
3ef2ca
*** 740,741 ****
3ef2ca
--- 740,743 ----
3ef2ca
  {   /* Add new patch number below this line */
3ef2ca
+ /**/
3ef2ca
+     142,
3ef2ca
  /**/
3ef2ca
3ef2ca
-- 
3ef2ca
Drink wet cement and get really stoned.
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    ///