forked from aniani/vim
patch 8.2.3467: CursorHoldI event interferes with "CTRL-G U"
Problem: CursorHoldI event interferes with "CTRL-G U". (Naohiro Ono) Solution: Restore the flag for "CTRL-G U" after triggering CursorHoldI. (closes #8937)
This commit is contained in:
@@ -1057,6 +1057,9 @@ doESCkey:
|
|||||||
case K_CURSORHOLD: // Didn't type something for a while.
|
case K_CURSORHOLD: // Didn't type something for a while.
|
||||||
ins_apply_autocmds(EVENT_CURSORHOLDI);
|
ins_apply_autocmds(EVENT_CURSORHOLDI);
|
||||||
did_cursorhold = TRUE;
|
did_cursorhold = TRUE;
|
||||||
|
// If CTRL-G U was used apply it to the next typed key.
|
||||||
|
if (dont_sync_undo == TRUE)
|
||||||
|
dont_sync_undo = MAYBE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifdef FEAT_GUI_MSWIN
|
#ifdef FEAT_GUI_MSWIN
|
||||||
|
@@ -100,6 +100,22 @@ if has('timers')
|
|||||||
set updatetime&
|
set updatetime&
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_cursorhold_insert_ctrl_g_U()
|
||||||
|
au CursorHoldI * :
|
||||||
|
set updatetime=20
|
||||||
|
new
|
||||||
|
call timer_start(100, { -> feedkeys("\<Left>foo\<Esc>", 't') })
|
||||||
|
call feedkeys("i()\<C-g>U", 'tx!')
|
||||||
|
sleep 200m
|
||||||
|
call assert_equal('(foo)', getline(1))
|
||||||
|
undo
|
||||||
|
call assert_equal('', getline(1))
|
||||||
|
|
||||||
|
bwipe!
|
||||||
|
au! CursorHoldI
|
||||||
|
set updatetime&
|
||||||
|
endfunc
|
||||||
|
|
||||||
func Test_OptionSet_modeline()
|
func Test_OptionSet_modeline()
|
||||||
call test_override('starting', 1)
|
call test_override('starting', 1)
|
||||||
au! OptionSet
|
au! OptionSet
|
||||||
|
@@ -757,6 +757,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
3467,
|
||||||
/**/
|
/**/
|
||||||
3466,
|
3466,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user