1
0
forked from aniani/vim

patch 8.2.3644: count for 'operatorfunc' in Visual mode is not redone

Problem:    Count for 'operatorfunc' in Visual mode is not redone.
Solution:   Add the count to the redo buffer. (closes #9174)
This commit is contained in:
Bram Moolenaar
2021-11-22 14:16:08 +00:00
parent a3f83feb63
commit 2228cd72cf
5 changed files with 58 additions and 9 deletions

View File

@@ -380,8 +380,10 @@ static const struct nv_cmd
// Number of commands in nv_cmds[].
#define NV_CMDS_SIZE ARRAY_LENGTH(nv_cmds)
#ifndef PROTO // cproto doesn't like this
// Sorted index of commands in nv_cmds[].
static short nv_cmd_idx[NV_CMDS_SIZE];
#endif
// The highest index for which
// nv_cmds[idx].cmd_char == nv_cmd_idx[nv_cmds[idx].cmd_char]
@@ -1696,6 +1698,23 @@ prep_redo(
int cmd3,
int cmd4,
int cmd5)
{
prep_redo_num2(regname, num, cmd1, cmd2, 0L, cmd3, cmd4, cmd5);
}
/*
* Prepare for redo of any command with extra count after "cmd2".
*/
void
prep_redo_num2(
int regname,
long num1,
int cmd1,
int cmd2,
long num2,
int cmd3,
int cmd4,
int cmd5)
{
ResetRedobuff();
if (regname != 0) // yank from specified buffer
@@ -1703,13 +1722,14 @@ prep_redo(
AppendCharToRedobuff('"');
AppendCharToRedobuff(regname);
}
if (num)
AppendNumberToRedobuff(num);
if (num1 != 0)
AppendNumberToRedobuff(num1);
if (cmd1 != NUL)
AppendCharToRedobuff(cmd1);
if (cmd2 != NUL)
AppendCharToRedobuff(cmd2);
if (num2 != 0)
AppendNumberToRedobuff(num2);
if (cmd3 != NUL)
AppendCharToRedobuff(cmd3);
if (cmd4 != NUL)