mirror of
https://github.com/neovim/neovim.git
synced 2025-10-17 15:21:47 +00:00
vim-patch:8.2.0035: saving and restoring called_emsg is clumsy (#19335)
Problem: Saving and restoring called_emsg is clumsy.
Solution: Count the number of error messages.
53989554a4
This commit is contained in:
@@ -3902,15 +3902,14 @@ static void f_wait(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
||||
typval_T argv = TV_INITIAL_VALUE;
|
||||
typval_T exprval = TV_INITIAL_VALUE;
|
||||
bool error = false;
|
||||
int save_called_emsg = called_emsg;
|
||||
called_emsg = false;
|
||||
const int called_emsg_before = called_emsg;
|
||||
|
||||
LOOP_PROCESS_EVENTS_UNTIL(&main_loop, main_loop.events, timeout,
|
||||
eval_expr_typval(&expr, &argv, 0, &exprval) != OK
|
||||
|| tv_get_number_chk(&exprval, &error)
|
||||
|| called_emsg || error || got_int);
|
||||
|| called_emsg > called_emsg_before || error || got_int);
|
||||
|
||||
if (called_emsg || error) {
|
||||
if (called_emsg > called_emsg_before || error) {
|
||||
rettv->vval.v_number = -3;
|
||||
} else if (got_int) {
|
||||
got_int = false;
|
||||
@@ -3920,8 +3919,6 @@ static void f_wait(typval_T *argvars, typval_T *rettv, FunPtr fptr)
|
||||
rettv->vval.v_number = 0;
|
||||
}
|
||||
|
||||
called_emsg = save_called_emsg;
|
||||
|
||||
// Stop dummy timer
|
||||
time_watcher_stop(tw);
|
||||
time_watcher_close(tw, dummy_timer_close_cb);
|
||||
|
Reference in New Issue
Block a user