From: Richard M. Stallman Date: Fri, 1 Sep 1995 18:43:30 +0000 (+0000) Subject: (re_search_2): If pattern starts with \=, optimize search. X-Git-Tag: emacs-19.34~2877 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=ae4788a82befc4d0903e349e0df2f8038e8b6ac5;p=emacs.git (re_search_2): If pattern starts with \=, optimize search. --- diff --git a/src/regex.c b/src/regex.c index d497d895784..d0086ed1aad 100644 --- a/src/regex.c +++ b/src/regex.c @@ -3036,7 +3036,7 @@ re_compile_fastmap (bufp) case at_dot: case after_dot: continue; -#endif /* not emacs */ +#endif /* emacs */ case no_op: @@ -3275,6 +3275,17 @@ re_search_2 (bufp, string1, size1, string2, size2, startpos, range, regs, stop) range = 1; } +#ifdef emacs + /* In a forward search for something that starts with \=. + don't keep searching past point. */ + if (bufp->used > 0 && (re_opcode_t) bufp->buffer[0] == at_dot && range > 0) + { + range = PT - startpos; + if (range <= 0) + return -1; + } +#endif /* emacs */ + /* Update the fastmap now if not correct already. */ if (fastmap && !bufp->fastmap_accurate) if (re_compile_fastmap (bufp) == -2) @@ -4678,13 +4689,6 @@ re_match_2_internal (bufp, string1, size1, string2, size2, pos, regs, stop) if (PTR_CHAR_POS ((unsigned char *) d) <= point) goto fail; break; -#if 0 /* not emacs19 */ - case at_dot: - DEBUG_PRINT1 ("EXECUTING at_dot.\n"); - if (PTR_CHAR_POS ((unsigned char *) d) + 1 != point) - goto fail; - break; -#endif /* not emacs19 */ case syntaxspec: DEBUG_PRINT2 ("EXECUTING syntaxspec %d.\n", mcnt);