]> granicus.if.org Git - vim/commitdiff
patch 8.1.1061: when substitute string throws error, substitute happens anyway v8.1.1061
authorBram Moolenaar <Bram@vim.org>
Wed, 27 Mar 2019 21:53:53 +0000 (22:53 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 27 Mar 2019 21:53:53 +0000 (22:53 +0100)
Problem:    When substitute string throws error, substitute happens anyway.
Solution:   Skip substitution when aborting. (closes #4161)

src/ex_cmds.c
src/testdir/test_substitute.vim
src/version.c

index 1b73ba3bab00c8d292630486f2610e0f9da0dc9b..25441247afb99ac2d97953483fb3f28acc2b7b56 100644 (file)
@@ -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)
                {
index f01e60e595df41cee427ad3e0e9431fda27bd3b0..790f2381e894c9a984d88d4265719c76b171b393 100644 (file)
@@ -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
index 69f2f064ca1d09861f46b81d08c1b689d88f642f..07b3a0c9c81acc2f188a9e99ff113842c08d7075 100644 (file)
@@ -775,6 +775,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1061,
 /**/
     1060,
 /**/