summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRichard M. Stallman <rms@gnu.org>1997-03-22 04:17:06 +0000
committerRichard M. Stallman <rms@gnu.org>1997-03-22 04:17:06 +0000
commit6fc1b02894b9b198b0d096cf89139656a2bb00f5 (patch)
tree24d05cc7d7ab0cb83ceb46baf39d12990fb76957
parent0ac2c5690cb1e4027d9deb6c1a69e53a7450cdf7 (diff)
downloademacs-6fc1b02894b9b198b0d096cf89139656a2bb00f5.tar.gz
(Freplace_match): Give error if
NEWTEXT uses backslash in an invalid way.
-rw-r--r--src/search.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/src/search.c b/src/search.c
index abdd2460bd8..9978f9b7e3b 100644
--- a/src/search.c
+++ b/src/search.c
@@ -1821,7 +1821,8 @@ since only regular expressions have distinguished subexpressions.")
make_number (search_regs.start[sub]));
after = Fsubstring (string, make_number (search_regs.end[sub]), Qnil);
- /* Do case substitution into NEWTEXT if desired. */
+ /* Substitute parts of the match into NEWTEXT
+ if desired. */
if (NILP (literal))
{
int lastpos = -1;
@@ -1856,6 +1857,8 @@ since only regular expressions have distinguished subexpressions.")
}
else if (c == '\\')
delbackslash = 1;
+ else
+ error ("Invalid use of `\\' in replacement text");
}
if (substart >= 0)
{
@@ -1888,6 +1891,7 @@ since only regular expressions have distinguished subexpressions.")
newtext = concat2 (accum, middle);
}
+ /* Do case substitution in NEWTEXT if desired. */
if (case_action == all_caps)
newtext = Fupcase (newtext);
else if (case_action == cap_initial)
@@ -1929,8 +1933,10 @@ since only regular expressions have distinguished subexpressions.")
make_number (search_regs.start[c - '0'] + offset),
make_number (search_regs.end[c - '0'] + offset));
}
- else
+ else if (c == '\\')
insert_char (c);
+ else
+ error ("Invalid use of `\\' in replacement text");
}
else
insert_char (c);