mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 7.4.743
Problem: "p" in Visual mode causes an unexpected line split. Solution: Advance the cursor first. (Yukihiro Nakadaira)
This commit is contained in:
parent
a594d77ffc
commit
c004bc2726
13
src/ops.c
13
src/ops.c
@ -3459,17 +3459,26 @@ do_put(regname, dir, count, flags)
|
|||||||
{
|
{
|
||||||
if (flags & PUT_LINE_SPLIT)
|
if (flags & PUT_LINE_SPLIT)
|
||||||
{
|
{
|
||||||
|
char_u *p;
|
||||||
|
|
||||||
/* "p" or "P" in Visual mode: split the lines to put the text in
|
/* "p" or "P" in Visual mode: split the lines to put the text in
|
||||||
* between. */
|
* between. */
|
||||||
if (u_save_cursor() == FAIL)
|
if (u_save_cursor() == FAIL)
|
||||||
goto end;
|
goto end;
|
||||||
ptr = vim_strsave(ml_get_cursor());
|
p = ml_get_cursor();
|
||||||
|
if (dir == FORWARD && *p != NUL)
|
||||||
|
mb_ptr_adv(p);
|
||||||
|
ptr = vim_strsave(p);
|
||||||
if (ptr == NULL)
|
if (ptr == NULL)
|
||||||
goto end;
|
goto end;
|
||||||
ml_append(curwin->w_cursor.lnum, ptr, (colnr_T)0, FALSE);
|
ml_append(curwin->w_cursor.lnum, ptr, (colnr_T)0, FALSE);
|
||||||
vim_free(ptr);
|
vim_free(ptr);
|
||||||
|
|
||||||
ptr = vim_strnsave(ml_get_curline(), curwin->w_cursor.col);
|
oldp = ml_get_curline();
|
||||||
|
p = oldp + curwin->w_cursor.col;
|
||||||
|
if (dir == FORWARD && *p != NUL)
|
||||||
|
mb_ptr_adv(p);
|
||||||
|
ptr = vim_strnsave(oldp, p - oldp);
|
||||||
if (ptr == NULL)
|
if (ptr == NULL)
|
||||||
goto end;
|
goto end;
|
||||||
ml_replace(curwin->w_cursor.lnum, ptr, FALSE);
|
ml_replace(curwin->w_cursor.lnum, ptr, FALSE);
|
||||||
|
@ -174,6 +174,42 @@ gH<Del>
|
|||||||
:$put ='c'
|
:$put ='c'
|
||||||
kgH<Down><Del>
|
kgH<Down><Del>
|
||||||
:$put ='---'
|
:$put ='---'
|
||||||
|
:
|
||||||
|
:$put =''
|
||||||
|
:$put ='v_p: replace last character with line register at middle line'
|
||||||
|
:$put ='aaa'
|
||||||
|
:$put ='bbb'
|
||||||
|
:$put ='ccc'
|
||||||
|
:-2yank
|
||||||
|
k$vp
|
||||||
|
:$put ='---'
|
||||||
|
:
|
||||||
|
:$put =''
|
||||||
|
:$put ='v_p: replace last character with line register at middle line selecting newline'
|
||||||
|
:$put ='aaa'
|
||||||
|
:$put ='bbb'
|
||||||
|
:$put ='ccc'
|
||||||
|
:-2yank
|
||||||
|
k$v$p
|
||||||
|
:$put ='---'
|
||||||
|
:
|
||||||
|
:$put =''
|
||||||
|
:$put ='v_p: replace last character with line register at last line'
|
||||||
|
:$put ='aaa'
|
||||||
|
:$put ='bbb'
|
||||||
|
:$put ='ccc'
|
||||||
|
:-2yank
|
||||||
|
$vp
|
||||||
|
:$put ='---'
|
||||||
|
:
|
||||||
|
:$put =''
|
||||||
|
:$put ='v_p: replace last character with line register at last line selecting newline'
|
||||||
|
:$put ='aaa'
|
||||||
|
:$put ='bbb'
|
||||||
|
:$put ='ccc'
|
||||||
|
:-2yank
|
||||||
|
$v$p
|
||||||
|
:$put ='---'
|
||||||
:/^start:/+2,$w! test.out
|
:/^start:/+2,$w! test.out
|
||||||
:q!
|
:q!
|
||||||
ENDTEST
|
ENDTEST
|
||||||
|
@ -81,3 +81,34 @@ b
|
|||||||
linewise select mode: delete last two line
|
linewise select mode: delete last two line
|
||||||
a
|
a
|
||||||
---
|
---
|
||||||
|
|
||||||
|
v_p: replace last character with line register at middle line
|
||||||
|
aaa
|
||||||
|
bb
|
||||||
|
aaa
|
||||||
|
|
||||||
|
ccc
|
||||||
|
---
|
||||||
|
|
||||||
|
v_p: replace last character with line register at middle line selecting newline
|
||||||
|
aaa
|
||||||
|
bb
|
||||||
|
aaa
|
||||||
|
ccc
|
||||||
|
---
|
||||||
|
|
||||||
|
v_p: replace last character with line register at last line
|
||||||
|
aaa
|
||||||
|
bbb
|
||||||
|
cc
|
||||||
|
aaa
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
v_p: replace last character with line register at last line selecting newline
|
||||||
|
aaa
|
||||||
|
bbb
|
||||||
|
cc
|
||||||
|
aaa
|
||||||
|
|
||||||
|
---
|
||||||
|
@ -741,6 +741,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
743,
|
||||||
/**/
|
/**/
|
||||||
742,
|
742,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user