]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1561: display wrong when moving cursor to above the top line v9.0.1561
authorLuuk van Baal <luukvbaal@gmail.com>
Mon, 15 May 2023 17:17:43 +0000 (18:17 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 15 May 2023 17:17:43 +0000 (18:17 +0100)
Problem:    Display wrong when moving cursor to above the top line and
            'smoothscroll' is set.
Solution:   Call adjust_skipcol() in more places and make it work better.
            (Luuk van Baal, closes #12395)

src/move.c
src/testdir/dumps/Test_display_cursor_long_line.dump [deleted file]
src/testdir/dumps/Test_display_cursor_long_line_1.dump [new file with mode: 0644]
src/testdir/dumps/Test_display_cursor_long_line_2.dump [new file with mode: 0644]
src/testdir/dumps/Test_display_cursor_long_line_3.dump [new file with mode: 0644]
src/testdir/dumps/Test_display_cursor_long_line_4.dump [new file with mode: 0644]
src/testdir/test_display.vim
src/testdir/test_scroll_opt.vim
src/textobject.c
src/version.c

index d969de2fc030ed9a2dae225d368aa09f28c9dcf6..93c101b794e91a4faa8c801082b532139428b515 100644 (file)
@@ -1960,12 +1960,14 @@ adjust_skipcol(void)
            curwin->w_skipcol -= width2;
        else
            curwin->w_skipcol -= width1;
-       redraw_later(UPD_NOT_VALID);
        scrolled = TRUE;
-       validate_virtcol();
     }
     if (scrolled)
+    {
+       validate_virtcol();
+       redraw_later(UPD_NOT_VALID);
        return;  // don't scroll in the other direction now
+    }
 
     int col = curwin->w_virtcol - curwin->w_skipcol + scrolloff_cols;
     int row = 0;
diff --git a/src/testdir/dumps/Test_display_cursor_long_line.dump b/src/testdir/dumps/Test_display_cursor_long_line.dump
deleted file mode 100644 (file)
index eafad8c..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-|<+0#4040ff13#ffffff0@2|b+0#0000000&@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| 
-|b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@2
-@2| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| 
-|b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@2
-@2| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| 
-|b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@2
-@2| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4| |b@4> 
-@57|2|,|6|0@1| @8|5|0|%| 
diff --git a/src/testdir/dumps/Test_display_cursor_long_line_1.dump b/src/testdir/dumps/Test_display_cursor_long_line_1.dump
new file mode 100644 (file)
index 0000000..a54a17f
--- /dev/null
@@ -0,0 +1,8 @@
+|<+0#4040ff13#ffffff0@2|b+0#0000000&@71
+@75
+@75
+@75
+@75
+@75
+@1>b| @72
+@57|2|,|7|5|2| @8|5|0|%| 
diff --git a/src/testdir/dumps/Test_display_cursor_long_line_2.dump b/src/testdir/dumps/Test_display_cursor_long_line_2.dump
new file mode 100644 (file)
index 0000000..cdae4ba
--- /dev/null
@@ -0,0 +1,8 @@
+|<+0#4040ff13#ffffff0@2|b+0#0000000&>b@70
+@75
+@75
+@75
+@75
+@75
+@75
+| @56|2|,|1| @10|5|0|%| 
diff --git a/src/testdir/dumps/Test_display_cursor_long_line_3.dump b/src/testdir/dumps/Test_display_cursor_long_line_3.dump
new file mode 100644 (file)
index 0000000..a736d9d
--- /dev/null
@@ -0,0 +1,8 @@
+| +0#af5f00255#ffffff0@1|2| |b+0#0000000&| >b@68
+@75
+@75
+@75
+@75
+@75
+@75
+| @56|2|,|3| @10|5|0|%| 
diff --git a/src/testdir/dumps/Test_display_cursor_long_line_4.dump b/src/testdir/dumps/Test_display_cursor_long_line_4.dump
new file mode 100644 (file)
index 0000000..0f54c43
--- /dev/null
@@ -0,0 +1,8 @@
+| +0#af5f00255#ffffff0@1|2| >b+0#0000000&| |b@68
+@75
+@75
+@75
+@75
+@75
+@75
+| @56|2|,|1| @10|5|0|%| 
index 1332ab55e8db7486f7f3d8a2630fb5984faa1ccc..f817a8502d785ae21265688c52e5fe1600cc66f8 100644 (file)
@@ -507,14 +507,29 @@ func Test_display_cursor_long_line()
   CheckScreendump
 
   let lines =<< trim END
-    call setline(1, ['a', 'bbbbb '->repeat(100), 'c'])
+    call setline(1, ['a', 'b ' .. 'bbbbb'->repeat(150), 'c'])
     norm $j
   END
 
   call writefile(lines, 'XdispCursorLongline', 'D')
   let buf = RunVimInTerminal('-S XdispCursorLongline', #{rows: 8})
 
-  call VerifyScreenDump(buf, 'Test_display_cursor_long_line', {})
+  call VerifyScreenDump(buf, 'Test_display_cursor_long_line_1', {})
+
+  " FIXME: moving the cursor above the topline does not set w_skipcol
+  " correctly with cpo+=n and zero scrolloff (curs_columns() extra == 1).
+  call term_sendkeys(buf, ":set number cpo+=n scrolloff=0\<CR>")
+  call term_sendkeys(buf, '$0')
+  call VerifyScreenDump(buf, 'Test_display_cursor_long_line_2', {})
+
+  " Going to the start of the line with "b" did not set w_skipcol correctly
+  " with 'smoothscroll'.
+   call term_sendkeys(buf, ":set smoothscroll\<CR>")
+   call term_sendkeys(buf, '$b')
+   call VerifyScreenDump(buf, 'Test_display_cursor_long_line_3', {})
+  " Same for "ge".
+   call term_sendkeys(buf, '$ge')
+   call VerifyScreenDump(buf, 'Test_display_cursor_long_line_4', {})
 
   call StopVimInTerminal(buf)
 endfunc
index 636e7b76c50bf24c5de98aaa3c5e7744907d106a..469cf127196485e0a83625dce2cb52afd5cb1e8b 100644 (file)
@@ -502,7 +502,7 @@ func Test_smoothscroll_cursor_position()
   " regardless of number and cpo-=n.
   setl number list listchars=precedes:< cpo-=n
   call s:check_col_calc(5, 1, 1)
-  exe "normal 2|\<C-E>"
+  exe "normal 3|\<C-E>h"
   call s:check_col_calc(6, 1, 18)
   norm h
   call s:check_col_calc(5, 2, 17)
index d77ec961abae767edda7ff19b3bfd1b591f5cfcf..b315d0320c449076758f1dbdcc2c8bf3de4c6a4a 100644 (file)
@@ -472,6 +472,7 @@ bck_word(long count, int bigword, int stop)
 finished:
        stop = FALSE;
     }
+    adjust_skipcol();
     return OK;
 }
 
@@ -598,6 +599,7 @@ bckend_word(
                return OK;
        }
     }
+    adjust_skipcol();
     return OK;
 }
 
index 7d691e37268f37e3e949054fbf0a9e028ee49613..9f6484354c3456a858eae081b7a8ba2e7e0a8902 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1561,
 /**/
     1560,
 /**/