diff options
| author | Raphael Zimmerer <killekulla@rdrz.de> | 2008-10-01 18:11:15 +0200 | 
|---|---|---|
| committer | Shawn O. Pearce <spearce@spearce.org> | 2008-10-01 09:14:54 -0700 | 
| commit | 83caecca2f0805d440099d19011fdedc2b3467a5 (patch) | |
| tree | fd5ba5878c5058991a7e9e3bde78a8908221e500 | |
| parent | 5e22e21769454857e00bc55be1f2eef8d873ba72 (diff) | |
| download | git-83caecca2f0805d440099d19011fdedc2b3467a5.tar.gz | |
git grep: Add "-z/--null" option as in GNU's grep.
Here's a trivial patch that adds "-z" and "--null" options to "git
grep". It was discussed on the mailing-list that git's "-z"
convention should be used instead of GNU grep's "-Z".
So things like 'git grep -l -z "$FOO" | xargs -0 sed -i "s/$FOO/$BOO/"'
do work now.
Signed-off-by: Raphael Zimmerer <killekulla@rdrz.de>
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
| -rw-r--r-- | Documentation/git-grep.txt | 6 | ||||
| -rw-r--r-- | builtin-grep.c | 8 | ||||
| -rw-r--r-- | grep.c | 14 | ||||
| -rw-r--r-- | grep.h | 1 | 
4 files changed, 26 insertions, 3 deletions
| diff --git a/Documentation/git-grep.txt b/Documentation/git-grep.txt index fa4d133c1b..553da6cbb1 100644 --- a/Documentation/git-grep.txt +++ b/Documentation/git-grep.txt @@ -15,6 +15,7 @@ SYNOPSIS  	   [-E | --extended-regexp] [-G | --basic-regexp]  	   [-F | --fixed-strings] [-n]  	   [-l | --files-with-matches] [-L | --files-without-match] +	   [-z | --null]  	   [-c | --count] [--all-match]  	   [-A <post-context>] [-B <pre-context>] [-C <context>]  	   [-f <file>] [-e] <pattern> @@ -94,6 +95,11 @@ OPTIONS  	For better compatibility with 'git-diff', --name-only is a  	synonym for --files-with-matches. +-z:: +--null:: +	Output \0 instead of the character that normally follows a +	file name. +  -c::  --count::  	Instead of showing every matched line, show the number of diff --git a/builtin-grep.c b/builtin-grep.c index 3a51662a35..624f86e287 100644 --- a/builtin-grep.c +++ b/builtin-grep.c @@ -295,6 +295,9 @@ static int external_grep(struct grep_opt *opt, const char **paths, int cached)  		push_arg("-l");  	if (opt->unmatch_name_only)  		push_arg("-L"); +	if (opt->null_following_name) +		/* in GNU grep git's "-z" translates to "-Z" */ +		push_arg("-Z");  	if (opt->count)  		push_arg("-c");  	if (opt->post_context || opt->pre_context) { @@ -599,6 +602,11 @@ int cmd_grep(int argc, const char **argv, const char *prefix)  			opt.unmatch_name_only = 1;  			continue;  		} +		if (!strcmp("-z", arg) || +		    !strcmp("--null", arg)) { +			opt.null_following_name = 1; +			continue; +		}  		if (!strcmp("-c", arg) ||  		    !strcmp("--count", arg)) {  			opt.count = 1; @@ -239,6 +239,8 @@ static int word_char(char ch)  static void show_line(struct grep_opt *opt, const char *bol, const char *eol,  		      const char *name, unsigned lno, char sign)  { +	if (opt->null_following_name) +		sign = '\0';  	if (opt->pathname)  		printf("%s%c", name, sign);  	if (opt->linenum) @@ -246,6 +248,11 @@ static void show_line(struct grep_opt *opt, const char *bol, const char *eol,  	printf("%.*s\n", (int)(eol-bol), bol);  } +static void show_name(struct grep_opt *opt, const char *name) +{ +	printf("%s%c", name, opt->null_following_name ? '\0' : '\n'); +} +  static int fixmatch(const char *pattern, char *line, regmatch_t *match)  {  	char *hit = strstr(line, pattern); @@ -489,7 +496,7 @@ static int grep_buffer_1(struct grep_opt *opt, const char *name,  				return 1;  			}  			if (opt->name_only) { -				printf("%s\n", name); +				show_name(opt, name);  				return 1;  			}  			/* Hit at this line.  If we haven't shown the @@ -555,7 +562,7 @@ static int grep_buffer_1(struct grep_opt *opt, const char *name,  		return 0;  	if (opt->unmatch_name_only) {  		/* We did not see any hit, so we want to show this */ -		printf("%s\n", name); +		show_name(opt, name);  		return 1;  	} @@ -565,7 +572,8 @@ static int grep_buffer_1(struct grep_opt *opt, const char *name,  	 * make it another option?  For now suppress them.  	 */  	if (opt->count && count) -		printf("%s:%u\n", name, count); +		printf("%s%c%u\n", name, +		       opt->null_following_name ? '\0' : ':', count);  	return !!last_hit;  } @@ -74,6 +74,7 @@ struct grep_opt {  	unsigned extended:1;  	unsigned relative:1;  	unsigned pathname:1; +	unsigned null_following_name:1;  	int regflags;  	unsigned pre_context;  	unsigned post_context; | 
