]> granicus.if.org Git - vim/commitdiff
patch 8.1.1681: insert stray "{" when listener gets buffer line v8.1.1681
authorBram Moolenaar <Bram@vim.org>
Sat, 13 Jul 2019 18:14:45 +0000 (20:14 +0200)
committerBram Moolenaar <Bram@vim.org>
Sat, 13 Jul 2019 18:14:45 +0000 (20:14 +0200)
Problem:    Insert stray "{" when listener gets buffer line. (Paul Jolly)
Solution:   Flush the cached line after invoking listeners. (closes #4455)

src/memline.c
src/testdir/test_listener.vim
src/version.c

index 0e3bdb8b6b324132348f5ef5bd370b25a1c3c07e..b9de06e1df09e064f4b863ff3e03dd249c37a3fc 100644 (file)
@@ -2836,8 +2836,10 @@ ml_append_int(
 
 #ifdef FEAT_EVAL
     // When inserting above recorded changes: flush the changes before changing
-    // the text.
+    // the text.  Then flush the cached line, it may become invalid.
     may_invoke_listeners(buf, lnum + 1, lnum + 1, 1);
+    if (curbuf->b_ml.ml_line_lnum != 0)
+       ml_flush_line(curbuf);
 #endif
 
 #ifdef FEAT_TEXT_PROP
index ed501c2ef80d58733b64f384d167f15d6efd1bad..6a68ae64b58e98a76b02c238e30d05427833b58d 100644 (file)
@@ -242,3 +242,29 @@ func Test_listener_garbage_collect()
   delfunc MyListener
   bwipe!
 endfunc
+
+" This verifies the fix for issue #4455
+func Test_listener_caches_buffer_line()
+  new
+  inoremap <silent> <CR> <CR><Esc>O
+
+  function EchoChanges(bufnr, start, end, added, changes)
+    for l:change in a:changes
+      let text = getbufline(a:bufnr, l:change.lnum, l:change.end-1+l:change.added)
+    endfor
+  endfunction
+  let lid = listener_add("EchoChanges")
+  set autoindent
+  set cindent
+
+  call setline(1, ["{", "\tif true {}", "}"])
+  exe "normal /{}\nl"
+  call feedkeys("i\r\e", 'xt')
+  call assert_equal(["{", "\tif true {", "", "\t}", "}"], getline(1, 5))
+
+  bwipe!
+  delfunc EchoChanges
+  call listener_remove(lid)
+  iunmap <CR>
+  set nocindent
+endfunc
index eaa8047cd096eab45d99f7a02716e0a4a6c30035..fff8d22a23a8822dc4aac1ff0de4cfb762aadb44 100644 (file)
@@ -777,6 +777,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1681,
 /**/
     1680,
 /**/