]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.1.0132: "C" doesn't include composing chars with 'virtualedit' v9.1.0132
authorzeertzjq <zeertzjq@outlook.com>
Sat, 24 Feb 2024 13:21:39 +0000 (14:21 +0100)
committerChristian Brabandt <cb@256bit.org>
Sat, 24 Feb 2024 13:21:39 +0000 (14:21 +0100)
Problem:  using "C" and 've=all' set, doesn't include composing chars
          when changing a line, keeps the composing chars for whatever
          is typed afterwards.
Solution: Use mb_head_off() and mb_ptr2len() instead of mb_tail_off().
          (zeertzjq)

closes: #14083

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

index e66b4b5ee737484c1ec4283fa9b1ca8b53f5103b..57e699150f731b235d7b557c5e67d9f5b8d6b81c 100644 (file)
--- a/src/ops.c
+++ b/src/ops.c
@@ -990,13 +990,20 @@ setmarks:
     static void
 mb_adjust_opend(oparg_T *oap)
 {
-    char_u     *p;
+    char_u     *line;
+    char_u     *ptr;
 
     if (!oap->inclusive)
        return;
 
-    p = ml_get(oap->end.lnum);
-    oap->end.col += mb_tail_off(p, p + oap->end.col);
+    line = ml_get(oap->end.lnum);
+    ptr = line + oap->end.col;
+    if (*ptr != NUL)
+    {
+       ptr -= (*mb_head_off)(line, ptr);
+       ptr += (*mb_ptr2len)(ptr) - 1;
+       oap->end.col = ptr - line;
+    }
 }
 
 /*
index ec2b276c3f812fce562ceca4b28b553185cbc55d..48d4aa0616432169b9e01461e5425a5dfe7705af 100644 (file)
@@ -77,13 +77,30 @@ endfunc
 func Test_edit_change()
   new
   set virtualedit=all
+
   call setline(1, "\t⒌")
   normal Cx
   call assert_equal('x', getline(1))
+
+  call setline(1, "\ta̳")
+  normal Cx
+  call assert_equal('x', getline(1))
+
+  call setline(1, "\tβ̳")
+  normal Cx
+  call assert_equal('x', getline(1))
+
+  if has('arabic')
+    call setline(1, "\tلا")
+    normal Cx
+    call assert_equal('x', getline(1))
+  endif
+
   " Do a visual block change
   call setline(1, ['a', 'b', 'c'])
   exe "normal gg3l\<C-V>2jcx"
   call assert_equal(['a  x', 'b  x', 'c  x'], getline(1, '$'))
+
   bwipe!
   set virtualedit=
 endfunc
index a80f2a87b582aa8263ebf95d7e7ff1a29d817860..59a940ba0905fe4489e0dc57a174dee15d44c31d 100644 (file)
@@ -704,6 +704,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    132,
 /**/
     131,
 /**/