From 65d3378009cf2b94e4a240d2c5c3d4d19fa7fc92 Mon Sep 17 00:00:00 2001 From: zeertzjq Date: Tue, 5 Sep 2023 06:25:51 +0800 Subject: vim-patch:9.0.1866: undo is synced after character find (#25021) vim-patch:9.0.1866: undo is synced after character find Problem: Undo is synced after character find. Solution: Set no_u_sync when calling gotchars_nop(). closes: vim/vim#13022 closes: vim/vim#13024 https://github.com/vim/vim/commit/dccc29c228f8336ef7dd069a447886639af4458e --- src/nvim/normal.c | 4 +++- test/old/testdir/test_undo.vim | 10 ++++++++++ 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/src/nvim/normal.c b/src/nvim/normal.c index 513fb5b202..4280d62a95 100644 --- a/src/nvim/normal.c +++ b/src/nvim/normal.c @@ -831,7 +831,7 @@ static void normal_get_additional_char(NormalState *s) // because if it's put back with vungetc() it's too late to apply // mapping. no_mapping--; - while (lang && (s->c = vpeekc()) > 0 + while ((s->c = vpeekc()) > 0 && (s->c >= 0x100 || MB_BYTE2LEN(vpeekc()) > 1)) { s->c = plain_vgetc(); if (!utf_iscomposing(s->c)) { @@ -848,7 +848,9 @@ static void normal_get_additional_char(NormalState *s) // but when replaying a recording the next key is already in the // typeahead buffer, so record a before that to prevent the // vpeekc() above from applying wrong mappings when replaying. + no_u_sync++; gotchars_nop(); + no_u_sync--; } } no_mapping--; diff --git a/test/old/testdir/test_undo.vim b/test/old/testdir/test_undo.vim index 2d7604b1bf..b75b6f9b0d 100644 --- a/test/old/testdir/test_undo.vim +++ b/test/old/testdir/test_undo.vim @@ -870,5 +870,15 @@ func Test_undo_after_write() call delete('Xtestfile.txt') endfunc +func Test_undo_range_normal() + new + call setline(1, ['asa', 'bsb']) + let &l:undolevels = &l:undolevels + %normal dfs + call assert_equal(['a', 'b'], getline(1, '$')) + undo + call assert_equal(['asa', 'bsb'], getline(1, '$')) + bwipe! +endfunc " vim: shiftwidth=2 sts=2 expandtab -- cgit