]> granicus.if.org Git - vim/commitdiff
patch 8.0.1518: error messages suppressed after ":silent! try" v8.0.1518
authorBram Moolenaar <Bram@vim.org>
Tue, 13 Feb 2018 17:05:18 +0000 (18:05 +0100)
committerBram Moolenaar <Bram@vim.org>
Tue, 13 Feb 2018 17:05:18 +0000 (18:05 +0100)
Problem:    Error messages suppressed after ":silent! try". (Ben Reilly)
Solution:   Restore emsg_silent before executing :try. (closes #2531)

src/ex_docmd.c
src/testdir/test_eval_stuff.vim
src/version.c

index 5825bf1d1b00172339c5ffbf96d46c66dee1524f..b923980e354dfeae0a4394d859b6dbf373e54f4e 100644 (file)
@@ -2880,8 +2880,18 @@ do_one_cmd(
     }
 #endif
 
+    /* The :try command saves the emsg_silent flag, reset it here when
+     * ":silent! try" was used, it should only apply to :try itself. */
+    if (ea.cmdidx == CMD_try && did_esilent > 0)
+    {
+       emsg_silent -= did_esilent;
+       if (emsg_silent < 0)
+           emsg_silent = 0;
+       did_esilent = 0;
+    }
+
 /*
- * 7. Switch on command name.
+ * 7. Execute the command.
  *
  * The "ea" structure holds the arguments that can be used.
  */
index 92e1ec5335a2245c9b5094554794388649ef410b..12222303d363104c2d74b493b2a4f3c1d4d5e7f6 100644 (file)
@@ -11,3 +11,17 @@ endfunction
 func Test_catch_return_with_error()
   call assert_equal(1, s:foo())
 endfunc
+
+func Test_nocatch_restore_silent_emsg()
+  silent! try
+    throw 1
+  catch
+  endtry
+  echoerr 'wrong'
+  let c1 = nr2char(screenchar(&lines, 1))
+  let c2 = nr2char(screenchar(&lines, 2))
+  let c3 = nr2char(screenchar(&lines, 3))
+  let c4 = nr2char(screenchar(&lines, 4))
+  let c5 = nr2char(screenchar(&lines, 5))
+  call assert_equal('wrong', c1 . c2 . c3 . c4 . c5)
+endfunc
index 931037d3d3516fbfff48997aa1e8eccf931dec8f..92fd162fa4632d86414852c674d848cd75d1684f 100644 (file)
@@ -771,6 +771,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1518,
 /**/
     1517,
 /**/