]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1610: display is wrong when 'smoothscroll' is set v9.0.1610
authorzeertzjq <zeertzjq@outlook.com>
Mon, 5 Jun 2023 17:41:35 +0000 (18:41 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 5 Jun 2023 17:41:35 +0000 (18:41 +0100)
Problem:    Display is wrong when 'smoothscroll' is set and scrolling multiple
            lines.
Solution:   Redraw with UPD_NOT_VALID when "skipcol" is or was set.
            (closes #12490, closes #12468)

src/move.c
src/testdir/dumps/Test_smooth_multi_skipcol_1.dump
src/testdir/dumps/Test_smooth_multi_skipcol_2.dump
src/testdir/dumps/Test_smooth_multi_skipcol_3.dump [new file with mode: 0644]
src/testdir/test_scroll_opt.vim
src/version.c

index e021d71c59f0a007cd4435f8297dedcf658967a8..4cd4d1c2bcf0f221217a573c4740f4e20bf6ad2c 100644 (file)
@@ -1786,7 +1786,6 @@ scrollup(
        int         width1 = curwin->w_width - curwin_col_off();
        int         width2 = width1 + curwin_col_off2();
        int         size = 0;
-       linenr_T    prev_topline = curwin->w_topline;
        colnr_T     prev_skipcol = curwin->w_skipcol;
 
        if (do_sms)
@@ -1850,10 +1849,9 @@ scrollup(
            }
        }
 
-       // TODO: is comparing w_topline with prev_topline still needed?
-       if (curwin->w_topline == prev_topline
-               || curwin->w_skipcol != prev_skipcol)
-           // need to redraw because wl_size of the topline may now be invalid
+       if (prev_skipcol > 0 || curwin->w_skipcol > 0)
+           // need to redraw more, because wl_size of the (new) topline may
+           // now be invalid
            redraw_later(UPD_NOT_VALID);
     }
     else
index 80f563b715ebad15142765a8e4fd61678dce3451..f642e9263afcfab1c0121a4b1250d8523ebdac6b 100644 (file)
@@ -2,8 +2,8 @@
 | +0&&@39
 |a@39
 @10| @29
-@40
-@40
+|a@39
+@10| @29
 @40
 @40
 |b@2| @36
index 9ef4aaf789294a9faf78aaeadadc219dfaf62052..7431351c78f8d07b14a87ccad6f4d9666fc0ec48 100644 (file)
@@ -1,6 +1,6 @@
 |<+0#4040ff13#ffffff0@2|a+8#0000000&@5>a| @29
-| +0&&@39
-@40
+|a+0&&@39
+@10| @29
 @40
 @40
 |b@2| @36
diff --git a/src/testdir/dumps/Test_smooth_multi_skipcol_3.dump b/src/testdir/dumps/Test_smooth_multi_skipcol_3.dump
new file mode 100644 (file)
index 0000000..a79f3fe
--- /dev/null
@@ -0,0 +1,10 @@
+|<+0#4040ff13#ffffff0@2|a+8#0000000&@5>a| @29
+| +0&&@39
+@40
+|b@2| @36
+|c@2| @36
+|~+0#4040ff13&| @38
+|~| @38
+|~| @38
+|~| @38
+| +0#0000000&@21|4|,|5|0| @9|B|o|t| 
index 3806486bf654275845219c2a5825d1631a759eca..f8b4b4f09ee031ba1f57671cd804a505ed1e4cfa 100644 (file)
@@ -798,10 +798,11 @@ func Test_smoothscroll_multi_skipcol()
 
   let lines =<< trim END
       setlocal cursorline scrolloff=0 smoothscroll
-      call setline(1, repeat([''], 9))
+      call setline(1, repeat([''], 8))
       call setline(3, repeat('a', 50))
-      call setline(8, 'bbb')
-      call setline(9, 'ccc')
+      call setline(4, repeat('a', 50))
+      call setline(7, 'bbb')
+      call setline(8, 'ccc')
       redraw
   END
   call writefile(lines, 'XSmoothMultiSkipcol', 'D')
@@ -811,6 +812,9 @@ func Test_smoothscroll_multi_skipcol()
   call term_sendkeys(buf, "3\<C-E>")
   call VerifyScreenDump(buf, 'Test_smooth_multi_skipcol_2', {})
 
+  call term_sendkeys(buf, "2\<C-E>")
+  call VerifyScreenDump(buf, 'Test_smooth_multi_skipcol_3', {})
+
   call StopVimInTerminal(buf)
 endfunc
 
index 12884906700c156dc1678a82a7baba23944d1c2d..a8f21046987f2e3574cb4fcaae57996340e7c1ed 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1610,
 /**/
     1609,
 /**/