diff options
Diffstat (limited to 'builtin-rev-parse.c')
| -rw-r--r-- | builtin-rev-parse.c | 29 | 
1 files changed, 24 insertions, 5 deletions
| diff --git a/builtin-rev-parse.c b/builtin-rev-parse.c index 22c6d6ad16..45bead6545 100644 --- a/builtin-rev-parse.c +++ b/builtin-rev-parse.c @@ -301,7 +301,7 @@ static const char *skipspaces(const char *s)  static int cmd_parseopt(int argc, const char **argv, const char *prefix)  { -	static int keep_dashdash = 0; +	static int keep_dashdash = 0, stop_at_non_option = 0;  	static char const * const parseopt_usage[] = {  		"git rev-parse --parseopt [options] -- [<args>...]",  		NULL @@ -309,6 +309,9 @@ static int cmd_parseopt(int argc, const char **argv, const char *prefix)  	static struct option parseopt_opts[] = {  		OPT_BOOLEAN(0, "keep-dashdash", &keep_dashdash,  					"keep the `--` passed as an arg"), +		OPT_BOOLEAN(0, "stop-at-non-option", &stop_at_non_option, +					"stop parsing after the " +					"first non-option argument"),  		OPT_END(),  	}; @@ -318,7 +321,7 @@ static int cmd_parseopt(int argc, const char **argv, const char *prefix)  	int onb = 0, osz = 0, unb = 0, usz = 0;  	strbuf_addstr(&parsed, "set --"); -	argc = parse_options(argc, argv, parseopt_opts, parseopt_usage, +	argc = parse_options(argc, argv, prefix, parseopt_opts, parseopt_usage,  	                     PARSE_OPT_KEEP_DASHDASH);  	if (argc < 1 || strcmp(argv[0], "--"))  		usage_with_options(parseopt_usage, parseopt_opts); @@ -393,8 +396,9 @@ static int cmd_parseopt(int argc, const char **argv, const char *prefix)  	/* put an OPT_END() */  	ALLOC_GROW(opts, onb + 1, osz);  	memset(opts + onb, 0, sizeof(opts[onb])); -	argc = parse_options(argc, argv, opts, usage, -	                     keep_dashdash ? PARSE_OPT_KEEP_DASHDASH : 0); +	argc = parse_options(argc, argv, prefix, opts, usage, +			keep_dashdash ? PARSE_OPT_KEEP_DASHDASH : 0 | +			stop_at_non_option ? PARSE_OPT_STOP_AT_NON_OPTION : 0);  	strbuf_addf(&parsed, " --");  	sq_quote_argv(&parsed, argv, 0); @@ -402,6 +406,18 @@ static int cmd_parseopt(int argc, const char **argv, const char *prefix)  	return 0;  } +static int cmd_sq_quote(int argc, const char **argv) +{ +	struct strbuf buf = STRBUF_INIT; + +	if (argc) +		sq_quote_argv(&buf, argv, 0); +	printf("%s\n", buf.buf); +	strbuf_release(&buf); + +	return 0; +} +  static void die_no_single_rev(int quiet)  {  	if (quiet) @@ -419,6 +435,9 @@ int cmd_rev_parse(int argc, const char **argv, const char *prefix)  	if (argc > 1 && !strcmp("--parseopt", argv[1]))  		return cmd_parseopt(argc - 1, argv + 1, prefix); +	if (argc > 1 && !strcmp("--sq-quote", argv[1])) +		return cmd_sq_quote(argc - 2, argv + 2); +  	prefix = setup_git_directory();  	git_config(git_default_config, NULL);  	for (i = 1; i < argc; i++) { @@ -577,7 +596,7 @@ int cmd_rev_parse(int argc, const char **argv, const char *prefix)  					continue;  				}  				if (!getcwd(cwd, PATH_MAX)) -					die("unable to get current working directory"); +					die_errno("unable to get current working directory");  				printf("%s/.git\n", cwd);  				continue;  			} | 
