]> git.ipfire.org Git - thirdparty/vim.git/commitdiff
patch 9.0.0079: error in autoload script not reported for 'foldexpr' v9.0.0079
authorBram Moolenaar <Bram@vim.org>
Tue, 26 Jul 2022 14:10:56 +0000 (15:10 +0100)
committerBram Moolenaar <Bram@vim.org>
Tue, 26 Jul 2022 14:10:56 +0000 (15:10 +0100)
Problem:    Error in autoload script not reported for 'foldexpr'.
Solution:   Reset "emsg_off" when auto-loading a script. (closes #10685)

src/testdir/test_vim9_script.vim
src/version.c
src/vim9compile.c

index fc0ef15b885b867a05c371c5456abf3d0023a3ac..98a4590c24e10993dead826599f193f2b3802c39 100644 (file)
@@ -3440,6 +3440,30 @@ def Test_error_in_autoload_script()
   delete(dir, 'rf')
 enddef
 
+def Test_error_in_autoload_script_foldexpr()
+  var save_rtp = &rtp
+  mkdir('Xvim/autoload', 'p')
+  &runtimepath = 'Xvim'
+
+  var lines =<< trim END
+      vim9script
+      eval [][0]
+      echomsg 'no error'
+  END
+  lines->writefile('Xvim/autoload/script.vim')
+
+  lines =<< trim END
+      vim9script
+      import autoload 'script.vim'
+      &foldmethod = 'expr'
+      &foldexpr = 'script.Func()'
+      redraw
+  END
+  v9.CheckScriptFailure(lines, 'E684: List index out of range: 0')
+
+  delete('Xvim', 'rf')
+enddef
+
 def Test_invalid_sid()
   assert_fails('func <SNR>1234_func', 'E123:')
 
index a7fe96c9483ca0047535bc6ca5d95c5ba19ea8b3..bd75074afea0f9b23b38b8d42046f263c4e3ff60 100644 (file)
@@ -735,6 +735,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    79,
 /**/
     78,
 /**/
index b7f590e106810aa9977aec696fb459d2418b41e2..c6316367e730c3913d9187e66294367309eec29e 100644 (file)
@@ -610,12 +610,20 @@ find_imported(char_u *name, size_t len, int load)
     ret = find_imported_in_script(name, len, current_sctx.sc_sid);
     if (ret != NULL && load && (ret->imp_flags & IMP_FLAGS_AUTOLOAD))
     {
-       scid_T dummy;
+       scid_T  dummy;
+       int     save_emsg_off = emsg_off;
+
+       // "emsg_off" will be set when evaluating an expression silently, but
+       // we do want to know about errors in a script.  Also because it then
+       // aborts when an error is encountered.
+       emsg_off = FALSE;
 
        // script found before but not loaded yet
        ret->imp_flags &= ~IMP_FLAGS_AUTOLOAD;
        (void)do_source(SCRIPT_ITEM(ret->imp_sid)->sn_name, FALSE,
                                                            DOSO_NONE, &dummy);
+
+       emsg_off = save_emsg_off;
     }
     return ret;
 }