diff --git a/src/move.c b/src/move.c index 5d34947a58..f4bce40d7b 100644 --- a/src/move.c +++ b/src/move.c @@ -3120,6 +3120,7 @@ cursor_correct(void) ~(VALID_WROW|VALID_WCOL|VALID_CHEIGHT|VALID_CROW); } } + check_cursor_moved(curwin); curwin->w_valid |= VALID_TOPLINE; } diff --git a/src/testdir/test_normal.vim b/src/testdir/test_normal.vim index 35c290c8d7..aa24bceda5 100644 --- a/src/testdir/test_normal.vim +++ b/src/testdir/test_normal.vim @@ -4326,4 +4326,23 @@ func Test_normal_go() bwipe! endfunc +" Test for Ctrl-D with 'scrolloff' and narrow window does not get stuck. +func Test_scroll_longline_scrolloff() + 11new + 36vsplit + set scrolloff=5 + + call setline(1, ['']->repeat(5)) + call setline(6, ['foo'->repeat(20)]->repeat(2)) + call setline(8, ['bar'->repeat(30)]) + call setline(9, ['']->repeat(5)) + exe "normal! \" + call assert_equal(6, line('w0')) + exe "normal! \" + call assert_equal(7, line('w0')) + + set scrolloff& + bwipe! +endfunc + " vim: shiftwidth=2 sts=2 expandtab nofoldenable diff --git a/src/version.c b/src/version.c index 6f3f241784..e95226cdcd 100644 --- a/src/version.c +++ b/src/version.c @@ -704,6 +704,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 1297, /**/ 1296, /**/