diff options
author | Junio C Hamano <gitster@pobox.com> | 2012-05-25 12:04:19 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2012-05-25 12:04:19 -0700 |
commit | fca9e0013eeaad45bff38f66667d2791a1edc53f (patch) | |
tree | b487bf942d747ec16185d361b9249eb5034b7ca4 /builtin/grep.c | |
parent | 4f64464023d0bf7ce065f1dccaf267ca38b3521f (diff) | |
parent | ec83061156e18ce600384d3c57f90729a9295488 (diff) | |
download | git-fca9e0013eeaad45bff38f66667d2791a1edc53f.tar.gz git-fca9e0013eeaad45bff38f66667d2791a1edc53f.tar.xz |
Merge branch 'rs/maint-grep-F'
"git grep -e '$pattern'", unlike the case where the patterns are read from
a file, did not treat individual lines in the given pattern argument as
separate regular expressions as it should.
Diffstat (limited to 'builtin/grep.c')
-rw-r--r-- | builtin/grep.c | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/builtin/grep.c b/builtin/grep.c index 643938d90..fe1726f5e 100644 --- a/builtin/grep.c +++ b/builtin/grep.c @@ -600,15 +600,12 @@ static int file_callback(const struct option *opt, const char *arg, int unset) if (!patterns) die_errno(_("cannot open '%s'"), arg); while (strbuf_getline(&sb, patterns, '\n') == 0) { - char *s; - size_t len; - /* ignore empty line like grep does */ if (sb.len == 0) continue; - s = strbuf_detach(&sb, &len); - append_grep_pat(grep_opt, s, len, arg, ++lno, GREP_PATTERN); + append_grep_pat(grep_opt, sb.buf, sb.len, arg, ++lno, + GREP_PATTERN); } if (!from_stdin) fclose(patterns); |