mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 8.2.2330: Vim9: crash when using :trow in a not executed block
Problem: Vim9: crash when using :trow in a not executed block. Solution: Don't generate the instruction when skipping. (closes #7659)
This commit is contained in:
@@ -324,7 +324,7 @@ func g:NoSuchFunc()
|
|||||||
echo 'none'
|
echo 'none'
|
||||||
endfunc
|
endfunc
|
||||||
|
|
||||||
def Test_try_catch()
|
def Test_try_catch_throw()
|
||||||
var l = []
|
var l = []
|
||||||
try # comment
|
try # comment
|
||||||
add(l, '1')
|
add(l, '1')
|
||||||
@@ -558,6 +558,12 @@ def Test_try_catch()
|
|||||||
assert_equal(411, n)
|
assert_equal(411, n)
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
|
def Test_throw_skipped()
|
||||||
|
if 0
|
||||||
|
throw dontgethere
|
||||||
|
endif
|
||||||
|
enddef
|
||||||
|
|
||||||
def DeletedFunc(): list<any>
|
def DeletedFunc(): list<any>
|
||||||
return ['delete me']
|
return ['delete me']
|
||||||
enddef
|
enddef
|
||||||
|
@@ -750,6 +750,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
2330,
|
||||||
/**/
|
/**/
|
||||||
2329,
|
2329,
|
||||||
/**/
|
/**/
|
||||||
|
@@ -474,8 +474,10 @@ may_generate_2STRING(int offset, cctx_T *cctx)
|
|||||||
isn_T *isn;
|
isn_T *isn;
|
||||||
isntype_T isntype = ISN_2STRING;
|
isntype_T isntype = ISN_2STRING;
|
||||||
garray_T *stack = &cctx->ctx_type_stack;
|
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)
|
switch ((*type)->tt_type)
|
||||||
{
|
{
|
||||||
// nothing to be done
|
// nothing to be done
|
||||||
@@ -7461,6 +7463,8 @@ compile_throw(char_u *arg, cctx_T *cctx UNUSED)
|
|||||||
|
|
||||||
if (compile_expr0(&p, cctx) == FAIL)
|
if (compile_expr0(&p, cctx) == FAIL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
if (cctx->ctx_skip == SKIP_YES)
|
||||||
|
return p;
|
||||||
if (may_generate_2STRING(-1, cctx) == FAIL)
|
if (may_generate_2STRING(-1, cctx) == FAIL)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (generate_instr_drop(cctx, ISN_THROW, 1) == NULL)
|
if (generate_instr_drop(cctx, ISN_THROW, 1) == NULL)
|
||||||
|
Reference in New Issue
Block a user