]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.1742: wrong curswant when clicking on second cell of double-width char v9.0.1742
authorzeertzjq <zeertzjq@outlook.com>
Sat, 19 Aug 2023 11:08:50 +0000 (13:08 +0200)
committerChristian Brabandt <cb@256bit.org>
Sat, 19 Aug 2023 11:08:50 +0000 (13:08 +0200)
Problem:  Wrong curswant when clicking and the second cell of a
          double-width char.
Solution: Don't copy virtcol of the first char to the second one.

closes: #12842

Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: zeertzjq <zeertzjq@outlook.com>
src/screen.c
src/testdir/test_normal.vim
src/version.c

index b3220de613a9d73e225828e7c3285c606813b9f4..b4f55fe5107248b7e8207be3d991444fb92948c7 100644 (file)
@@ -17,7 +17,7 @@
  * ScreenLines[off]  Contains a copy of the whole screen, as it is currently
  *                  displayed (excluding text written by external commands).
  * ScreenAttrs[off]  Contains the associated attributes.
- * ScreenCols[off]   Contains the byte offset in the line. -1 means not
+ * ScreenCols[off]   Contains the virtual columns in the line. -1 means not
  *                  available (below last line), MAXCOL means after the end
  *                  of the line.
  *
@@ -743,7 +743,7 @@ screen_line(
 
        ScreenCols[off_to] = ScreenCols[off_from];
        if (char_cells == 2)
-           ScreenCols[off_to + 1] = ScreenCols[off_from];
+           ScreenCols[off_to + 1] = ScreenCols[off_from + 1];
 
        off_to += char_cells;
        off_from += char_cells;
index e9478fab7697b8ebcc22c7cbbc926364daf28bbb..31fbe770f2fd47b8e6ea5c46ed2adc8f97a8bb55 100644 (file)
@@ -4079,4 +4079,29 @@ func Test_normal_click_on_ctrl_char()
   let &mouse = save_mouse
 endfunc
 
+" Test clicking on a double-width character in Normal mode
+func Test_normal_click_on_double_width_char()
+  let save_mouse = &mouse
+  set mouse=a
+  new
+
+  call setline(1, "口口")
+  redraw
+  call test_setmouse(1, 1)
+  call feedkeys("\<LeftMouse>", 'xt')
+  call assert_equal([0, 1, 1, 0, 1], getcurpos())
+  call test_setmouse(1, 2)
+  call feedkeys("\<LeftMouse>", 'xt')
+  call assert_equal([0, 1, 1, 0, 2], getcurpos())
+  call test_setmouse(1, 3)
+  call feedkeys("\<LeftMouse>", 'xt')
+  call assert_equal([0, 1, 4, 0, 3], getcurpos())
+  call test_setmouse(1, 4)
+  call feedkeys("\<LeftMouse>", 'xt')
+  call assert_equal([0, 1, 4, 0, 4], getcurpos())
+
+  bwipe!
+  let &mouse = save_mouse
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index ff74ff4a9c970f808759d7f000f5d20e0eef31b0..a30793d76c9853cfbeae352986e6891d60081d35 100644 (file)
@@ -695,6 +695,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1742,
 /**/
     1741,
 /**/