Blob Blame History Raw
To: vim_dev@googlegroups.com
Subject: Patch 7.4.886
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.4.886 (after 7.4.876)
Problem:    Windows7: Switching screen buffer causes flicker when using
            system().
Solution:   Instead of actually switching screen buffer, duplicate the handle.
            (Yasuhiro Matsumoto)
Files:      src/os_win32.c


*** ../vim-7.4.885/src/os_win32.c	2015-09-25 15:28:32.740126079 +0200
--- src/os_win32.c	2015-09-29 13:59:59.648635163 +0200
***************
*** 4612,4631 ****
  mch_system(char *cmd, int options)
  {
      int ret;
  
      /*
!      * Restore non-termcap screen buffer before execute external program, and
!      * revert it after.  Because msys and msys2's programs will cause freeze
!      * or crash conhost.exe (Windows's console window provider) and vim.exe,
!      * if active screen buffer is vim's one on Windows7.
       */
!     if (is_win7 && g_fTermcapMode)
! 	SetConsoleActiveScreenBuffer(g_cbNonTermcap.handle);
  
      ret = mch_system1(cmd, options);
  
!     if (is_win7 && g_fTermcapMode)
! 	SetConsoleActiveScreenBuffer(g_cbTermcap.handle);
  
      return ret;
  }
--- 4612,4645 ----
  mch_system(char *cmd, int options)
  {
      int ret;
+     HANDLE hTemp = INVALID_HANDLE_VALUE;
  
      /*
!      * Call DuplicateHandle before executing an external program, because msys
!      * and msys2's programs will call CreateConsoleScreenBuffer and
!      * CloseHandle.  CreateConsoleScreenBuffer returns the same handle which
!      * created by vim.  This causes a crash. This workaround is required on
!      * Windows7.
       */
!     if (is_win7
! 	    && g_fTermcapMode
! 	    && DuplicateHandle(
! 		    GetCurrentProcess(),
! 		    g_hConOut,
! 		    GetCurrentProcess(),
! 		    &hTemp,
! 		    0,
! 		    TRUE,
! 		    DUPLICATE_SAME_ACCESS))
! 	SetConsoleActiveScreenBuffer(hTemp);
  
      ret = mch_system1(cmd, options);
  
!     if (hTemp != INVALID_HANDLE_VALUE)
!     {
! 	SetConsoleActiveScreenBuffer(g_hConOut);
! 	CloseHandle(hTemp);
!     }
  
      return ret;
  }
*** ../vim-7.4.885/src/version.c	2015-09-29 12:08:39.333321460 +0200
--- src/version.c	2015-09-29 13:56:54.234534337 +0200
***************
*** 743,744 ****
--- 743,746 ----
  {   /* Add new patch number below this line */
+ /**/
+     886,
  /**/

-- 
Anyone who is capable of getting themselves made President should on no
account be allowed to do the job.
		-- Douglas Adams, "The Hitchhiker's Guide to the Galaxy"

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