]> granicus.if.org Git - vim/commitdiff
patch 9.0.0893: 'smoothscroll' cursor calculations wrong when 'number' is set v9.0.0893
authorYee Cheng Chin <ychin.git@gmail.com>
Thu, 17 Nov 2022 12:41:42 +0000 (12:41 +0000)
committerBram Moolenaar <Bram@vim.org>
Thu, 17 Nov 2022 12:41:42 +0000 (12:41 +0000)
Problem:    'smoothscroll' cursor calculations wrong when 'number' is set.
Solution:   Correct the code that computes the width. (closes #11492)

src/move.c
src/testdir/dumps/Test_smooth_number_7.dump
src/testdir/test_scroll_opt.vim
src/version.c

index 3a5f806b5dcc5adc7c7aa6bb6d21dde702e4700f..3c359468e5bad85e8a5393890ddafc8d99721f86 100644 (file)
@@ -1127,13 +1127,15 @@ curs_columns(
                && curwin->w_skipcol > 0
                && curwin->w_wcol >= curwin->w_skipcol)
        {
-           // w_skipcol excludes win_col_off().  Include it here, since w_wcol
-           // counts actual screen columns.
+           // Deduct by multiples of width2.  This allows the long line
+           // wrapping formula below to correctly calculate the w_wcol value
+           // when wrapping.
            if (curwin->w_skipcol <= width1)
-               curwin->w_wcol -= curwin->w_width;
+               curwin->w_wcol -= width2;
            else
-               curwin->w_wcol -= curwin->w_width
+               curwin->w_wcol -= width2
                               * (((curwin->w_skipcol - width1) / width2) + 1);
+
            did_sub_skipcol = TRUE;
        }
 
index 1f70072829f055d790f9074171abe2bea656da0f..1199593f4d2e96dc43ab25448ca36415cb143736 100644 (file)
@@ -1,5 +1,5 @@
-|2+0#af5f00255#ffffff0|<+0#4040ff13&@2|o+0#0000000&|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n>g| |t|e
-| +0#af5f00255&@3|x+0#0000000&|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r
+|2+0#af5f00255#ffffff0|<+0#4040ff13&@2|o+0#0000000&|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e
+| +0#af5f00255&@3>x+0#0000000&|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r
 | +0#af5f00255&@3|y+0#0000000&| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g
 | +0#af5f00255&@3| +0#0000000&|t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| |v|e|r|y| |l|o|n|g| |t|e|x|t| 
 | +0#af5f00255&@1|1| |t+0#0000000&|h|r|e@1| @30
index aba8603a657e1db7fee29a92487ea10d2243ae99..d863d039ba04a3072a096e1acbb30f81f641b41d 100644 (file)
@@ -308,5 +308,71 @@ func Test_smoothscroll_one_long_line()
   call StopVimInTerminal(buf)
 endfunc
 
+" Test that if the current cursor is on a smooth scrolled line, we correctly
+" reposition it. Also check that we don't miscalculate the values by checking
+" the consistency between wincol() and col('.') as they are calculated
+" separately in code.
+func Test_smoothscroll_cursor_position()
+  call NewWindow(10, 20)
+  setl smoothscroll wrap
+  call setline(1, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ")
+
+  func s:check_col_calc(win_col, win_line, buf_col)
+    call assert_equal(a:win_col, wincol())
+    call assert_equal(a:win_line, winline())
+    call assert_equal(a:buf_col, col('.'))
+  endfunc
+
+  call s:check_col_calc(1, 1, 1)
+  exe "normal \<C-E>"
+
+  " Move down another line to avoid blocking the <<< display
+  call s:check_col_calc(1, 2, 41)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(1, 3, 41)
+  normal ggg$
+  exe "normal \<C-E>"
+
+  " Move down only 1 line when we are out of the range of the <<< display
+  call s:check_col_calc(20, 1, 40)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(20, 2, 40)
+  normal gg
+
+  " Test number, where we have indented lines
+  setl number
+  call s:check_col_calc(5, 1, 1)
+  exe "normal \<C-E>"
+  call s:check_col_calc(5, 2, 33)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(5, 3, 33)
+  normal ggg$
+  exe "normal \<C-E>"
+  call s:check_col_calc(20, 1, 32)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(20, 2, 32)
+  normal gg
+
+  " Test number + showbreak, so test that the additional indentation works
+  setl number showbreak=+++
+  call s:check_col_calc(5, 1, 1)
+  exe "normal \<C-E>"
+  call s:check_col_calc(8, 2, 30)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(8, 3, 30)
+  normal gg
+
+  " Test number + cpo+=n mode, where wrapped lines aren't indented
+  setl number cpo+=n showbreak=
+  call s:check_col_calc(5, 1, 1)
+  exe "normal \<C-E>"
+  call s:check_col_calc(1, 2, 37)
+  exe "normal \<C-Y>"
+  call s:check_col_calc(1, 3, 37)
+  normal gg
+
+  bwipeout!
+endfunc
+
 
 " vim: shiftwidth=2 sts=2 expandtab
index b526652de3efc4b61a6f576a3b81a09e70409406..cfdd33a74ed3e439d4a071dfbb3a0b73392f001e 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    893,
 /**/
     892,
 /**/