From 695428bac032192609f23dfcdab55a2ee79b4bb0 Mon Sep 17 00:00:00 2001 From: Marko Njezic Date: Wed, 8 Jun 2011 14:59:43 +0200 Subject: Fix regex search on the last line of search range when search pattern ends with escaped $ modifier. Bug #3313746. --- src/Document.cxx | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/Document.cxx b/src/Document.cxx index 7b718f272..dde9c4b6b 100644 --- a/src/Document.cxx +++ b/src/Document.cxx @@ -2113,6 +2113,7 @@ long BuiltinRegex::FindText(Document *doc, int minPos, int maxPos, const char *s int pos = -1; int lenRet = 0; char searchEnd = s[*length - 1]; + char searchEndPrev = (*length > 1) ? s[*length - 2] : '\0'; int lineRangeBreak = lineRangeEnd + increment; for (int line = lineRangeStart; line != lineRangeBreak; line += increment) { int startOfLine = doc->LineStart(line); @@ -2124,7 +2125,7 @@ long BuiltinRegex::FindText(Document *doc, int minPos, int maxPos, const char *s startOfLine = startPos; } if (line == lineRangeEnd) { - if ((endPos != endOfLine) && (searchEnd == '$')) + if ((endPos != endOfLine) && (searchEnd == '$') && (searchEndPrev != '\\')) continue; // Can't match end of line if end position before end of line endOfLine = endPos; } @@ -2135,7 +2136,7 @@ long BuiltinRegex::FindText(Document *doc, int minPos, int maxPos, const char *s startOfLine = endPos; } if (line == lineRangeStart) { - if ((startPos != endOfLine) && (searchEnd == '$')) + if ((startPos != endOfLine) && (searchEnd == '$') && (searchEndPrev != '\\')) continue; // Can't match end of line if start position before end of line endOfLine = startPos; } -- cgit v1.2.3