mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.2.2933: when 'clipboard' is "unnamed" zp does not work correctly
Problem: When 'clipboard' is "unnamed" zp and zP do not work correctly. Solution: Pass -1 to str_to_reg() and fix computing the character width instead of using the byte length. (Christian Brabandt, closes #8301, closes #8317)
This commit is contained in:
@@ -2090,7 +2090,7 @@ clip_yank_selection(
|
||||
|
||||
clip_free_selection(cbd);
|
||||
|
||||
str_to_reg(y_ptr, type, str, len, 0L, FALSE);
|
||||
str_to_reg(y_ptr, type, str, len, -1, FALSE);
|
||||
}
|
||||
|
||||
/*
|
||||
|
@@ -4308,7 +4308,6 @@ mb_charlen(char_u *str)
|
||||
return count;
|
||||
}
|
||||
|
||||
#if (defined(FEAT_SPELL) || defined(FEAT_EVAL)) || defined(PROTO)
|
||||
/*
|
||||
* Like mb_charlen() but for a string with specified length.
|
||||
*/
|
||||
@@ -4323,7 +4322,6 @@ mb_charlen_len(char_u *str, int len)
|
||||
|
||||
return count;
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Try to un-escape a multi-byte character.
|
||||
|
@@ -2836,6 +2836,7 @@ str_to_reg(
|
||||
char_u **ss;
|
||||
char_u **pp;
|
||||
long maxlen;
|
||||
int charlen;
|
||||
|
||||
if (y_ptr->y_array == NULL) // NULL means empty register
|
||||
y_ptr->y_size = 0;
|
||||
@@ -2894,22 +2895,26 @@ str_to_reg(
|
||||
{
|
||||
for (ss = (char_u **) str; *ss != NULL; ++ss, ++lnum)
|
||||
{
|
||||
charlen = MB_CHARLEN(*ss);
|
||||
i = (long)STRLEN(*ss);
|
||||
pp[lnum] = vim_strnsave(*ss, i);
|
||||
if (i > maxlen)
|
||||
maxlen = i;
|
||||
if (charlen > maxlen)
|
||||
maxlen = charlen;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for (start = 0; start < len + extraline; start += i + 1)
|
||||
{
|
||||
charlen = 0;
|
||||
for (i = start; i < len; ++i) // find the end of the line
|
||||
if (str[i] == '\n')
|
||||
break;
|
||||
i -= start; // i is now length of line
|
||||
if (i > maxlen)
|
||||
maxlen = i;
|
||||
if (start < len)
|
||||
charlen = mb_charlen_len(str + start, i);
|
||||
if (charlen > maxlen)
|
||||
maxlen = charlen;
|
||||
if (append)
|
||||
{
|
||||
--lnum;
|
||||
|
@@ -750,6 +750,8 @@ static char *(features[]) =
|
||||
|
||||
static int included_patches[] =
|
||||
{ /* Add new patch number below this line */
|
||||
/**/
|
||||
2933,
|
||||
/**/
|
||||
2932,
|
||||
/**/
|
||||
|
Reference in New Issue
Block a user