]> granicus.if.org Git - vim/commitdiff
patch 8.2.1690: text properties not adjusted for "I" in Visual block mode v8.2.1690
authorBram Moolenaar <Bram@vim.org>
Tue, 15 Sep 2020 19:34:18 +0000 (21:34 +0200)
committerBram Moolenaar <Bram@vim.org>
Tue, 15 Sep 2020 19:34:18 +0000 (21:34 +0200)
Problem:    Text properties not adjusted for "I" in Visual block mode.
Solution:   Call inserted_bytes().

src/change.c
src/ops.c
src/proto/change.pro
src/testdir/test_textprop.vim
src/version.c

index 3a823b62969230b82e1046a3351cab90583e2a53..44c2f0480c41fa7b978ad57f61524f0c76eef892 100644 (file)
@@ -693,7 +693,7 @@ changed_bytes(linenr_T lnum, colnr_T col)
  * Like changed_bytes() but also adjust text properties for "added" bytes.
  * When "added" is negative text was deleted.
  */
-    static void
+    void
 inserted_bytes(linenr_T lnum, colnr_T col, int added UNUSED)
 {
 #ifdef FEAT_PROP_POPUP
index 2988a185b4d947525b5f867cd8549b768bff2d16..d5729403464999e9ba47bca02b468f410b02bf34 100644 (file)
--- a/src/ops.c
+++ b/src/ops.c
@@ -481,6 +481,7 @@ block_insert(
     int                count = 0;      // extra spaces to replace a cut TAB
     int                spaces = 0;     // non-zero if cutting a TAB
     colnr_T    offset;         // pointer along new line
+    colnr_T    startcol;       // column where insert starts
     unsigned   s_len;          // STRLEN(s)
     char_u     *newp, *oldp;   // new, old lines
     linenr_T   lnum;           // loop var
@@ -553,9 +554,10 @@ block_insert(
 
        // insert pre-padding
        vim_memset(newp + offset, ' ', (size_t)spaces);
+       startcol = offset + spaces;
 
        // copy the new text
-       mch_memmove(newp + offset + spaces, s, (size_t)s_len);
+       mch_memmove(newp + startcol, s, (size_t)s_len);
        offset += s_len;
 
        if (spaces && !bdp->is_short)
@@ -574,6 +576,10 @@ block_insert(
 
        ml_replace(lnum, newp, FALSE);
 
+       if (b_insert)
+           // correct any text properties
+           inserted_bytes(lnum, startcol, s_len);
+
        if (lnum == oap->end.lnum)
        {
            // Set "']" mark to the end of the block instead of the end of
index badb19dbdfc02ec6bbf5eb03410d70ea2f671dd6..69ba2a6b08fdd74b9d7dd6cb3f57d4b52d746535 100644 (file)
@@ -9,6 +9,7 @@ void may_invoke_listeners(buf_T *buf, linenr_T lnum, linenr_T lnume, int added);
 void invoke_listeners(buf_T *buf);
 void remove_listeners(buf_T *buf);
 void changed_bytes(linenr_T lnum, colnr_T col);
+void inserted_bytes(linenr_T lnum, colnr_T col, int added);
 void appended_lines(linenr_T lnum, long count);
 void appended_lines_mark(linenr_T lnum, long count);
 void deleted_lines(linenr_T lnum, long count);
index ae84cf974e597569b661af8d2ed76fa322f6e5ca..5bd7e95c3ddb14890c46f14c69c1f39b9cb1bf76 100644 (file)
@@ -1314,4 +1314,35 @@ func Test_prop_increment_decrement()
   call prop_type_delete('test')
 endfunc
 
+func Test_prop_block_insert()
+  new
+  call prop_type_add('test', {'highlight': 'ErrorMsg'})
+  call setline(1, ['one ', 'two '])
+  call prop_add(1, 1, {'length': 3, 'type': 'test'})
+  call prop_add(2, 1, {'length': 3, 'type': 'test'})
+
+  " insert "xx" in the first column of both lines
+  exe "normal! gg0\<C-V>jIxx\<Esc>"
+  eval getline(1, 2)->assert_equal(['xxone ', 'xxtwo '])
+  let expected = [#{id: 0, col: 3, end: 1, type: 'test', length: 3, start: 1}]
+  eval prop_list(1)->assert_equal(expected)
+  eval prop_list(2)->assert_equal(expected)
+
+  " insert "yy" inside the text props to make them longer
+  exe "normal! gg03l\<C-V>jIyy\<Esc>"
+  eval getline(1, 2)->assert_equal(['xxoyyne ', 'xxtyywo '])
+  let expected[0].length = 5
+  eval prop_list(1)->assert_equal(expected)
+  eval prop_list(2)->assert_equal(expected)
+
+  " insert "zz" after the text props, text props don't change
+  exe "normal! gg07l\<C-V>jIzz\<Esc>"
+  eval getline(1, 2)->assert_equal(['xxoyynezz ', 'xxtyywozz '])
+  eval prop_list(1)->assert_equal(expected)
+  eval prop_list(2)->assert_equal(expected)
+
+  bwipe!
+  call prop_type_delete('test')
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index f4b02418ed57581622cc611fd5b23c2f43d117b8..6aa02b47445ba7c829962f90f10c2dc047688071 100644 (file)
@@ -750,6 +750,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1690,
 /**/
     1689,
 /**/