0
0
mirror of https://github.com/vim/vim.git synced 2025-09-24 03:44:06 -04:00

patch 7.4.2275

Problem:    ":diffoff!" does not remove filler lines.
Solution:   Force a redraw and invalidate the cursor. (closes #1014)
This commit is contained in:
Bram Moolenaar
2016-08-27 22:40:42 +02:00
parent 818078ddfb
commit e67d546f3c
3 changed files with 24 additions and 2 deletions

View File

@@ -1236,10 +1236,14 @@ ex_diffoff(exarg_T *eap)
: wp->w_p_fen_save; : wp->w_p_fen_save;
foldUpdateAll(wp); foldUpdateAll(wp);
/* make sure topline is not halfway a fold */
changed_window_setting_win(wp);
#endif #endif
} }
/* 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);

View File

@@ -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

View File

@@ -763,6 +763,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 */
/**/
2275,
/**/ /**/
2274, 2274,
/**/ /**/