Mercurial > vim
diff src/edit.c @ 34703:d432af20fe54 v9.1.0230
patch 9.1.0230: TextChanged autocommand not triggered under some circumstances
Commit: https://github.com/vim/vim/commit/86032702932995db74fed265ba99ae0c823cb75d
Author: Christian Brabandt <cb@256bit.org>
Date: Sun Mar 31 18:38:09 2024 +0200
patch 9.1.0230: TextChanged autocommand not triggered under some circumstances
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>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Sun, 31 Mar 2024 18:45:03 +0200 |
parents | bfd2c0032686 |
children | d537272fa503 |
line wrap: on
line diff
--- 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); }