diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-03-27 22:53:53 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-03-27 22:53:53 +0100 |
commit | 0e97b9487571cf725a9cb28fe4dcefc800415f69 (patch) | |
tree | 8e3c232261680bf2f82a40eb4e245a75949eef68 | |
parent | 760285dd4f20d25e8ae3166996981b8dddba366a (diff) | |
download | vim-git-8.1.1061.tar.gz |
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.c | 7 | ||||
-rw-r--r-- | src/testdir/test_substitute.vim | 30 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 38 insertions, 1 deletions
diff --git a/src/ex_cmds.c b/src/ex_cmds.c index 1b73ba3ba..25441247a 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 f01e60e59..790f2381e 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 69f2f064c..07b3a0c9c 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, |