Patch 9.0.1612
Problem:    "skipcol" not reset when using multi-byte characters.
Solution:   Compare with w_virtcol instead of w_cursor.col. (closes #12457)
Files:      src/move.c, src/testdir/test_scroll_opt.vim,
            src/testdir/dumps/Test_smoothscroll_multi_1.dump


*** ../vim-9.0.1611/src/move.c  2023-06-05 18:41:11.757624535 +0100
--- src/move.c  2023-06-05 20:43:48.818215644 +0100
***************
*** 2414,2423 ****
        }
        check_topfill(curwin, FALSE);
  #endif
!       // TODO: if the line doesn't fit may optimize w_skipcol
!       if (curwin->w_topline == curwin->w_cursor.lnum
!               && curwin->w_skipcol >= curwin->w_cursor.col)
!           reset_skipcol();
        if (curwin->w_topline != old_topline
                || curwin->w_skipcol != old_skipcol
  #ifdef FEAT_DIFF
--- 2414,2427 ----
        }
        check_topfill(curwin, FALSE);
  #endif
!       if (curwin->w_topline == curwin->w_cursor.lnum)
!       {
!           validate_virtcol();
!           if (curwin->w_skipcol >= curwin->w_virtcol)
!               // TODO: if the line doesn't fit may optimize w_skipcol instead
!               // of making it zero
!               reset_skipcol();
!       }
        if (curwin->w_topline != old_topline
                || curwin->w_skipcol != old_skipcol
  #ifdef FEAT_DIFF
*** ../vim-9.0.1611/src/testdir/test_scroll_opt.vim     2023-06-05 
18:41:11.757624535 +0100
--- src/testdir/test_scroll_opt.vim     2023-06-05 20:42:09.790085119 +0100
***************
*** 124,129 ****
--- 124,144 ----
    call StopVimInTerminal(buf)
  endfunc
  
+ func Test_smoothscroll_multibyte()
+   CheckScreendump
+ 
+   let lines =<< trim END
+       set scrolloff=0 smoothscroll
+       call setline(1, [repeat('ϛ', 45), repeat('2', 36)])
+       exe "normal G35l\<C-E>k"
+   END
+   call writefile(lines, 'XSmoothMultibyte', 'D')
+   let buf = RunVimInTerminal('-S XSmoothMultibyte', #{rows: 6, cols: 40})
+   call VerifyScreenDump(buf, 'Test_smoothscroll_multi_1', {})
+ 
+   call StopVimInTerminal(buf)
+ endfunc
+ 
  func Test_smoothscroll_number()
    CheckScreendump
  
*** ../vim-9.0.1611/src/testdir/dumps/Test_smoothscroll_multi_1.dump    
2023-06-05 20:44:25.390252548 +0100
--- src/testdir/dumps/Test_smoothscroll_multi_1.dump    2023-06-05 
20:42:41.442132040 +0100
***************
*** 0 ****
--- 1,6 ----
+ |ϛ+0&#ffffff0@34>ϛ@4
+ @5| @34
+ |2@35| @3
+ |~+0#4040ff13&| @38
+ |~| @38
+ | +0#0000000&@21|1|,|7|1|-|3|6| @6|A|l@1| 
*** ../vim-9.0.1611/src/version.c       2023-06-05 19:46:14.436726710 +0100
--- src/version.c       2023-06-05 20:40:05.361845840 +0100
***************
*** 697,698 ****
--- 697,700 ----
  {   /* Add new patch number below this line */
+ /**/
+     1612,
  /**/

-- 
hundred-and-one symptoms of being an internet addict:
121. You ask for e-mail adresses instead of telephone numbers.

 /// Bram Moolenaar -- b...@moolenaar.net -- http://www.Moolenaar.net   \\\
///                                                                      \\\
\\\        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to vim_dev+unsubscr...@googlegroups.com.
To view this discussion on the web visit 
https://groups.google.com/d/msgid/vim_dev/20230605194541.03B2C1C0542%40moolenaar.net.

Raspunde prin e-mail lui