mirror of
https://github.com/vim/vim.git
synced 2025-07-26 11:04:33 -04:00
patch 8.2.2370: Vim9: command fails in catch block
Problem: Vim9: command fails in catch block. Solution: Reset force_abort and need_rethrow. (closes #7692)
This commit is contained in:
parent
3af15ab788
commit
1430ceeb2d
@ -558,6 +558,43 @@ def Test_try_catch_throw()
|
|||||||
assert_equal(411, n)
|
assert_equal(411, n)
|
||||||
enddef
|
enddef
|
||||||
|
|
||||||
|
def Test_cnext_works_in_catch()
|
||||||
|
var lines =<< trim END
|
||||||
|
vim9script
|
||||||
|
au BufEnter * eval 0
|
||||||
|
writefile(['text'], 'Xfile1')
|
||||||
|
writefile(['text'], 'Xfile2')
|
||||||
|
var items = [
|
||||||
|
{lnum: 1, filename: 'Xfile1', valid: true},
|
||||||
|
{lnum: 1, filename: 'Xfile2', valid: true}
|
||||||
|
]
|
||||||
|
setqflist([], ' ', {items: items})
|
||||||
|
cwindow
|
||||||
|
|
||||||
|
def CnextOrCfirst()
|
||||||
|
# if cnext fails, cfirst is used
|
||||||
|
try
|
||||||
|
cnext
|
||||||
|
catch
|
||||||
|
cfirst
|
||||||
|
endtry
|
||||||
|
enddef
|
||||||
|
|
||||||
|
CnextOrCfirst()
|
||||||
|
CnextOrCfirst()
|
||||||
|
writefile([getqflist({idx: 0}).idx], 'Xresult')
|
||||||
|
qall
|
||||||
|
END
|
||||||
|
writefile(lines, 'XCatchCnext')
|
||||||
|
RunVim([], [], '--clean -S XCatchCnext')
|
||||||
|
assert_equal(['1'], readfile('Xresult'))
|
||||||
|
|
||||||
|
delete('Xfile1')
|
||||||
|
delete('Xfile2')
|
||||||
|
delete('XCatchCnext')
|
||||||
|
delete('Xresult')
|
||||||
|
enddef
|
||||||
|
|
||||||
def Test_throw_skipped()
|
def Test_throw_skipped()
|
||||||
if 0
|
if 0
|
||||||
throw dontgethere
|
throw dontgethere
|
||||||
|
@ -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 */
|
||||||
|
/**/
|
||||||
|
2370,
|
||||||
/**/
|
/**/
|
||||||
2369,
|
2369,
|
||||||
/**/
|
/**/
|
||||||
|
@ -2572,6 +2572,7 @@ call_def_function(
|
|||||||
trycmd->tcd_caught = TRUE;
|
trycmd->tcd_caught = TRUE;
|
||||||
}
|
}
|
||||||
did_emsg = got_int = did_throw = FALSE;
|
did_emsg = got_int = did_throw = FALSE;
|
||||||
|
force_abort = need_rethrow = FALSE;
|
||||||
catch_exception(current_exception);
|
catch_exception(current_exception);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user