]> granicus.if.org Git - vim/commitdiff
patch 8.0.1633: a TextChanged autocmd triggers when it is defined v8.0.1633
authorBram Moolenaar <Bram@vim.org>
Fri, 23 Mar 2018 21:39:31 +0000 (22:39 +0100)
committerBram Moolenaar <Bram@vim.org>
Fri, 23 Mar 2018 21:39:31 +0000 (22:39 +0100)
Problem:    A TextChanged autocmd triggers when it is defined after creating a
            buffer.
Solution:   Set b_last_changedtick when opening a buffer. (Hirohito Highlight,
            closes #2742)

src/buffer.c
src/testdir/test_autocmd.vim
src/version.c

index b292150a2e677e148b8f2d9d849e3b882a69a87b..c7f361af0a5f75eb98929bb3104c5715fcd880c7 100644 (file)
@@ -291,6 +291,13 @@ open_buffer(
        unchanged(curbuf, FALSE);
     save_file_ff(curbuf);              /* keep this fileformat */
 
+    /* Set last_changedtick to avoid triggering a TextChanged autocommand right
+     * after it was added. */
+    curbuf->b_last_changedtick = CHANGEDTICK(curbuf);
+#ifdef FEAT_INS_EXPAND
+    curbuf->b_last_changedtick_pum = CHANGEDTICK(curbuf);
+#endif
+
     /* require "!" to overwrite the file, because it wasn't read completely */
 #ifdef FEAT_EVAL
     if (aborting())
index d1ce5619735749f0aabeed2e55a2117fea683f7b..af7aaff74d81d8e4bb8fb16ee6531d96acdb3bb4 100644 (file)
@@ -1,5 +1,7 @@
 " Tests for autocommands
 
+source shared.vim
+
 func! s:cleanup_buffers() abort
   for bnr in range(1, bufnr('$'))
     if bufloaded(bnr) && bufnr('%') != bnr
@@ -1304,3 +1306,22 @@ func Test_ChangedP()
 
   bw!
 endfunc
+
+func Test_Changed_FirstTime()
+  if !has('terminal') || has('gui_running')
+    return
+  endif
+  " Prepare file for TextChanged event.
+  call writefile([''], 'Xchanged.txt')
+  let buf = term_start([GetVimProg(), '--clean', '-c', 'set noswapfile'], {'term_rows': 3})
+  call assert_equal('running', term_getstatus(buf))
+  " It's only adding autocmd, so that no event occurs.
+  call term_sendkeys(buf, ":au! TextChanged <buffer> call writefile(['No'], 'Xchanged.txt')\<cr>")
+  call term_sendkeys(buf, "\<C-\\>\<C-N>:qa!\<cr>")
+  call WaitFor({-> term_getstatus(buf) == 'finished'})
+  call assert_equal([''], readfile('Xchanged.txt'))
+
+  " clean up
+  call delete('Xchanged.txt')
+  bwipe!
+endfunc
index 6999611c0aa133c8eb2246fd09652782fa0e89cc..4ae79e7c530a9ebdf5f5417f90093ed67d335221 100644 (file)
@@ -766,6 +766,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1633,
 /**/
     1632,
 /**/