diff options
| author | Johannes Sixt <johannes.sixt@telecom.at> | 2008-07-21 21:19:52 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-07-25 17:41:13 -0700 | 
| commit | e1464ca7bb0d705210ba7198f004b2fb2b807e12 (patch) | |
| tree | 853d900a35dffa52c1001f3408eca528229afe5c /git.c | |
| parent | 46beb55988e68da04c2e9d319c71b9b940f0854c (diff) | |
| download | git-e1464ca7bb0d705210ba7198f004b2fb2b807e12.tar.gz | |
Record the command invocation path early
We will need the command invocation path in system_path(). This path was
passed to setup_path(), but  system_path() can be called earlier, for
example via:
    main
      commit_pager_choice
        setup_pager
          git_config
            git_etc_gitconfig
              system_path
Therefore, we introduce git_set_argv0_path() and call it as soon as
possible.
Signed-off-by: Johannes Sixt <johannes.sixt@telecom.at>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git.c')
| -rw-r--r-- | git.c | 5 | 
1 files changed, 2 insertions, 3 deletions
| @@ -418,7 +418,6 @@ int main(int argc, const char **argv)  {  	const char *cmd = argv[0] && *argv[0] ? argv[0] : "git-help";  	char *slash = (char *)cmd + strlen(cmd); -	const char *cmd_path = NULL;  	int done_alias = 0;  	/* @@ -431,7 +430,7 @@ int main(int argc, const char **argv)  	while (cmd <= slash && !is_dir_sep(*slash));  	if (cmd <= slash) {  		*slash++ = 0; -		cmd_path = cmd; +		git_set_argv0_path(cmd);  		cmd = slash;  	} @@ -475,7 +474,7 @@ int main(int argc, const char **argv)  	 * environment, and the $(gitexecdir) from the Makefile at build  	 * time.  	 */ -	setup_path(cmd_path); +	setup_path();  	while (1) {  		/* See if it's an internal command */ | 
