diff options
Diffstat (limited to 'git.c')
| -rw-r--r-- | git.c | 60 | 
1 files changed, 29 insertions, 31 deletions
| @@ -66,7 +66,7 @@ static void commit_pager_choice(void) {  static int handle_options(const char ***argv, int *argc, int *envchanged)  { -	int handled = 0; +	const char **orig_argv = *argv;  	while (*argc > 0) {  		const char *cmd = (*argv)[0]; @@ -116,7 +116,6 @@ static int handle_options(const char ***argv, int *argc, int *envchanged)  				*envchanged = 1;  			(*argv)++;  			(*argc)--; -			handled++;  		} else if (!prefixcmp(cmd, "--git-dir=")) {  			setenv(GIT_DIR_ENVIRONMENT, cmd + 10, 1);  			if (envchanged) @@ -156,9 +155,8 @@ static int handle_options(const char ***argv, int *argc, int *envchanged)  		(*argv)++;  		(*argc)--; -		handled++;  	} -	return handled; +	return (*argv) - orig_argv;  }  static int handle_alias(int *argcp, const char ***argv) @@ -177,24 +175,24 @@ static int handle_alias(int *argcp, const char ***argv)  	alias_string = alias_lookup(alias_command);  	if (alias_string) {  		if (alias_string[0] == '!') { +			const char **alias_argv; +			int argc = *argcp, i; +  			commit_pager_choice(); -			if (*argcp > 1) { -				struct strbuf buf; - -				strbuf_init(&buf, PATH_MAX); -				strbuf_addstr(&buf, alias_string); -				sq_quote_argv(&buf, (*argv) + 1, PATH_MAX); -				free(alias_string); -				alias_string = buf.buf; -			} -			trace_printf("trace: alias to shell cmd: %s => %s\n", -				     alias_command, alias_string + 1); -			ret = system(alias_string + 1); -			if (ret >= 0 && WIFEXITED(ret) && -			    WEXITSTATUS(ret) != 127) -				exit(WEXITSTATUS(ret)); -			die("Failed to run '%s' when expanding alias '%s'", -			    alias_string + 1, alias_command); + +			/* build alias_argv */ +			alias_argv = xmalloc(sizeof(*alias_argv) * (argc + 1)); +			alias_argv[0] = alias_string + 1; +			for (i = 1; i < argc; ++i) +				alias_argv[i] = (*argv)[i]; +			alias_argv[argc] = NULL; + +			ret = run_command_v_opt(alias_argv, RUN_USING_SHELL); +			if (ret >= 0)   /* normal exit */ +				exit(ret); + +			die_errno("While expanding alias '%s': '%s'", +			    alias_command, alias_string + 1);  		}  		count = split_cmdline(alias_string, &new_argv);  		if (count < 0) @@ -313,7 +311,6 @@ static void handle_internal_command(int argc, const char **argv)  	const char *cmd = argv[0];  	static struct cmd_struct commands[] = {  		{ "add", cmd_add, RUN_SETUP | NEED_WORK_TREE }, -		{ "stage", cmd_add, RUN_SETUP | NEED_WORK_TREE },  		{ "annotate", cmd_annotate, RUN_SETUP },  		{ "apply", cmd_apply, RUN_SETUP_GENTLY },  		{ "archive", cmd_archive }, @@ -322,15 +319,15 @@ static void handle_internal_command(int argc, const char **argv)  		{ "branch", cmd_branch, RUN_SETUP },  		{ "bundle", cmd_bundle, RUN_SETUP_GENTLY },  		{ "cat-file", cmd_cat_file, RUN_SETUP }, +		{ "check-attr", cmd_check_attr, RUN_SETUP }, +		{ "check-ref-format", cmd_check_ref_format },  		{ "checkout", cmd_checkout, RUN_SETUP | NEED_WORK_TREE },  		{ "checkout-index", cmd_checkout_index,  			RUN_SETUP | NEED_WORK_TREE}, -		{ "check-ref-format", cmd_check_ref_format }, -		{ "check-attr", cmd_check_attr, RUN_SETUP },  		{ "cherry", cmd_cherry, RUN_SETUP },  		{ "cherry-pick", cmd_cherry_pick, RUN_SETUP | NEED_WORK_TREE }, -		{ "clone", cmd_clone },  		{ "clean", cmd_clean, RUN_SETUP | NEED_WORK_TREE }, +		{ "clone", cmd_clone },  		{ "commit", cmd_commit, RUN_SETUP | NEED_WORK_TREE },  		{ "commit-tree", cmd_commit_tree, RUN_SETUP },  		{ "config", cmd_config, RUN_SETUP_GENTLY }, @@ -358,8 +355,8 @@ static void handle_internal_command(int argc, const char **argv)  		{ "init-db", cmd_init_db },  		{ "log", cmd_log, RUN_SETUP },  		{ "ls-files", cmd_ls_files, RUN_SETUP }, -		{ "ls-tree", cmd_ls_tree, RUN_SETUP },  		{ "ls-remote", cmd_ls_remote, RUN_SETUP_GENTLY }, +		{ "ls-tree", cmd_ls_tree, RUN_SETUP },  		{ "mailinfo", cmd_mailinfo },  		{ "mailsplit", cmd_mailsplit },  		{ "merge", cmd_merge, RUN_SETUP | NEED_WORK_TREE }, @@ -379,6 +376,7 @@ static void handle_internal_command(int argc, const char **argv)  		{ "notes", cmd_notes, RUN_SETUP },  		{ "pack-objects", cmd_pack_objects, RUN_SETUP },  		{ "pack-redundant", cmd_pack_redundant, RUN_SETUP }, +		{ "pack-refs", cmd_pack_refs, RUN_SETUP },  		{ "patch-id", cmd_patch_id },  		{ "peek-remote", cmd_ls_remote, RUN_SETUP_GENTLY },  		{ "pickaxe", cmd_blame, RUN_SETUP }, @@ -392,7 +390,7 @@ static void handle_internal_command(int argc, const char **argv)  		{ "remote-ext", cmd_remote_ext },  		{ "remote-fd", cmd_remote_fd },  		{ "replace", cmd_replace, RUN_SETUP }, -		{ "repo-config", cmd_config, RUN_SETUP_GENTLY }, +		{ "repo-config", cmd_repo_config, RUN_SETUP_GENTLY },  		{ "rerere", cmd_rerere, RUN_SETUP },  		{ "reset", cmd_reset, RUN_SETUP },  		{ "rev-list", cmd_rev_list, RUN_SETUP }, @@ -401,8 +399,10 @@ static void handle_internal_command(int argc, const char **argv)  		{ "rm", cmd_rm, RUN_SETUP },  		{ "send-pack", cmd_send_pack, RUN_SETUP },  		{ "shortlog", cmd_shortlog, RUN_SETUP_GENTLY | USE_PAGER }, -		{ "show-branch", cmd_show_branch, RUN_SETUP },  		{ "show", cmd_show, RUN_SETUP }, +		{ "show-branch", cmd_show_branch, RUN_SETUP }, +		{ "show-ref", cmd_show_ref, RUN_SETUP }, +		{ "stage", cmd_add, RUN_SETUP | NEED_WORK_TREE },  		{ "status", cmd_status, RUN_SETUP | NEED_WORK_TREE },  		{ "stripspace", cmd_stripspace },  		{ "symbolic-ref", cmd_symbolic_ref, RUN_SETUP }, @@ -415,13 +415,11 @@ static void handle_internal_command(int argc, const char **argv)  		{ "update-server-info", cmd_update_server_info, RUN_SETUP },  		{ "upload-archive", cmd_upload_archive },  		{ "var", cmd_var, RUN_SETUP_GENTLY }, +		{ "verify-pack", cmd_verify_pack },  		{ "verify-tag", cmd_verify_tag, RUN_SETUP },  		{ "version", cmd_version },  		{ "whatchanged", cmd_whatchanged, RUN_SETUP },  		{ "write-tree", cmd_write_tree, RUN_SETUP }, -		{ "verify-pack", cmd_verify_pack }, -		{ "show-ref", cmd_show_ref, RUN_SETUP }, -		{ "pack-refs", cmd_pack_refs, RUN_SETUP },  	};  	int i;  	static const char ext[] = STRIP_EXTENSION; | 
