diff options
author | Yegappan Lakshmanan <yegappan@yahoo.com> | 2023-10-19 10:52:34 +0200 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2023-10-19 10:52:34 +0200 |
commit | c59c1e0d88651a71ece7366e418f1253abbe2a28 (patch) | |
tree | 98453e9da10f027b806d3c3cf2cd524df85241c5 /src/testdir/test_vim9_script.vim | |
parent | d7b616d0ad006db06140729313b6217677cc4e80 (diff) |
patch 9.0.2050: Vim9: crash with deferred function call and exceptionv9.0.2050
Problem: Vim9: crash with deferred function call and exception
Solution: Save and restore exception state
Crash when a deferred function is called after an exception and another
exception is thrown
closes: #13376
closes: #13377
Signed-off-by: Christian Brabandt <cb@256bit.org>
Co-authored-by: Yegappan Lakshmanan <yegappan@yahoo.com>
Diffstat (limited to 'src/testdir/test_vim9_script.vim')
-rw-r--r-- | src/testdir/test_vim9_script.vim | 24 |
1 files changed, 17 insertions, 7 deletions
diff --git a/src/testdir/test_vim9_script.vim b/src/testdir/test_vim9_script.vim index f8280c6d28..75a358e859 100644 --- a/src/testdir/test_vim9_script.vim +++ b/src/testdir/test_vim9_script.vim @@ -4691,12 +4691,22 @@ def Test_defer_after_exception() var lines =<< trim END vim9script - var callTrace: list<string> = [] + var callTrace: list<number> = [] + def Bar() + callTrace += [1] + throw 'InnerException' + enddef + def Defer() - callTrace += ['a'] - callTrace += ['b'] - callTrace += ['c'] - callTrace += ['d'] + callTrace += [2] + callTrace += [3] + try + Bar() + catch /InnerException/ + callTrace += [4] + endtry + callTrace += [5] + callTrace += [6] enddef def Foo() @@ -4707,10 +4717,10 @@ def Test_defer_after_exception() try Foo() catch /TestException/ - callTrace += ['e'] + callTrace += [7] endtry - assert_equal(['a', 'b', 'c', 'd', 'e'], callTrace) + assert_equal([2, 3, 1, 4, 5, 6, 7], callTrace) END v9.CheckScriptSuccess(lines) enddef |