summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-04-10 14:03:43 +0200
committerBram Moolenaar <Bram@vim.org>2021-04-10 14:03:43 +0200
commit599410cb3cb19946cd6df22441da5de003e114bb (patch)
tree7e8736d5a2c136a8aab567c57e21519d91a11985
parent701cc6ca9e940665a9424541f989bb38c853a498 (diff)
downloadvim-git-599410cb3cb19946cd6df22441da5de003e114bb.tar.gz
patch 8.2.2743: Vim9: function state stuck when compiling with ":silent!"v8.2.2743
Problem: Vim9: function state stuck when compiling with ":silent!". Solution: Check for uf_def_status to be UF_COMPILING.
-rw-r--r--src/globals.h3
-rw-r--r--src/message.c3
-rw-r--r--src/testdir/test_vim9_func.vim14
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c6
5 files changed, 27 insertions, 1 deletions
diff --git a/src/globals.h b/src/globals.h
index 94ec54b9a..51a69465c 100644
--- a/src/globals.h
+++ b/src/globals.h
@@ -230,6 +230,9 @@ EXTERN int did_endif INIT(= FALSE); // just had ":endif"
EXTERN int did_emsg; // set by emsg() when the message
// is displayed or thrown
#ifdef FEAT_EVAL
+EXTERN int did_emsg_silent INIT(= 0); // incremented by emsg() when
+ // emsg_silent was set and did_emsg
+ // is not incremented
EXTERN int did_emsg_def; // set by emsg() when emsg_silent
// is set before calling a function
EXTERN int did_emsg_cumul; // cumulative did_emsg, increased
diff --git a/src/message.c b/src/message.c
index 07c3943ab..f2fe23b58 100644
--- a/src/message.c
+++ b/src/message.c
@@ -685,6 +685,9 @@ emsg_core(char_u *s)
*/
if (emsg_silent != 0)
{
+#ifdef FEAT_EVAL
+ ++did_emsg_silent;
+#endif
if (emsg_noredir == 0)
{
msg_start();
diff --git a/src/testdir/test_vim9_func.vim b/src/testdir/test_vim9_func.vim
index 6a3dfbbe6..e254f44b7 100644
--- a/src/testdir/test_vim9_func.vim
+++ b/src/testdir/test_vim9_func.vim
@@ -2603,6 +2603,20 @@ def Test_compile_error()
# Second call won't try compiling again
assert_fails('call g:Broken()', 'E1091: Function is not compiled: Broken')
+ delfunc g:Broken
+
+ # No error when compiling with :silent!
+ lines =<< trim END
+ def g:Broken()
+ echo 'a' + []
+ enddef
+ silent! defcompile
+ END
+ CheckScriptSuccess(lines)
+
+ # Calling the function won't try compiling again
+ assert_fails('call g:Broken()', 'E1091: Function is not compiled: Broken')
+ delfunc g:Broken
enddef
diff --git a/src/version.c b/src/version.c
index 5cf56fead..a22312a15 100644
--- a/src/version.c
+++ b/src/version.c
@@ -751,6 +751,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 2743,
+/**/
2742,
/**/
2741,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index aa5894a35..e5e3068d5 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -8429,6 +8429,7 @@ compile_def_function(
cctx_T cctx;
garray_T *instr;
int did_emsg_before = did_emsg;
+ int did_emsg_silent_before = did_emsg_silent;
int ret = FAIL;
sctx_T save_current_sctx = current_sctx;
int save_estack_compiling = estack_compiling;
@@ -8967,6 +8968,9 @@ nextline:
generate_instr(&cctx, ISN_RETURN_ZERO);
}
+ // When compiled with ":silent!" and there was an error don't consider the
+ // function compiled.
+ if (emsg_silent == 0 || did_emsg_silent == did_emsg_silent_before)
{
dfunc_T *dfunc = ((dfunc_T *)def_functions.ga_data)
+ ufunc->uf_dfunc_idx;
@@ -8994,7 +8998,7 @@ nextline:
ret = OK;
erret:
- if (ret == FAIL)
+ if (ufunc->uf_def_status == UF_COMPILING)
{
int idx;
dfunc_T *dfunc = ((dfunc_T *)def_functions.ga_data)