aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2018-10-10 11:20:43 +0200
committerGitHub <noreply@github.com>2018-10-10 11:20:43 +0200
commit8c7c8f596268eb46f17143f31a024d4c72192e1b (patch)
treeb89e092949ac181611aecd8a21d6d5975f2b207c
parentf4b2b66661893c1ca80b1b662b826bc2307fcc36 (diff)
parent0394cb23e93858de2cd77b5cecf008d55e5a7717 (diff)
downloadrneovim-8c7c8f596268eb46f17143f31a024d4c72192e1b.tar.gz
rneovim-8c7c8f596268eb46f17143f31a024d4c72192e1b.tar.bz2
rneovim-8c7c8f596268eb46f17143f31a024d4c72192e1b.zip
Merge #8954 from janlazo/vim-8.0.1423
-rw-r--r--src/nvim/eval.c18
-rw-r--r--src/nvim/testdir/test_eval_stuff.vim13
2 files changed, 22 insertions, 9 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c
index 9c678168bb..515dd0e69f 100644
--- a/src/nvim/eval.c
+++ b/src/nvim/eval.c
@@ -21797,15 +21797,15 @@ void ex_return(exarg_T *eap)
} else {
tv_clear(&rettv);
}
- }
- /* It's safer to return also on error. */
- else if (!eap->skip) {
- /*
- * Return unless the expression evaluation has been cancelled due to an
- * aborting error, an interrupt, or an exception.
- */
- if (!aborting())
- returning = do_return(eap, FALSE, TRUE, NULL);
+ } else if (!eap->skip) { // It's safer to return also on error.
+ // In return statement, cause_abort should be force_abort.
+ update_force_abort();
+
+ // Return unless the expression evaluation has been cancelled due to an
+ // aborting error, an interrupt, or an exception.
+ if (!aborting()) {
+ returning = do_return(eap, false, true, NULL);
+ }
}
/* When skipping or the return gets pending, advance to the next command
diff --git a/src/nvim/testdir/test_eval_stuff.vim b/src/nvim/testdir/test_eval_stuff.vim
new file mode 100644
index 0000000000..92e1ec5335
--- /dev/null
+++ b/src/nvim/testdir/test_eval_stuff.vim
@@ -0,0 +1,13 @@
+" Tests for various eval things.
+
+function s:foo() abort
+ try
+ return [] == 0
+ catch
+ return 1
+ endtry
+endfunction
+
+func Test_catch_return_with_error()
+ call assert_equal(1, s:foo())
+endfunc