summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-08-19 13:08:50 +0200
committerChristian Brabandt <cb@256bit.org>2023-08-19 13:08:50 +0200
commit9994160bfe74501886bbbf5631aec8ea2ae05991 (patch)
tree99acb17f9963bce48aa9abcd38ff860e682b7166
parentc5d2744c045f9ad058cbc799f2434d90a6d83516 (diff)
patch 9.0.1742: wrong curswant when clicking on second cell of double-width charv9.0.1742
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>
-rw-r--r--src/screen.c4
-rw-r--r--src/testdir/test_normal.vim25
-rw-r--r--src/version.c2
3 files changed, 29 insertions, 2 deletions
diff --git a/src/screen.c b/src/screen.c
index b3220de613..b4f55fe510 100644
--- a/src/screen.c
+++ b/src/screen.c
@@ -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;
diff --git a/src/testdir/test_normal.vim b/src/testdir/test_normal.vim
index e9478fab76..31fbe770f2 100644
--- a/src/testdir/test_normal.vim
+++ b/src/testdir/test_normal.vim
@@ -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
diff --git a/src/version.c b/src/version.c
index ff74ff4a9c..a30793d76c 100644
--- a/src/version.c
+++ b/src/version.c
@@ -696,6 +696,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1742,
+/**/
1741,
/**/
1740,