Mercurial > vim
changeset 33171:db2e9816e400 v9.0.1866
patch 9.0.1866: undo is synced after character find
Commit: https://github.com/vim/vim/commit/dccc29c228f8336ef7dd069a447886639af4458e
Author: zeertzjq <zeertzjq@outlook.com>
Date: Mon Sep 4 22:25:07 2023 +0200
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: #13022
closes: #13024
Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: zeertzjq <zeertzjq@outlook.com>
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Mon, 04 Sep 2023 22:30:07 +0200 |
parents | 345c8a959d76 |
children | 6564d48fe98a |
files | src/normal.c src/testdir/test_undo.vim src/version.c |
diffstat | 3 files changed, 14 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/src/normal.c +++ b/src/normal.c @@ -570,7 +570,9 @@ normal_cmd_get_more_chars( // but when replaying a recording the next key is already in the // typeahead buffer, so record a <Nop> before that to prevent the // vpeekc() above from applying wrong mappings when replaying. + ++no_u_sync; gotchars_nop(); + --no_u_sync; } } --no_mapping;
--- a/src/testdir/test_undo.vim +++ b/src/testdir/test_undo.vim @@ -862,5 +862,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