]> granicus.if.org Git - vim/commitdiff
patch 8.0.1190: unusable after opening new window in BufWritePre event v8.0.1190
authorBram Moolenaar <Bram@vim.org>
Sat, 14 Oct 2017 14:06:20 +0000 (16:06 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 14 Oct 2017 14:06:20 +0000 (16:06 +0200)
Problem:    Vim becomes unusable after opening new window in BufWritePre
            event.
Solution:   Call not_exiting(). (Martin Tournoij, closes #2205)
            Also for "2q" when a help window is open.  Add a test.

src/ex_docmd.c
src/testdir/test_writefile.vim
src/version.c

index bb1ae46907fc469b24a741601dc42ac6b914e5e7..7365d1bd3a327c0b968f35ec4c54c8bfe7d4887a 100644 (file)
@@ -7261,6 +7261,7 @@ ex_quit(exarg_T *eap)
         */
        if (only_one_window() && (ONE_WINDOW || eap->addr_count == 0))
            getout(0);
+       not_exiting();
 #ifdef FEAT_GUI
        need_mouse_correct = TRUE;
 #endif
@@ -7799,6 +7800,7 @@ ex_exit(exarg_T *eap)
     {
        if (only_one_window())      /* quit last window, exit Vim */
            getout(0);
+       not_exiting();
 # ifdef FEAT_GUI
        need_mouse_correct = TRUE;
 # endif
index 6768e3154a6a604c8b066225c3bef017b0bed1f9..f462d049c0ef4117c09546fbd7c4044eec3563d3 100644 (file)
@@ -49,3 +49,47 @@ func Test_writefile_fails_conversion()
   bwipe!
   set backup& writebackup&
 endfunc
+
+func SetFlag(timer)
+  let g:flag = 1
+endfunc
+
+func Test_write_quit_split()
+  " Prevent exiting by splitting window on file write.
+  augroup testgroup
+    autocmd BufWritePre * split
+  augroup END
+  e! Xfile
+  call setline(1, 'nothing')
+  wq
+
+  if has('timers')
+    " timer will not run if "exiting" is still set
+    let g:flag = 0
+    call timer_start(1, 'SetFlag')
+    sleep 50m
+    call assert_equal(1, g:flag)
+    unlet g:flag
+  endif
+  au! testgroup
+  bwipe Xfile
+  call delete('Xfile')
+endfunc
+
+func Test_nowrite_quit_split()
+  " Prevent exiting by opening a help window.
+  e! Xfile
+  help
+  wincmd w
+  exe winnr() . 'q'
+
+  if has('timers')
+    " timer will not run if "exiting" is still set
+    let g:flag = 0
+    call timer_start(1, 'SetFlag')
+    sleep 50m
+    call assert_equal(1, g:flag)
+    unlet g:flag
+  endif
+  bwipe Xfile
+endfunc
index 451eb36c8648e1195184a88dae975f71a1926aa4..efdc5abcf42f94afa5447bafd2ac29e8e37d151c 100644 (file)
@@ -761,6 +761,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1190,
 /**/
     1189,
 /**/