mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 9.0.0671: negative topline using CTRL-Y with 'smoothscroll' and 'diff'
Problem: Negative topline using CTRL-Y with 'smoothscroll' and 'diff'. (Ernie Rael) Solution: Only use 'smoothscroll' when 'wrap' is set.
This commit is contained in:
parent
c9f5f73206
commit
1a58e1d97c
22
src/move.c
22
src/move.c
@ -1458,10 +1458,11 @@ scrolldown(
|
|||||||
long done = 0; // total # of physical lines done
|
long done = 0; // total # of physical lines done
|
||||||
int wrow;
|
int wrow;
|
||||||
int moved = FALSE;
|
int moved = FALSE;
|
||||||
|
int do_sms = curwin->w_p_wrap && curwin->w_p_sms;
|
||||||
int width1 = 0;
|
int width1 = 0;
|
||||||
int width2 = 0;
|
int width2 = 0;
|
||||||
|
|
||||||
if (curwin->w_p_wrap && curwin->w_p_sms)
|
if (do_sms)
|
||||||
{
|
{
|
||||||
width1 = curwin->w_width - curwin_col_off();
|
width1 = curwin->w_width - curwin_col_off();
|
||||||
width2 = width1 + curwin_col_off2();
|
width2 = width1 + curwin_col_off2();
|
||||||
@ -1474,7 +1475,7 @@ scrolldown(
|
|||||||
(void)hasFolding(curwin->w_topline, &curwin->w_topline, NULL);
|
(void)hasFolding(curwin->w_topline, &curwin->w_topline, NULL);
|
||||||
#endif
|
#endif
|
||||||
validate_cursor(); // w_wrow needs to be valid
|
validate_cursor(); // w_wrow needs to be valid
|
||||||
while (line_count-- > 0)
|
for (int todo = line_count; todo > 0; --todo)
|
||||||
{
|
{
|
||||||
#ifdef FEAT_DIFF
|
#ifdef FEAT_DIFF
|
||||||
if (curwin->w_topfill < diff_check(curwin, curwin->w_topline)
|
if (curwin->w_topfill < diff_check(curwin, curwin->w_topline)
|
||||||
@ -1488,10 +1489,9 @@ scrolldown(
|
|||||||
{
|
{
|
||||||
// break when at the very top
|
// break when at the very top
|
||||||
if (curwin->w_topline == 1
|
if (curwin->w_topline == 1
|
||||||
&& (!curwin->w_p_sms || curwin->w_skipcol < width1))
|
&& (!do_sms || curwin->w_skipcol < width1))
|
||||||
break;
|
break;
|
||||||
if (curwin->w_p_wrap && curwin->w_p_sms
|
if (do_sms && curwin->w_skipcol >= width1)
|
||||||
&& curwin->w_skipcol >= width1)
|
|
||||||
{
|
{
|
||||||
// scroll a screen line down
|
// scroll a screen line down
|
||||||
if (curwin->w_skipcol >= width1 + width2)
|
if (curwin->w_skipcol >= width1 + width2)
|
||||||
@ -1515,13 +1515,13 @@ scrolldown(
|
|||||||
{
|
{
|
||||||
++done;
|
++done;
|
||||||
if (!byfold)
|
if (!byfold)
|
||||||
line_count -= curwin->w_topline - first - 1;
|
todo -= curwin->w_topline - first - 1;
|
||||||
curwin->w_botline -= curwin->w_topline - first;
|
curwin->w_botline -= curwin->w_topline - first;
|
||||||
curwin->w_topline = first;
|
curwin->w_topline = first;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
if (curwin->w_p_wrap && curwin->w_p_sms)
|
if (do_sms)
|
||||||
{
|
{
|
||||||
int size = win_linetabsize(curwin, curwin->w_topline,
|
int size = win_linetabsize(curwin, curwin->w_topline,
|
||||||
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
||||||
@ -1602,9 +1602,9 @@ scrollup(
|
|||||||
long line_count,
|
long line_count,
|
||||||
int byfold UNUSED) // TRUE: count a closed fold as one line
|
int byfold UNUSED) // TRUE: count a closed fold as one line
|
||||||
{
|
{
|
||||||
int do_smoothscroll = curwin->w_p_wrap && curwin->w_p_sms;
|
int do_sms = curwin->w_p_wrap && curwin->w_p_sms;
|
||||||
|
|
||||||
if (do_smoothscroll
|
if (do_sms
|
||||||
# ifdef FEAT_FOLDING
|
# ifdef FEAT_FOLDING
|
||||||
|| (byfold && hasAnyFolding(curwin))
|
|| (byfold && hasAnyFolding(curwin))
|
||||||
# endif
|
# endif
|
||||||
@ -1618,7 +1618,7 @@ scrollup(
|
|||||||
int size = 0;
|
int size = 0;
|
||||||
linenr_T prev_topline = curwin->w_topline;
|
linenr_T prev_topline = curwin->w_topline;
|
||||||
|
|
||||||
if (do_smoothscroll)
|
if (do_sms)
|
||||||
size = win_linetabsize(curwin, curwin->w_topline,
|
size = win_linetabsize(curwin, curwin->w_topline,
|
||||||
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
||||||
|
|
||||||
@ -1675,7 +1675,7 @@ scrollup(
|
|||||||
curwin->w_topfill = diff_check_fill(curwin, lnum);
|
curwin->w_topfill = diff_check_fill(curwin, lnum);
|
||||||
# endif
|
# endif
|
||||||
curwin->w_skipcol = 0;
|
curwin->w_skipcol = 0;
|
||||||
if (todo > 1 && do_smoothscroll)
|
if (todo > 1 && do_sms)
|
||||||
size = win_linetabsize(curwin, curwin->w_topline,
|
size = win_linetabsize(curwin, curwin->w_topline,
|
||||||
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
ml_get(curwin->w_topline), (colnr_T)MAXCOL);
|
||||||
}
|
}
|
||||||
|
8
src/testdir/dumps/Test_smooth_diff_1.dump
Normal file
8
src/testdir/dumps/Test_smooth_diff_1.dump
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
|-+0#0000e05#a8a8a8255| >j+0#0000000#ffffff0|u|s|t| |s|o|m|e| |t|e|x|t| |h|e|r|e| @53
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|~| @73
|
||||||
|
|[+3#0000000&|N|o| |N|a|m|e|]| |[|+|]| @43|1|,|1| @11|A|l@1
|
||||||
|
|-+0#0000e05#a8a8a8255| |j+0#0000000#ffffff0|u|s|t| |s|o|m|e| |t|e|x|t| |h|e|r|e| @53
|
||||||
|
|~+0#4040ff13&| @73
|
||||||
|
|[+1#0000000&|N|o| |N|a|m|e|]| |[|+|]| @43|1|,|1| @11|A|l@1
|
||||||
|
| +0&&@74
|
@ -141,6 +141,32 @@ func Test_smoothscroll_number()
|
|||||||
call StopVimInTerminal(buf)
|
call StopVimInTerminal(buf)
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_smoothscroll_diff_mode()
|
||||||
|
CheckScreendump
|
||||||
|
|
||||||
|
let lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
var text = 'just some text here'
|
||||||
|
setline(1, text)
|
||||||
|
set smoothscroll
|
||||||
|
diffthis
|
||||||
|
new
|
||||||
|
setline(1, text)
|
||||||
|
set smoothscroll
|
||||||
|
diffthis
|
||||||
|
END
|
||||||
|
call writefile(lines, 'XSmoothDiff', 'D')
|
||||||
|
let buf = RunVimInTerminal('-S XSmoothDiff', #{rows: 8})
|
||||||
|
|
||||||
|
call VerifyScreenDump(buf, 'Test_smooth_diff_1', {})
|
||||||
|
call term_sendkeys(buf, "\<C-Y>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_smooth_diff_1', {})
|
||||||
|
call term_sendkeys(buf, "\<C-E>")
|
||||||
|
call VerifyScreenDump(buf, 'Test_smooth_diff_1', {})
|
||||||
|
|
||||||
|
call StopVimInTerminal(buf)
|
||||||
|
endfunc
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
" vim: shiftwidth=2 sts=2 expandtab
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@ -699,6 +699,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 */
|
||||||
|
/**/
|
||||||
|
671,
|
||||||
/**/
|
/**/
|
||||||
670,
|
670,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user