mirror of
https://github.com/neovim/neovim.git
synced 2026-04-19 22:10:45 +00:00
vim-patch:9.1.1473: inconsistent range arg for :diffget/diffput (#34588)
Problem: inconsistent range arg for :diffget/diffput
Solution: fix the range specification, place the cursor for :diffput and
:diffget consistently on the last line (Yee Cheng Chin)
Previously, `:<range>diffget` only allowed using 1 or above in the range
value, making it impossible to use the command for a diff block at the
beginning of the file. Fix the range specification so the user can now
use 0 to specify the space before the first line. This allows
`:0,$+1diffget` to work to retrieve all the changes from the other file
instead of missing the first diff block. Also do this for `:diffput`.
Also, make `:diffput` work more similar to `:diffget`. Make it so that
if the cursor is on the last line and a new line is inserted in the
other file, doing `:diffput` will select that diff block below the line,
just like `:diffget` would.
Also clean up the logic a little bit for edge cases and for handling
line matched diff blocks better.
closes: vim/vim#17579
d75ab0cbf5
Co-authored-by: Yee Cheng Chin <ychin.git@gmail.com>
This commit is contained in:
@@ -288,6 +288,63 @@ func Test_diffget_diffput_range()
|
||||
%bw!
|
||||
endfunc
|
||||
|
||||
" Test :diffget/:diffput handling of added/deleted lines
|
||||
func Test_diffget_diffput_deleted_lines()
|
||||
call setline(1, ['2','4','6'])
|
||||
diffthis
|
||||
new
|
||||
call setline(1, range(1,7))
|
||||
diffthis
|
||||
wincmd w
|
||||
|
||||
3,3diffget " get nothing
|
||||
call assert_equal(['2', '4', '6'], getline(1, '$'))
|
||||
3,4diffget " get the last insertion past the end of file
|
||||
call assert_equal(['2', '4', '6', '7'], getline(1, '$'))
|
||||
0,1diffget " get the first insertion above first line
|
||||
call assert_equal(['1', '2', '4', '6', '7'], getline(1, '$'))
|
||||
|
||||
" When using non-range diffget on the last line, it should get the
|
||||
" change above or at the line as usual, but if the only change is below the
|
||||
" last line, diffget should get that instead.
|
||||
1,$delete
|
||||
call setline(1, ['2','4','6'])
|
||||
diffupdate
|
||||
norm Gdo
|
||||
call assert_equal(['2', '4', '5', '6'], getline(1, '$'))
|
||||
norm Gdo
|
||||
call assert_equal(['2', '4', '5', '6', '7'], getline(1, '$'))
|
||||
|
||||
" Test non-range diffput on last line with the same logic
|
||||
1,$delete
|
||||
call setline(1, ['2','4','6'])
|
||||
diffupdate
|
||||
norm Gdp
|
||||
wincmd w
|
||||
call assert_equal(['1', '2', '3', '4', '6', '7'], getline(1, '$'))
|
||||
wincmd w
|
||||
norm Gdp
|
||||
wincmd w
|
||||
call assert_equal(['1', '2', '3', '4', '6'], getline(1, '$'))
|
||||
call setline(1, range(1,7))
|
||||
diffupdate
|
||||
wincmd w
|
||||
|
||||
" Test that 0,$+1 will get/put all changes from/to the other buffer
|
||||
1,$delete
|
||||
call setline(1, ['2','4','6'])
|
||||
diffupdate
|
||||
0,$+1diffget
|
||||
call assert_equal(['1', '2', '3', '4', '5', '6', '7'], getline(1, '$'))
|
||||
1,$delete
|
||||
call setline(1, ['2','4','6'])
|
||||
diffupdate
|
||||
0,$+1diffput
|
||||
wincmd w
|
||||
call assert_equal(['2', '4', '6'], getline(1, '$'))
|
||||
%bw!
|
||||
endfunc
|
||||
|
||||
" Test for :diffget/:diffput with an empty buffer and a non-empty buffer
|
||||
func Test_diffget_diffput_empty_buffer()
|
||||
%d _
|
||||
|
||||
Reference in New Issue
Block a user