aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/normal.c
diff options
context:
space:
mode:
authorzeertzjq <zeertzjq@outlook.com>2023-04-27 00:23:39 +0800
committerGitHub <noreply@github.com>2023-04-27 00:23:39 +0800
commitefae71819a99b1cf9cce024b520b62bb455229f9 (patch)
tree606619758ac55c4e28f7d8c52df7b33513bf64a9 /src/nvim/normal.c
parent9f0762f1fec2aa23df592dda70124e3cbdb703b7 (diff)
parenta35bca21125980d407bdb830e7c52d95a629de76 (diff)
downloadrneovim-efae71819a99b1cf9cce024b520b62bb455229f9.tar.gz
rneovim-efae71819a99b1cf9cce024b520b62bb455229f9.tar.bz2
rneovim-efae71819a99b1cf9cce024b520b62bb455229f9.zip
Merge pull request #23288 from MunifTanjim/issue-22263
fix(normal): fix repeated trigger modechanged for scheduled callback
Diffstat (limited to 'src/nvim/normal.c')
-rw-r--r--src/nvim/normal.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/src/nvim/normal.c b/src/nvim/normal.c
index 2bafeccba4..635d177ecc 100644
--- a/src/nvim/normal.c
+++ b/src/nvim/normal.c
@@ -956,10 +956,12 @@ normal_end:
set_reg_var(get_default_register_name());
}
- // Reset finish_op, in case it was set
s->c = finish_op;
- finish_op = false;
- may_trigger_modechanged();
+ if (s->oa.op_type == OP_NOP) {
+ // Reset finish_op, in case it was set
+ finish_op = false;
+ may_trigger_modechanged();
+ }
// Redraw the cursor with another shape, if we were in Operator-pending
// mode or did a replace command.
if (s->c || s->ca.cmdchar == 'r'
@@ -1729,9 +1731,9 @@ void prep_redo_num2(int regname, long num1, int cmd1, int cmd2, long num2, int c
}
}
-/// check for operator active and clear it
+/// Check for operator active and clear it.
///
-/// @return true if operator was active
+/// Beep and return true if an operator was active.
static bool checkclearop(oparg_T *oap)
{
if (oap->op_type == OP_NOP) {
@@ -1743,7 +1745,7 @@ static bool checkclearop(oparg_T *oap)
/// Check for operator or Visual active. Clear active operator.
///
-/// @return true if operator or Visual was active.
+/// Beep and return true if an operator or Visual was active.
static bool checkclearopq(oparg_T *oap)
{
if (oap->op_type == OP_NOP && !VIsual_active) {