vim-patch:9.0.1664: divide by zero when scrolling with 'smoothscroll' set

Problem:    Divide by zero when scrolling with 'smoothscroll' set.
Solution:   Avoid using a negative width. (closes vim/vim#12540, closes vim/vim#12528)

8154e642aa

Co-authored-by: fullwaywang <fullwaywang@tencent.com>
This commit is contained in:
zeertzjq 2023-06-25 08:15:45 +08:00
parent 0ca2d11c1f
commit 3b6fb3fefd
3 changed files with 78 additions and 10 deletions

View File

@ -1954,6 +1954,7 @@ void scroll_cursor_bot(int min_scroll, int set_topbot)
int top_plines = plines_win_nofill(curwin, curwin->w_topline, false);
int skip_lines = 0;
int width1 = curwin->w_width_inner - curwin_col_off();
if (width1 > 0) {
int width2 = width1 + curwin_col_off2();
// similar formula is used in curs_columns()
if (curwin->w_skipcol > width1) {
@ -1968,6 +1969,7 @@ void scroll_cursor_bot(int min_scroll, int set_topbot)
}
}
}
}
lineoff_T boff;
// Stop counting lines to scroll when

View File

@ -939,6 +939,48 @@ describe('smoothscroll', function()
]])
end)
-- oldtest: Test_smoothscroll_zero_width_scroll_cursor_bot()
it('does not divide by zero in zero-width window', function()
screen:try_resize(12, 19)
screen:set_default_attr_ids({
[1] = {foreground = Screen.colors.Brown}; -- LineNr
[2] = {bold = true, reverse = true}; -- StatusLine
[3] = {reverse = true}; -- StatusLineNC
})
exec([[
silent normal yy
silent normal 19p
winsize 0 19
vsplit
vertical resize 0
set foldcolumn=1
set number
set smoothscroll
silent normal 20G
]])
screen:expect([[
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1: } |
{1:^ } |
{2:< }{3:<ame] [+] }|
|
]])
end)
it("works with virt_lines above and below", function()
screen:try_resize(55, 7)
exec([=[

View File

@ -836,4 +836,28 @@ func Test_smoothscroll_multi_skipcol()
call StopVimInTerminal(buf)
endfunc
" this was dividing by zero bug in scroll_cursor_bot
func Test_smoothscroll_zero_width_scroll_cursor_bot()
CheckScreendump
let lines =<< trim END
silent normal yy
silent normal 19p
winsize 0 19
vsplit
vertical resize 0
set foldcolumn=1
set number
set smoothscroll
silent normal 20G
END
call writefile(lines, 'XSmoothScrollZeroBot', 'D')
let buf = RunVimInTerminal('-u NONE -S XSmoothScrollZeroBot', #{rows: 19, wait_for_ruler: 0})
call TermWait(buf, 1000)
call VerifyScreenDump(buf, 'Test_smoothscroll_zero_bot', {})
call StopVimInTerminal(buf)
endfunc
" vim: shiftwidth=2 sts=2 expandtab