patch 9.1.1322: small delete register cannot paste multi-line correctly
Problem: small delete register cannot paste multi-line correctly
(after v8.2.2189)
Solution: caused by 032a2d050b82b146d70d6ff714838ee62c07d8ad, so make
this logic handle charwise only (phanium)
closes: #17151
Signed-off-by: phanium <91544758+phanen@users.noreply.github.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
diff --git a/src/register.c b/src/register.c
index 267e0fc..9d27706 100644
--- a/src/register.c
+++ b/src/register.c
@@ -846,7 +846,7 @@
{
for (i = 0; i < y_current->y_size; ++i)
{
- if (regname == '-')
+ if (regname == '-' && y_current->y_type == MCHAR)
{
int dir = BACKWARD;
if ((State & REPLACE_FLAG) != 0)
@@ -867,11 +867,13 @@
do_put(regname, NULL, dir, 1L, PUT_CURSEND);
}
else
+ {
stuffescaped(y_current->y_array[i].string, literally);
- // Insert a newline between lines and after last line if
- // y_type is MLINE.
- if (y_current->y_type == MLINE || i < y_current->y_size - 1)
- stuffcharReadbuff('\n');
+ // Insert a newline between lines and after last line if
+ // y_type is MLINE.
+ if (y_current->y_type == MLINE || i < y_current->y_size - 1)
+ stuffcharReadbuff('\n');
+ }
}
}
}
diff --git a/src/testdir/test_registers.vim b/src/testdir/test_registers.vim
index 981f9d2..b597ab3 100644
--- a/src/testdir/test_registers.vim
+++ b/src/testdir/test_registers.vim
@@ -1204,4 +1204,13 @@
bw!
endfunc
+func Test_insert_small_delete_linewise()
+ new
+ call setline(1, ['foo'])
+ call cursor(1, 1)
+ exe ":norm! \"-cc\<C-R>-"
+ call assert_equal(['foo', ''], getline(1, '$'))
+ bwipe!
+endfunc
+
" vim: shiftwidth=2 sts=2 expandtab
diff --git a/src/version.c b/src/version.c
index 4c9f4ce..4990e44 100644
--- a/src/version.c
+++ b/src/version.c
@@ -705,6 +705,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1322,
+/**/
1321,
/**/
1320,