Skip to content

Commit

Permalink
[vim mode] codemirror#5753 Feature request: Support &/$0 in vim subst…
Browse files Browse the repository at this point in the history
…itute replacements
  • Loading branch information
ilyakharlamov committed Jul 5, 2019
1 parent 1fb5c61 commit 107d26b
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 2 deletions.
4 changes: 2 additions & 2 deletions keymap/vim.js
Original file line number Diff line number Diff line change
Expand Up @@ -4073,7 +4073,7 @@
}

// Unescape \ and / in the replace part, for PCRE mode.
var unescapes = {'\\/': '/', '\\\\': '\\', '\\n': '\n', '\\r': '\r', '\\t': '\t'};
var unescapes = {'\\/': '/', '\\\\': '\\', '\\n': '\n', '\\r': '\r', '\\t': '\t', '\\&':'&'};
function unescapeRegexReplace(str) {
var stream = new CodeMirror.StringStream(str);
var output = [];
Expand Down Expand Up @@ -4871,7 +4871,7 @@
}
if (replacePart !== undefined) {
if (getOption('pcre')) {
replacePart = unescapeRegexReplace(replacePart);
replacePart = unescapeRegexReplace(replacePart.replace(/([^\\])&/g,"$1$$&"));
} else {
replacePart = translateRegexReplace(replacePart);
}
Expand Down
18 changes: 18 additions & 0 deletions test/vim_test.js
Original file line number Diff line number Diff line change
Expand Up @@ -3939,6 +3939,24 @@ testSubstitute('ex_substitute_forward_slash_regex', {
expectedValue: 'forward slash was here',
expr: '%s#\\/##g',
noPcreExpr: '%s#/##g'});
testVim("ex_substitute_ampersand_pcre", function(cm, vim, helpers) {
cm.setCursor(0, 0);
CodeMirror.Vim.setOption('pcre', true);
helpers.doEx('%s/foo/namespace.&/');
eq("namespace.foo", cm.getValue());
}, { value: 'foo' });
testVim("ex_substitute_ampersand_multiple_pcre", function(cm, vim, helpers) {
cm.setCursor(0, 0);
CodeMirror.Vim.setOption('pcre', true);
helpers.doEx('%s/f.o/namespace.&/');
eq("namespace.foo\nnamespace.fzo", cm.getValue());
}, { value: 'foo\nfzo' });
testVim("ex_escaped_ampersand_should_not_substitute_pcre", function(cm, vim, helpers) {
cm.setCursor(0, 0);
CodeMirror.Vim.setOption('pcre', true);
helpers.doEx('%s/foo/namespace.\\&/');
eq("namespace.&", cm.getValue());
}, { value: 'foo' });
testSubstitute('ex_substitute_backslashslash_regex', {
value: 'one\\two \n three\\four',
expectedValue: 'one,two \n three,four',
Expand Down

0 comments on commit 107d26b

Please sign in to comment.