mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:7.4.2275
Problem: ":diffoff!" does not remove filler lines.
Solution: Force a redraw and invalidate the cursor. (closes vim/vim#1014)
e67d546f3c
This commit is contained in:
parent
cca8d2751a
commit
7629176fb1
@ -1154,10 +1154,13 @@ void ex_diffoff(exarg_T *eap)
|
|||||||
}
|
}
|
||||||
|
|
||||||
foldUpdateAll(wp);
|
foldUpdateAll(wp);
|
||||||
|
|
||||||
// make sure topline is not halfway through a fold
|
|
||||||
changed_window_setting_win(wp);
|
|
||||||
}
|
}
|
||||||
|
// remove filler lines
|
||||||
|
wp->w_topfill = 0;
|
||||||
|
|
||||||
|
// make sure topline is not halfway a fold and cursor is
|
||||||
|
// invalidated
|
||||||
|
changed_window_setting_win(wp);
|
||||||
|
|
||||||
// Note: 'sbo' is not restored, it's a global option.
|
// Note: 'sbo' is not restored, it's a global option.
|
||||||
diff_buf_adjust(wp);
|
diff_buf_adjust(wp);
|
||||||
|
@ -202,3 +202,19 @@ func Test_diffget_diffput()
|
|||||||
bwipe!
|
bwipe!
|
||||||
enew!
|
enew!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_diffoff()
|
||||||
|
enew!
|
||||||
|
call setline(1, ['Two', 'Three'])
|
||||||
|
let normattr = screenattr(1, 1)
|
||||||
|
diffthis
|
||||||
|
botright vert new
|
||||||
|
call setline(1, ['One', '', 'Two', 'Three'])
|
||||||
|
diffthis
|
||||||
|
redraw
|
||||||
|
diffoff!
|
||||||
|
redraw
|
||||||
|
call assert_equal(normattr, screenattr(1, 1))
|
||||||
|
bwipe!
|
||||||
|
bwipe!
|
||||||
|
endfunc
|
||||||
|
@ -165,7 +165,7 @@ static int included_patches[] = {
|
|||||||
// 2278 NA
|
// 2278 NA
|
||||||
2277,
|
2277,
|
||||||
// 2276,
|
// 2276,
|
||||||
// 2275,
|
2275,
|
||||||
2274,
|
2274,
|
||||||
2273,
|
2273,
|
||||||
2272,
|
2272,
|
||||||
|
Loading…
Reference in New Issue
Block a user