summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/change.c7
-rw-r--r--src/testdir/test_textprop.vim7
-rw-r--r--src/version.c2
3 files changed, 15 insertions, 1 deletions
diff --git a/src/change.c b/src/change.c
index 47411ca59..2d01f9258 100644
--- a/src/change.c
+++ b/src/change.c
@@ -1118,7 +1118,12 @@ ins_char_bytes(char_u *buf, int charlen)
ml_replace(lnum, newp, FALSE);
// mark the buffer as changed and prepare for displaying
- inserted_bytes(lnum, col, newlen - oldlen);
+ changed_bytes(lnum, col);
+#ifdef FEAT_PROP_POPUP
+ if (curbuf->b_has_textprop && newlen != oldlen)
+ adjust_prop_columns(lnum, col, newlen - oldlen,
+ State & REPLACE_FLAG ? APC_SUBSTITUTE : 0);
+#endif
// If we're in Insert or Replace mode and 'showmatch' is set, then briefly
// show the match for right parens and braces.
diff --git a/src/testdir/test_textprop.vim b/src/testdir/test_textprop.vim
index 3203305e8..c29c10b27 100644
--- a/src/testdir/test_textprop.vim
+++ b/src/testdir/test_textprop.vim
@@ -573,6 +573,13 @@ func Test_prop_replace()
call assert_equal('yyyex xyyoxx', getline(1))
call assert_equal(expected, prop_list(1))
+ " Replace three 1-byte chars with three 2-byte ones.
+ exe "normal 0l3rø"
+ call assert_equal('yøøøx xyyoxx', getline(1))
+ let expected[0].length += 3
+ let expected[1].col += 3
+ call assert_equal(expected, prop_list(1))
+
call DeletePropTypes()
bwipe!
set bs&
diff --git a/src/version.c b/src/version.c
index 708f4a8ed..ec25334d3 100644
--- a/src/version.c
+++ b/src/version.c
@@ -747,6 +747,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 4988,
+/**/
4987,
/**/
4986,