patch 8.2.4957: text properties in a wrong position after a block change v8.2.4957
authorLemonBoy <thatlemon@gmail.com>
Sun, 15 May 2022 12:08:02 +0000 (13:08 +0100)
committerBram Moolenaar <Bram@vim.org>
Sun, 15 May 2022 12:08:02 +0000 (13:08 +0100)
Problem:    Text properties in a wrong position after a block change.
Solution:   Adjust the properties columns. (closes #10427)

src/ops.c
src/testdir/test_textprop.vim
src/version.c

index b11cbf5416f3dedf5c2e3bca2e0c6d027d3b1aa7..5b4c2957bc28cfe3b28895cfb6cc44a975d38aa9 100644 (file)
--- a/src/ops.c
+++ b/src/ops.c
@@ -1814,6 +1814,12 @@ op_change(oparg_T *oap)
                        oldp += bd.textcol;
                        STRMOVE(newp + offset, oldp);
                        ml_replace(linenr, newp, FALSE);
+#ifdef FEAT_PROP_POPUP
+                       // Shift the properties for linenr as edit() would do.
+                       if (curbuf->b_has_textprop)
+                           adjust_prop_columns(linenr, bd.textcol,
+                                                    vpos.coladd + ins_len, 0);
+#endif
                    }
                }
                check_cursor();
index 50012acaf8ef7b76de9c33c3490f55079f52766d..8e12041427be0be0d7d3c1322354d5f0bf45570e 100644 (file)
@@ -2003,4 +2003,37 @@ func Test_prop_insert_multiline()
   bwipe!
 endfunc
 
+func Test_prop_blockwise_change()
+  new
+  call AddPropTypes()
+
+  call setline(1, ['foooooo', 'bar', 'baaaaz'])
+  call prop_add(1, 1, #{end_col: 3, type: 'one'})
+  call prop_add(2, 1, #{end_col: 3, type: 'two'})
+  call prop_add(3, 1, #{end_col: 3, type: 'three'})
+
+  " Replace the first two columns with '123', since 'start_incl' is false the
+  " prop is not extended.
+  call feedkeys("gg\<c-v>2jc123\<Esc>", 'nxt')
+
+  let lines =<< trim END
+      123oooooo
+      123ar
+      123aaaaz
+  END
+  call assert_equal(lines, getline(1, '$'))
+  let expected = [
+      \ {'lnum': 1, 'id': 0, 'col': 4, 'type_bufnr': 0, 'end': 1, 'type': 'one',
+      \ 'length': 1, 'start': 1},
+      \ {'lnum': 2, 'id': 0, 'col': 4, 'type_bufnr': 0, 'end': 1, 'type': 'two',
+      \ 'length': 1, 'start': 1},
+      \ {'lnum': 3, 'id': 0, 'col': 4, 'type_bufnr': 0, 'end': 1 ,
+      \ 'type': 'three', 'length': 1, 'start': 1}
+      \ ]
+  call assert_equal(expected, prop_list(1, #{end_lnum: 10}))
+
+  call DeletePropTypes()
+  bwipe!
+endfunc
+
 " vim: shiftwidth=2 sts=2 expandtab
index 821f3680e2fb5d2d2a8d813cd33f0c31d3298557..711349a35fb3c90b42d59ba944e603166e87bc43 100644 (file)
@@ -746,6 +746,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    4957,
 /**/
     4956,
 /**/