]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0186: cursor pos wrong on mouse click after eol with 'rl', 've' and conceal v9.1.0186
authorzeertzjq <zeertzjq@outlook.com>
Sun, 17 Mar 2024 18:44:30 +0000 (19:44 +0100)
committerChristian Brabandt <cb@256bit.org>
Sun, 17 Mar 2024 18:44:30 +0000 (19:44 +0100)
Problem:  Wrong cursor position when clicking after end of line with
          'rightleft', 'virtualedit' and conceal.
Solution: Set values in ScreenCols[] also with SLF_RIGHTLEFT.  Also fix
          off-by-one cursor position with 'colorcolumn' (zeertzjq).

closes: #14218

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

index cc1bed6b194af7ddcc621cd8b661ca7959e4d822..ed02f3cab6db9bea4051180b757a4faf37dfbfbc 100644 (file)
@@ -975,15 +975,14 @@ draw_screen_line(win_T *wp, winlinevars_T *wlv)
                ++wlv->off;
                ++wlv->col;
            }
+           ++wlv->vcol;
 
-           if (VCOL_HLC >= rightmost_vcol
+           if (VCOL_HLC > rightmost_vcol
 # ifdef LINE_ATTR
                    && wlv->line_attr == 0
 # endif
                    && wlv->win_attr == 0)
                break;
-
-           ++wlv->vcol;
        }
     }
 #endif
index 08b1c018f219d2610b80e4981b6678e8cfb0039c..71ddbcaab220c0b77c38fbdd87af829f11596dba 100644 (file)
@@ -18,8 +18,7 @@
  *                  displayed (excluding text written by external commands).
  * ScreenAttrs[off]  Contains the associated attributes.
  * ScreenCols[off]   Contains the virtual columns in the line. -1 means not
- *                  available or before buffer text, MAXCOL means after the
- *                  end of the line.
+ *                  available or before buffer text.
  *
  * LineOffset[row]   Contains the offset into ScreenLines*[], ScreenAttrs[]
  *                  and ScreenCols[] for each line.
@@ -509,6 +508,8 @@ screen_line(
        // Clear rest first, because it's left of the text.
        if (clear_width > 0)
        {
+           int clear_start = col;
+
            while (col <= endcol && ScreenLines[off_to] == ' '
                    && ScreenAttrs[off_to] == 0
                                  && (!enc_utf8 || ScreenLinesUC[off_to] == 0))
@@ -519,6 +520,10 @@ screen_line(
            if (col <= endcol)
                screen_fill(row, row + 1, col + coloff,
                                            endcol + coloff + 1, ' ', ' ', 0);
+
+           for (int i = endcol; i >= clear_start; i--)
+               ScreenCols[off_to + (i - col)] =
+                   (flags & SLF_INC_VCOL) ? ++last_vcol : last_vcol;
        }
        col = endcol + 1;
        off_to = LineOffset[row] + col + coloff;
index 9696cdeae8088aab59f9f7b111b2703679e7c32d..355817dd36f6c5b2613d09838a8c5ab72e50eb19 100644 (file)
@@ -464,6 +464,53 @@ func Test_conceal_mouse_click()
     call test_setmouse(1, 32)
     call feedkeys("\<LeftMouse>", "tx")
     call assert_equal([0, 1, 24, 12, 36], getcurpos())
+    " Behavior should also be the same with 'colorcolumn'.
+    setlocal colorcolumn=30
+    redraw
+    call test_setmouse(1, 31)
+    call feedkeys("\<LeftMouse>", "tx")
+    call assert_equal([0, 1, 24, 11, 35], getcurpos())
+    call test_setmouse(1, 32)
+    call feedkeys("\<LeftMouse>", "tx")
+    call assert_equal([0, 1, 24, 12, 36], getcurpos())
+    setlocal colorcolumn&
+
+    if has('rightleft')
+      setlocal rightleft
+      call assert_equal([
+            \ '                     ereh kcilc  laecnoc',
+            \ ], ScreenLines(1, 40))
+      " Click on the space between "this" and "click" puts cursor there.
+      call test_setmouse(1, 41 - 9)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 13, 0, 13], getcurpos())
+      " Click on 'h' of "here" puts cursor there.
+      call test_setmouse(1, 41 - 16)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 20, 0, 20], getcurpos())
+      " Click on 'e' of "here" puts cursor there.
+      call test_setmouse(1, 41 - 19)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 23, 0, 23], getcurpos())
+      " Click after end of line puts cursor there with 'virtualedit'.
+      call test_setmouse(1, 41 - 20)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 24, 0, 24], getcurpos())
+      call test_setmouse(1, 41 - 21)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 24, 1, 25], getcurpos())
+      call test_setmouse(1, 41 - 22)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 24, 2, 26], getcurpos())
+      call test_setmouse(1, 41 - 31)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 24, 11, 35], getcurpos())
+      call test_setmouse(1, 41 - 32)
+      call feedkeys("\<LeftMouse>", "tx")
+      call assert_equal([0, 1, 24, 12, 36], getcurpos())
+      setlocal rightleft&
+    endif
+
     set virtualedit&
 
     " Test with a wrapped line.
index 07bed4f30a715eb39f7d6f37c21246dde1cc7aee..d0902280757eb494257e6883add849b30485b805 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    186,
 /**/
     185,
 /**/