summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2019-03-27 22:53:53 +0100
committerBram Moolenaar <Bram@vim.org>2019-03-27 22:53:53 +0100
commit0e97b9487571cf725a9cb28fe4dcefc800415f69 (patch)
tree8e3c232261680bf2f82a40eb4e245a75949eef68
parent760285dd4f20d25e8ae3166996981b8dddba366a (diff)
patch 8.1.1061: when substitute string throws error, substitute happens anywayv8.1.1061
Problem: When substitute string throws error, substitute happens anyway. Solution: Skip substitution when aborting. (closes #4161)
-rw-r--r--src/ex_cmds.c7
-rw-r--r--src/testdir/test_substitute.vim30
-rw-r--r--src/version.c2
3 files changed, 38 insertions, 1 deletions
diff --git a/src/ex_cmds.c b/src/ex_cmds.c
index 1b73ba3bab..25441247af 100644
--- a/src/ex_cmds.c
+++ b/src/ex_cmds.c
@@ -5574,7 +5574,12 @@ do_sub(exarg_T *eap)
sub_firstlnum - regmatch.startpos[0].lnum,
sub, sub_firstline, FALSE, p_magic, TRUE);
#ifdef FEAT_EVAL
- /* Don't keep flags set by a recursive call. */
+ // If getting the substitute string caused an error, don't do
+ // the replacement.
+ if (aborting())
+ goto skip;
+
+ // Don't keep flags set by a recursive call.
subflags = subflags_save;
if (subflags.do_count)
{
diff --git a/src/testdir/test_substitute.vim b/src/testdir/test_substitute.vim
index f01e60e595..790f2381e8 100644
--- a/src/testdir/test_substitute.vim
+++ b/src/testdir/test_substitute.vim
@@ -610,3 +610,33 @@ func Test_sub_cmd_8()
enew!
set titlestring&
endfunc
+
+func Test_nocatch_sub_failure_handling()
+ " normal error results in all replacements
+ func! Foo()
+ foobar
+ endfunc
+ new
+ call setline(1, ['1 aaa', '2 aaa', '3 aaa'])
+ %s/aaa/\=Foo()/g
+ call assert_equal(['1 0', '2 0', '3 0'], getline(1, 3))
+
+ " Trow without try-catch causes abort after the first line.
+ " We cannot test this, since it would stop executing the test script.
+
+ " try/catch does not result in any changes
+ func! Foo()
+ throw 'error'
+ endfunc
+ call setline(1, ['1 aaa', '2 aaa', '3 aaa'])
+ let error_caught = 0
+ try
+ %s/aaa/\=Foo()/g
+ catch
+ let error_caught = 1
+ endtry
+ call assert_equal(1, error_caught)
+ call assert_equal(['1 aaa', '2 aaa', '3 aaa'], getline(1, 3))
+
+ bwipe!
+endfunc
diff --git a/src/version.c b/src/version.c
index 69f2f064ca..07b3a0c9c8 100644
--- a/src/version.c
+++ b/src/version.c
@@ -776,6 +776,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1061,
+/**/
1060,
/**/
1059,