summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian Brabandt <cb@256bit.org>2024-03-31 18:38:09 +0200
committerChristian Brabandt <cb@256bit.org>2024-03-31 18:38:09 +0200
commit86032702932995db74fed265ba99ae0c823cb75d (patch)
treee803885d3ce0119602aebfdad0d09168a345bda4
parent18d730d7b5728c8f87272ac7047d86354013eeb9 (diff)
patch 9.1.0230: TextChanged autocommand not triggered under some circumstancesv9.1.0230
Problem: TextChanged autocommand not triggered under some circumstances (Sergey Vlasov) Solution: Trigger TextChanged when TextChangedI has not been triggered fixes: #14332 closes: #14339 Signed-off-by: Christian Brabandt <cb@256bit.org>
-rw-r--r--src/edit.c5
-rw-r--r--src/testdir/test_autocmd.vim20
-rw-r--r--src/version.c2
3 files changed, 25 insertions, 2 deletions
diff --git a/src/edit.c b/src/edit.c
index efa32f51e7..2f28562086 100644
--- a/src/edit.c
+++ b/src/edit.c
@@ -845,9 +845,10 @@ doESCkey:
did_cursorhold = FALSE;
// ins_redraw() triggers TextChangedI only when no characters
- // are in the typeahead buffer, so only reset curbuf->b_last_changedtick
+ // are in the typeahead buffer, so reset curbuf->b_last_changedtick only
// if the TextChangedI was not blocked by char_avail() (e.g. using :norm!)
- if (!char_avail())
+ // and the TextChangeDI autocommand has been trigered
+ if (!char_avail() && curbuf->b_last_changedtick_i == CHANGEDTICK(curbuf))
curbuf->b_last_changedtick = CHANGEDTICK(curbuf);
return (c == Ctrl_O);
}
diff --git a/src/testdir/test_autocmd.vim b/src/testdir/test_autocmd.vim
index f0620040c2..bf9087111c 100644
--- a/src/testdir/test_autocmd.vim
+++ b/src/testdir/test_autocmd.vim
@@ -4530,4 +4530,24 @@ func Test_implicit_session()
call delete(expected)
endfunc
+" Test TextChangedI and TextChanged
+func Test_Changed_ChangedI_2()
+ CheckRunVimInTerminal
+ call writefile(['one', 'two', 'three'], 'XTextChangedI2', 'D')
+ let before =<< trim END
+ autocmd TextChanged,TextChangedI * call writefile([b:changedtick], 'XTextChangedI3')
+ nnoremap <CR> o<Esc>
+ call writefile([], 'XTextChangedI3')
+ END
+
+ call writefile(before, 'Xinit', 'D')
+ let buf = RunVimInTerminal('-S Xinit XtextChangedI2', {})
+ call term_sendkeys(buf, "\<cr>")
+ call term_wait(buf)
+ call StopVimInTerminal(buf)
+ call assert_equal(['4'], readfile('XTextChangedI3'))
+
+ call delete('XTextChangedI3')
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index 017ccdbbeb..db942bc3a3 100644
--- a/src/version.c
+++ b/src/version.c
@@ -705,6 +705,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 230,
+/**/
229,
/**/
228,