]> granicus.if.org Git - vim/commitdiff
patch 8.2.2900: QuitPre is triggered before :wq writes the file v8.2.2900
authorBram Moolenaar <Bram@vim.org>
Sat, 29 May 2021 12:30:43 +0000 (14:30 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 29 May 2021 12:30:43 +0000 (14:30 +0200)
Problem:    QuitPre is triggered before :wq writes the file, which is
            different from other commands.
Solution:   Trigger QuitPre after writing the file. (closes #8279)

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

index 58dad657ce64b346435d90e756e1ee70f005844f..9c8eba558a86f0926dd1dc19e4fcf1e40a8cb817 100644 (file)
@@ -6089,7 +6089,7 @@ ex_stop(exarg_T *eap)
 }
 
 /*
- * ":exit", ":xit" and ":wq": Write file and quite the current window.
+ * ":exit", ":xit" and ":wq": Write file and quit the current window.
  */
     static void
 ex_exit(exarg_T *eap)
@@ -6112,17 +6112,17 @@ ex_exit(exarg_T *eap)
        return;
     }
 
-    if (before_quit_autocmds(curwin, FALSE, eap->forceit))
-       return;
-
     /*
-     * if more files or windows we won't exit
+     * we plan to exit if there is only one relevant window
      */
     if (check_more(FALSE, eap->forceit) == OK && only_one_window())
        exiting = TRUE;
-    if (       ((eap->cmdidx == CMD_wq
-                   || curbufIsChanged())
-               && do_write(eap) == FAIL)
+
+    // Write the buffer for ":wq" or when it was changed.
+    // Trigger QuitPre and ExitPre.
+    // Check if we can exit now, after autocommands have changed things.
+    if (((eap->cmdidx == CMD_wq || curbufIsChanged()) && do_write(eap) == FAIL)
+           || before_quit_autocmds(curwin, FALSE, eap->forceit)
            || check_more(TRUE, eap->forceit) == FAIL
            || (only_one_window() && check_changed_any(eap->forceit, FALSE)))
     {
index e4293e3f1072cb2e516e686bdbf2ff6e825c5119..e94071fd7defb9f7e99c14d1909c234a84e1df93 100644 (file)
@@ -915,4 +915,25 @@ func Test_write_binary_file()
   call delete('Xfile3')
 endfunc
 
+" Check that buffer is written before triggering QuitPre
+func Test_wq_quitpre_autocommand()
+  edit Xsomefile
+  call setline(1, 'hello')
+  split
+  let g:seq = []
+  augroup Testing
+    au QuitPre * call add(g:seq, 'QuitPre - ' .. (&modified ? 'modified' : 'not modified'))
+    au BufWritePost * call add(g:seq, 'written')
+  augroup END
+  wq
+  call assert_equal(['written', 'QuitPre - not modified'], g:seq)
+
+  augroup Testing
+    au!
+  augroup END
+  bwipe!
+  unlet g:seq
+  call delete('Xsomefile')
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index 9e3ba0fa363b31ce42cf450693736a2bb21717dd..4223259e2fb237cc4d41d25204a39187b8b357d1 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    2900,
 /**/
     2899,
 /**/