0
0
mirror of https://github.com/vim/vim.git synced 2025-09-27 04:14:06 -04:00

patch 7.4.1084

Problem:    Using "." to repeat CTRL-A in Visual mode increments the wrong
            numbers.
Solution:   Append right size to the redo buffer. (Ozaki Kiichi)
This commit is contained in:
Bram Moolenaar
2016-01-10 20:08:03 +01:00
parent 4514d2769b
commit e1edc1caba
3 changed files with 25 additions and 1 deletions

View File

@@ -3632,7 +3632,7 @@ prep_redo_visual(cap)
else if (curbuf->b_visual.vi_end.col > curbuf->b_visual.vi_start.col) else if (curbuf->b_visual.vi_end.col > curbuf->b_visual.vi_start.col)
{ {
AppendNumberToRedobuff(curbuf->b_visual.vi_end.col AppendNumberToRedobuff(curbuf->b_visual.vi_end.col
- curbuf->b_visual.vi_start.col - 1); - curbuf->b_visual.vi_start.col);
AppendCharToRedobuff(' '); AppendCharToRedobuff(' ');
} }
} }

View File

@@ -556,6 +556,7 @@ func Test_visual_increment_26()
exec "norm! \<C-V>$\<C-A>" exec "norm! \<C-V>$\<C-A>"
call assert_equal(["0b11111111111111111111111111111111"], getline(1, '$')) call assert_equal(["0b11111111111111111111111111111111"], getline(1, '$'))
call assert_equal([0, 1, 1, 0], getpos('.')) call assert_equal([0, 1, 1, 0], getpos('.'))
set nrformats-=alpha
endfunc endfunc
" 27) increment with 'rightreft', if supported " 27) increment with 'rightreft', if supported
@@ -575,4 +576,25 @@ func Test_visual_increment_27()
endif endif
endfunc endfunc
" 28) block-wise increment and dot-repeat
" Text:
" 1 23
" 4 56
"
" Expected:
" 1) f2 Ctrl-V jl <ctrl-a>, repeat twice afterwards with .
" 1 26
" 4 59
"
" Try with and without indent.
func Test_visual_increment_28()
call setline(1, [" 1 23", " 4 56"])
exec "norm! ggf2\<C-V>jl\<C-A>.."
call assert_equal([" 1 26", " 4 59"], getline(1, 2))
call setline(1, ["1 23", "4 56"])
exec "norm! ggf2\<C-V>jl\<C-A>.."
call assert_equal(["1 26", "4 59"], getline(1, 2))
endfunc
" vim: tabstop=2 shiftwidth=2 expandtab " vim: tabstop=2 shiftwidth=2 expandtab

View File

@@ -741,6 +741,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 */
/**/
1084,
/**/ /**/
1083, 1083,
/**/ /**/