summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2021-01-11 20:17:34 +0100
committerBram Moolenaar <Bram@vim.org>2021-01-11 20:17:34 +0100
commit9e1d9e3473f852735ffd605a0fa4d224b81a4f0c (patch)
tree93bbf3cdf7f47a3ba7755d0fb5c11ad017f5e41d
parentdf4c9af7e73aa5d0fb5bf4c0e19a39b4e1d73517 (diff)
downloadvim-git-9e1d9e3473f852735ffd605a0fa4d224b81a4f0c.tar.gz
patch 8.2.2330: Vim9: crash when using :trow in a not executed blockv8.2.2330
Problem: Vim9: crash when using :trow in a not executed block. Solution: Don't generate the instruction when skipping. (closes #7659)
-rw-r--r--src/testdir/test_vim9_script.vim8
-rw-r--r--src/version.c2
-rw-r--r--src/vim9compile.c6
3 files changed, 14 insertions, 2 deletions
diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim
index 1066a1d43..d567de75f 100644
--- a/src/testdir/test_vim9_script.vim
+++ b/src/testdir/test_vim9_script.vim
@@ -324,7 +324,7 @@ func g:NoSuchFunc()
echo 'none'
endfunc
-def Test_try_catch()
+def Test_try_catch_throw()
var l = []
try # comment
add(l, '1')
@@ -558,6 +558,12 @@ def Test_try_catch()
assert_equal(411, n)
enddef
+def Test_throw_skipped()
+ if 0
+ throw dontgethere
+ endif
+enddef
+
def DeletedFunc(): list<any>
return ['delete me']
enddef
diff --git a/src/version.c b/src/version.c
index 2a6e1daa0..0a3cd54a9 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 */
/**/
+ 2330,
+/**/
2329,
/**/
2328,
diff --git a/src/vim9compile.c b/src/vim9compile.c
index bcbc57dd1..0064bd205 100644
--- a/src/vim9compile.c
+++ b/src/vim9compile.c
@@ -474,8 +474,10 @@ may_generate_2STRING(int offset, cctx_T *cctx)
isn_T *isn;
isntype_T isntype = ISN_2STRING;
garray_T *stack = &cctx->ctx_type_stack;
- type_T **type = ((type_T **)stack->ga_data) + stack->ga_len + offset;
+ type_T **type;
+ RETURN_OK_IF_SKIP(cctx);
+ type = ((type_T **)stack->ga_data) + stack->ga_len + offset;
switch ((*type)->tt_type)
{
// nothing to be done
@@ -7461,6 +7463,8 @@ compile_throw(char_u *arg, cctx_T *cctx UNUSED)
if (compile_expr0(&p, cctx) == FAIL)
return NULL;
+ if (cctx->ctx_skip == SKIP_YES)
+ return p;
if (may_generate_2STRING(-1, cctx) == FAIL)
return NULL;
if (generate_instr_drop(cctx, ISN_THROW, 1) == NULL)