diff options
author | Benjamin Kramer <benny.kra@googlemail.com> | 2010-01-26 18:48:36 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-01-26 19:44:10 +0100 |
commit | 24072c0256a520408575416fe8706667b576ff99 (patch) | |
tree | 1155e3fcc4cd65d214fc406e1858f95f283d12eb /grep.c | |
parent | am: fix patch format detection for Thunderbird "Save As" emails (diff) | |
download | git-24072c0256a520408575416fe8706667b576ff99.tar.xz git-24072c0256a520408575416fe8706667b576ff99.zip |
grep: use REG_STARTEND (if available) to speed up regexec
BSD and glibc have an extension to regexec which takes a buffer + length pair
instead of a NUL-terminated string. Since we already have the length computed
this can save us a strlen call inside regexec.
Signed-off-by: Benjamin Kramer <benny.kra@googlemail.com>
Acked-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'grep.c')
-rw-r--r-- | grep.c | 9 |
1 files changed, 8 insertions, 1 deletions
@@ -640,8 +640,15 @@ static int look_ahead(struct grep_opt *opt, if (p->fixed) hit = !fixmatch(p->pattern, bol, p->ignore_case, &m); - else + else { +#ifdef REG_STARTEND + m.rm_so = 0; + m.rm_eo = *left_p; + hit = !regexec(&p->regexp, bol, 1, &m, REG_STARTEND); +#else hit = !regexec(&p->regexp, bol, 1, &m, 0); +#endif + } if (!hit || m.rm_so < 0 || m.rm_eo < 0) continue; if (earliest < 0 || m.rm_so < earliest) |