Skip to content

Commit

Permalink
patch 7.4.2275
Browse files Browse the repository at this point in the history
Problem:    ":diffoff!" does not remove filler lines.
Solution:   Force a redraw and invalidate the cursor. (closes #1014)
  • Loading branch information
brammool committed Aug 27, 2016
1 parent 818078d commit e67d546
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 2 deletions.
8 changes: 6 additions & 2 deletions src/diff.c
Original file line number Diff line number Diff line change
Expand Up @@ -1236,10 +1236,14 @@ ex_diffoff(exarg_T *eap)
: wp->w_p_fen_save;

foldUpdateAll(wp);
/* make sure topline is not halfway a fold */
changed_window_setting_win(wp);
#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. */
diff_buf_adjust(wp);
Expand Down
16 changes: 16 additions & 0 deletions src/testdir/test_diffmode.vim
Original file line number Diff line number Diff line change
Expand Up @@ -202,3 +202,19 @@ func Test_diffget_diffput()
bwipe!
enew!
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
2 changes: 2 additions & 0 deletions src/version.c
Original file line number Diff line number Diff line change
Expand Up @@ -763,6 +763,8 @@ static char *(features[]) =

static int included_patches[] =
{ /* Add new patch number below this line */
/**/
2275,
/**/
2274,
/**/
Expand Down

0 comments on commit e67d546

Please sign in to comment.