mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.0.0140
Problem: Pasting inserted text in Visual mode does not work properly. (Matthew Malcomson) Solution: Stop Visual mode before stuffing the inserted text. (Christian Brabandt, from neovim #5709)
This commit is contained in:
parent
5e1e6d265d
commit
f8eb9c51e5
@ -3351,6 +3351,8 @@ do_put(
|
|||||||
*/
|
*/
|
||||||
if (regname == '.')
|
if (regname == '.')
|
||||||
{
|
{
|
||||||
|
if (VIsual_active)
|
||||||
|
stuffcharReadbuff(VIsual_mode);
|
||||||
(void)stuff_inserted((dir == FORWARD ? (count == -1 ? 'o' : 'a') :
|
(void)stuff_inserted((dir == FORWARD ? (count == -1 ? 'o' : 'a') :
|
||||||
(count == -1 ? 'O' : 'i')), count, FALSE);
|
(count == -1 ? 'O' : 'i')), count, FALSE);
|
||||||
/* Putting the text is done later, so can't really move the cursor to
|
/* Putting the text is done later, so can't really move the cursor to
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
" Tests for Visual mode. Uses double-wide character.
|
" Tests for various Visual mode.
|
||||||
if !has('multi_byte')
|
|
||||||
finish
|
|
||||||
endif
|
|
||||||
|
|
||||||
if !has('visual')
|
if !has('visual')
|
||||||
finish
|
finish
|
||||||
endif
|
endif
|
||||||
|
|
||||||
func Test_block_shift_multibyte()
|
func Test_block_shift_multibyte()
|
||||||
|
" Uses double-wide character.
|
||||||
|
if !has('multi_byte')
|
||||||
|
return
|
||||||
|
endif
|
||||||
split
|
split
|
||||||
call setline(1, ['xヹxxx', 'ヹxxx'])
|
call setline(1, ['xヹxxx', 'ヹxxx'])
|
||||||
exe "normal 1G0l\<C-V>jl>"
|
exe "normal 1G0l\<C-V>jl>"
|
||||||
@ -15,3 +15,11 @@ func Test_block_shift_multibyte()
|
|||||||
call assert_equal(' ヹxxx', getline(2))
|
call assert_equal(' ヹxxx', getline(2))
|
||||||
q!
|
q!
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
|
func Test_dotregister_paste()
|
||||||
|
new
|
||||||
|
exe "norm! ihello world\<esc>"
|
||||||
|
norm! 0ve".p
|
||||||
|
call assert_equal('hello world world', getline(1))
|
||||||
|
q!
|
||||||
|
endfunc
|
||||||
|
@ -764,6 +764,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 */
|
||||||
|
/**/
|
||||||
|
140,
|
||||||
/**/
|
/**/
|
||||||
139,
|
139,
|
||||||
/**/
|
/**/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user