mirror of
https://github.com/neovim/neovim.git
synced 2025-10-04 08:56:29 +00:00
vim-patch:8.2.2971: cannot yank a block without trailing spaces
Problem: Cannot yank a block without trailing spaces.
Solution: Add the "zy" command. (Christian Brabandt, closes vim/vim#8292)
544a38e44d
This commit is contained in:
@@ -1870,6 +1870,7 @@ void do_pending_operator(cmdarg_T *cap, int old_col, bool gui_yank)
|
||||
}
|
||||
} else {
|
||||
curwin->w_p_lbr = lbr_saved;
|
||||
oap->excl_tr_ws = cap->cmdchar == 'z';
|
||||
(void)op_yank(oap, !gui_yank, false);
|
||||
}
|
||||
check_cursor_col();
|
||||
@@ -4393,6 +4394,9 @@ dozet:
|
||||
case 'p':
|
||||
nv_put(cap);
|
||||
break;
|
||||
// "zy" Yank without trailing spaces
|
||||
case 'y': nv_operator(cap);
|
||||
break;
|
||||
|
||||
/* "zF": create fold command */
|
||||
/* "zf": create fold operator */
|
||||
|
@@ -48,6 +48,8 @@ typedef struct oparg_S {
|
||||
colnr_T end_vcol; // end col for block mode operator
|
||||
long prev_opcount; // ca.opcount saved for K_EVENT
|
||||
long prev_count0; // ca.count0 saved for K_EVENT
|
||||
bool excl_tr_ws; // exclude trailing whitespace for yank of a
|
||||
// block
|
||||
} oparg_T;
|
||||
|
||||
/*
|
||||
|
@@ -156,6 +156,9 @@ int get_op_type(int char1, int char2)
|
||||
// subtract
|
||||
return OP_NR_SUB;
|
||||
}
|
||||
if (char1 == 'z' && char2 == 'y') { // OP_YANK
|
||||
return OP_YANK;
|
||||
}
|
||||
for (i = 0;; i++) {
|
||||
if (opchars[i][0] == char1 && opchars[i][1] == char2) {
|
||||
break;
|
||||
@@ -2563,7 +2566,7 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)
|
||||
switch (reg->y_type) {
|
||||
case kMTBlockWise:
|
||||
block_prep(oap, &bd, lnum, false);
|
||||
yank_copy_line(reg, &bd, y_idx);
|
||||
yank_copy_line(reg, &bd, y_idx, oap->excl_tr_ws);
|
||||
break;
|
||||
|
||||
case kMTLineWise:
|
||||
@@ -2627,7 +2630,7 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)
|
||||
bd.textlen = endcol - startcol + oap->inclusive;
|
||||
}
|
||||
bd.textstart = p + startcol;
|
||||
yank_copy_line(reg, &bd, y_idx);
|
||||
yank_copy_line(reg, &bd, y_idx, false);
|
||||
break;
|
||||
}
|
||||
// NOTREACHED
|
||||
@@ -2714,7 +2717,11 @@ static void op_yank_reg(oparg_T *oap, bool message, yankreg_T *reg, bool append)
|
||||
return;
|
||||
}
|
||||
|
||||
static void yank_copy_line(yankreg_T *reg, struct block_def *bd, size_t y_idx)
|
||||
// Copy a block range into a register.
|
||||
// If "exclude_trailing_space" is set, do not copy trailing whitespaces.
|
||||
static void yank_copy_line(yankreg_T *reg, const struct block_def *bd,
|
||||
size_t y_idx, bool exclude_trailing_space)
|
||||
FUNC_ATTR_NONNULL_ALL
|
||||
{
|
||||
int size = bd->startspaces + bd->endspaces + bd->textlen;
|
||||
assert(size >= 0);
|
||||
@@ -2726,6 +2733,14 @@ static void yank_copy_line(yankreg_T *reg, struct block_def *bd, size_t y_idx)
|
||||
pnew += bd->textlen;
|
||||
memset(pnew, ' ', (size_t)bd->endspaces);
|
||||
pnew += bd->endspaces;
|
||||
if (exclude_trailing_space) {
|
||||
int s = bd->textlen + bd->endspaces;
|
||||
|
||||
while (ascii_iswhite(*(bd->textstart + s - 1)) && s > 0) {
|
||||
s = s - utf_head_off(bd->textstart, bd->textstart + s - 1) - 1;
|
||||
pnew--;
|
||||
}
|
||||
}
|
||||
*pnew = NUL;
|
||||
}
|
||||
|
||||
|
@@ -1006,4 +1006,59 @@ func Test_visual_put_in_block_using_zp()
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
func Test_visual_put_in_block_using_zy_and_zp()
|
||||
new
|
||||
|
||||
" Test 1) Paste using zp - after the cursor without trailing spaces
|
||||
call setline(1, ['/path;text', '/path;text', '/path;text', '',
|
||||
\ 'texttext /subdir columntext',
|
||||
\ 'texttext /longsubdir columntext',
|
||||
\ 'texttext /longlongsubdir columntext'])
|
||||
exe "normal! 5G0f/\<c-v>2jezy"
|
||||
norm! 1G0f;hzp
|
||||
call assert_equal(['/path/subdir;text', '/path/longsubdir;text', '/path/longlongsubdir;text'], getline(1, 3))
|
||||
|
||||
" Test 2) Paste using zP - in front of the cursor without trailing spaces
|
||||
%d
|
||||
call setline(1, ['/path;text', '/path;text', '/path;text', '',
|
||||
\ 'texttext /subdir columntext',
|
||||
\ 'texttext /longsubdir columntext',
|
||||
\ 'texttext /longlongsubdir columntext'])
|
||||
exe "normal! 5G0f/\<c-v>2jezy"
|
||||
norm! 1G0f;zP
|
||||
call assert_equal(['/path/subdir;text', '/path/longsubdir;text', '/path/longlongsubdir;text'], getline(1, 3))
|
||||
|
||||
" Test 3) Paste using p - with trailing spaces
|
||||
%d
|
||||
call setline(1, ['/path;text', '/path;text', '/path;text', '',
|
||||
\ 'texttext /subdir columntext',
|
||||
\ 'texttext /longsubdir columntext',
|
||||
\ 'texttext /longlongsubdir columntext'])
|
||||
exe "normal! 5G0f/\<c-v>2jezy"
|
||||
norm! 1G0f;hp
|
||||
call assert_equal(['/path/subdir ;text', '/path/longsubdir ;text', '/path/longlongsubdir;text'], getline(1, 3))
|
||||
|
||||
" Test 4) Paste using P - with trailing spaces
|
||||
%d
|
||||
call setline(1, ['/path;text', '/path;text', '/path;text', '',
|
||||
\ 'texttext /subdir columntext',
|
||||
\ 'texttext /longsubdir columntext',
|
||||
\ 'texttext /longlongsubdir columntext'])
|
||||
exe "normal! 5G0f/\<c-v>2jezy"
|
||||
norm! 1G0f;P
|
||||
call assert_equal(['/path/subdir ;text', '/path/longsubdir ;text', '/path/longlongsubdir;text'], getline(1, 3))
|
||||
|
||||
" Test 5) Yank with spaces inside the block
|
||||
%d
|
||||
call setline(1, ['/path;text', '/path;text', '/path;text', '',
|
||||
\ 'texttext /sub dir/ columntext',
|
||||
\ 'texttext /lon gsubdir/ columntext',
|
||||
\ 'texttext /lon glongsubdir/ columntext'])
|
||||
exe "normal! 5G0f/\<c-v>2jf/zy"
|
||||
norm! 1G0f;zP
|
||||
call assert_equal(['/path/sub dir/;text', '/path/lon gsubdir/;text', '/path/lon glongsubdir/;text'], getline(1, 3))
|
||||
bwipe!
|
||||
endfunc
|
||||
|
||||
|
||||
" vim: shiftwidth=2 sts=2 expandtab
|
||||
|
Reference in New Issue
Block a user