0
0
mirror of https://github.com/vim/vim.git synced 2025-09-29 04:34:16 -04:00

patch 9.1.0056: wrong number of trailing spaces inserted after blockwise put

Problem:  Incorrect number of trailing spaces inserted for multibyte
	  characters when pasting a blockwise register in blockwise visual
          mode (VanaIgr)
Solution: Skip over trailing UTF-8 bytes when computing the number of trailing
          spaces (VanaIgr)

When pasting in blockwise visual mode, and the register type is <CTRL-V>, Vim
aligns the text after the replaced area by inserting spaces after pasted
lines that are shorter than the longest line. When a shorter line contains
multibyte characters, each trailing UTF-8 byte's width is counted in addition
to the width of the character itself. Each trailing byte counts as being 4
cells wide (since it would be displayed as <xx>).

closes: #13909

Signed-off-by: VanaIgr <vanaigranov@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
VanaIgr
2024-01-25 21:50:41 +01:00
committed by Christian Brabandt
parent 78019df645
commit 6638ec8afa
3 changed files with 15 additions and 3 deletions

View File

@@ -1903,10 +1903,10 @@ do_put(
spaces = y_width + 1; spaces = y_width + 1;
init_chartabsize_arg(&cts, curwin, 0, 0, init_chartabsize_arg(&cts, curwin, 0, 0,
y_array[i], y_array[i]); y_array[i], y_array[i]);
for (j = 0; j < yanklen; j++)
while (*cts.cts_ptr != NUL)
{ {
spaces -= lbr_chartabsize(&cts); spaces -= lbr_chartabsize_adv(&cts);
++cts.cts_ptr;
cts.cts_vcol = 0; cts.cts_vcol = 0;
} }
clear_chartabsize_arg(&cts); clear_chartabsize_arg(&cts);

View File

@@ -12,6 +12,16 @@ func Test_put_block()
bwipe! bwipe!
endfunc endfunc
func Test_put_block_unicode()
new
call setreg('a', "À\nÀÀ\naaaaaaaaaaaa", "\<C-V>")
call setline(1, [' 1', ' 2', ' 3'])
exe "norm! \<C-V>jj\"ap"
let expected = ['À 1', 'ÀÀ 2', 'aaaaaaaaaaaa3']
call assert_equal(expected, getline(1, 3))
bw!
endfunc
func Test_put_char_block() func Test_put_char_block()
new new
call setline(1, ['Line 1', 'Line 2']) call setline(1, ['Line 1', 'Line 2'])

View File

@@ -704,6 +704,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 */
/**/
56,
/**/ /**/
55, 55,
/**/ /**/