1
0
forked from aniani/vim

updated for version 7.4.323

Problem:    Substitute() with zero width pattern breaks multi-byte character.
Solution:   Take multi-byte character size into account. (Yukihiro Nakadaira)
This commit is contained in:
Bram Moolenaar 2014-06-12 18:39:22 +02:00
parent e639eb44e9
commit 8e7048ca4b
4 changed files with 18 additions and 2 deletions

View File

@ -24848,8 +24848,11 @@ do_string_sub(str, pat, sub, flags)
if (zero_width == regmatch.startp[0])
{
/* avoid getting stuck on a match with an empty string */
*((char_u *)ga.ga_data + ga.ga_len) = *tail++;
++ga.ga_len;
i = MB_PTR2LEN(tail);
mch_memmove((char_u *)ga.ga_data + ga.ga_len, tail,
(size_t)i);
ga.ga_len += i;
tail += i;
continue;
}
zero_width = regmatch.startp[0];

View File

@ -179,6 +179,13 @@ ENDTEST
byteidx
byteidxcomp
STARTTEST
/^substitute
:let y = substitute('', '\zs', 'a', 'g') | put =y
ENDTEST
substitute
STARTTEST
:g/^STARTTEST/.,/^ENDTEST/d
:1;/^Results/,$wq! test.out

View File

@ -160,3 +160,7 @@ byteidxcomp
[0, 1, 3, 4, -1]
[0, 1, 2, 4, 5, -1]
substitute
aaaa

View File

@ -734,6 +734,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
323,
/**/
322,
/**/