diff options
author | LemonBoy <thatlemon@gmail.com> | 2022-05-21 11:20:42 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-05-21 11:20:42 +0100 |
commit | 0d534d9cf2ae95fc85ef7fe048d9ff590586a6a6 (patch) | |
tree | 86874373cae236c7ed6a795a45234c66321fcdba /src | |
parent | 3fcccf94e8bc142d2c79c3b62087145896df6b36 (diff) |
patch 8.2.4988: textprop in wrong position when replacing multi-byte charsv8.2.4988
Problem: Textprop in wrong position when replacing multi-byte chars.
Solution: Adjust textprop position. (closes #10461)
Diffstat (limited to 'src')
-rw-r--r-- | src/change.c | 7 | ||||
-rw-r--r-- | src/testdir/test_textprop.vim | 7 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 15 insertions, 1 deletions
diff --git a/src/change.c b/src/change.c index 47411ca59b..2d01f92586 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 3203305e8c..c29c10b27f 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 708f4a8ed3..ec25334d3f 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, |