diff options
author | zeertzjq <zeertzjq@outlook.com> | 2023-04-18 21:04:53 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2023-04-18 21:04:53 +0100 |
commit | a1f2b5ddc63d4e2b6ab047d8c839dd8477b36aba (patch) | |
tree | fe1f8d25d413fb69536a983750b78ff49caec93f /src/vim9execute.c | |
parent | 142ffb024dd5123090c2fd02f55702e76520f1df (diff) |
patch 9.0.1468: recursively calling :defer function if it does :qav9.0.1468
Problem: Recursively calling :defer function if it does :qa in a compiled
function.
Solution: Clear the defer entry before calling the function. (closes #12271)
Diffstat (limited to 'src/vim9execute.c')
-rw-r--r-- | src/vim9execute.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/src/vim9execute.c b/src/vim9execute.c index d558ca0fa2..33a2fc6084 100644 --- a/src/vim9execute.c +++ b/src/vim9execute.c @@ -1063,6 +1063,10 @@ invoke_defer_funcs(ectx_T *ectx) int obj_off = functv->v_type == VAR_PARTIAL ? 1 : 0; int argcount = l->lv_len - 1 - obj_off; + if (functv->vval.v_string == NULL) + // already being called, can happen if function does ":qa" + continue; + if (obj_off == 1) arg_li = arg_li->li_next; // second list item is the object for (i = 0; i < argcount; ++i) @@ -1082,9 +1086,14 @@ invoke_defer_funcs(ectx_T *ectx) if (funcexe.fe_object != NULL) ++funcexe.fe_object->obj_refcount; } - (void)call_func(functv->vval.v_string, -1, - &rettv, argcount, argvars, &funcexe); + + char_u *name = functv->vval.v_string; + functv->vval.v_string = NULL; + + (void)call_func(name, -1, &rettv, argcount, argvars, &funcexe); + clear_tv(&rettv); + vim_free(name); } } |