diff options
author | Bram Moolenaar <Bram@vim.org> | 2019-05-18 13:41:22 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2019-05-18 13:41:22 +0200 |
commit | 6349e9411fd17f80c7aff9c678a8800647d34cfa (patch) | |
tree | 864908c652f6e0f5e074db2b2d38d3062ae90cc3 /src/ex_cmds.c | |
parent | 0d3cb73012332964e7a81d7afd1c21d393f45566 (diff) |
patch 8.1.1345: stuck in sandbox with ":s/../\=Function/gn"v8.1.1345
Problem: Stuck in sandbox with ":s/../\=Function/gn".
Solution: Don't skip over code to restore sandbox. (Christian Brabandt)
Diffstat (limited to 'src/ex_cmds.c')
-rw-r--r-- | src/ex_cmds.c | 15 |
1 files changed, 6 insertions, 9 deletions
diff --git a/src/ex_cmds.c b/src/ex_cmds.c index b99e54bce3..3c9166d424 100644 --- a/src/ex_cmds.c +++ b/src/ex_cmds.c @@ -5555,28 +5555,25 @@ do_sub(exarg_T *eap) #ifdef FEAT_EVAL if (subflags.do_count) { - /* prevent accidentally changing the buffer by a function */ - save_ma = curbuf->b_p_ma; + // prevent accidentally changing the buffer by a function curbuf->b_p_ma = FALSE; sandbox++; } - /* Save flags for recursion. They can change for e.g. - * :s/^/\=execute("s#^##gn") */ + // Save flags for recursion. They can change for e.g. + // :s/^/\=execute("s#^##gn") subflags_save = subflags; + save_ma = curbuf->b_p_ma; #endif - /* get length of substitution part */ + // get length of substitution part sublen = vim_regsub_multi(®match, sub_firstlnum - regmatch.startpos[0].lnum, sub, sub_firstline, FALSE, p_magic, TRUE); #ifdef FEAT_EVAL // 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) + if (aborting() || subflags.do_count) { curbuf->b_p_ma = save_ma; if (sandbox > 0) |