diff options
| author | Johannes Sixt <johannes.sixt@telecom.at> | 2008-07-23 21:12:18 +0200 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-07-25 17:41:13 -0700 | 
| commit | 49fa65a7a8185e81c1098815df607042103b0493 (patch) | |
| tree | 7f34aec46c7e76a2c1aa8892076fb70084369204 /exec_cmd.c | |
| parent | 966c6edd318f2e44dd150103ec2b6b7a53be58f0 (diff) | |
| download | git-49fa65a7a8185e81c1098815df607042103b0493.tar.gz | |
Allow the built-in exec path to be relative to the command invocation path
If GIT_EXEC_PATH (the macro that is defined in the Makefile) is relative,
it is interpreted relative to the command's invocation path, which usually
is $(bindir).
The Makefile rules were written with the assumption that $(gitexecdir) is
an absolute path. We introduce a separate variable that names the
(absolute) installation directory.
Signed-off-by: Johannes Sixt <johannes.sixt@telecom.at>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'exec_cmd.c')
| -rw-r--r-- | exec_cmd.c | 38 | 
1 files changed, 2 insertions, 36 deletions
| diff --git a/exec_cmd.c b/exec_cmd.c index 45f92eb164..c23603452e 100644 --- a/exec_cmd.c +++ b/exec_cmd.c @@ -7,40 +7,6 @@ extern char **environ;  static const char *argv_exec_path;  static const char *argv0_path; -static const char *builtin_exec_path(void) -{ -#ifndef __MINGW32__ -	return GIT_EXEC_PATH; -#else -	int len; -	char *p, *q, *sl; -	static char *ep; -	if (ep) -		return ep; - -	len = strlen(_pgmptr); -	if (len < 2) -		return ep = "."; - -	p = ep = xmalloc(len+1); -	q = _pgmptr; -	sl = NULL; -	/* copy program name, turn '\\' into '/', skip last part */ -	while ((*p = *q)) { -		if (*q == '\\' || *q == '/') { -			*p = '/'; -			sl = p; -		} -		p++, q++; -	} -	if (sl) -		*sl = '\0'; -	else -		ep[0] = '.', ep[1] = '\0'; -	return ep; -#endif -} -  const char *system_path(const char *path)  {  	if (!is_absolute_path(path) && argv0_path) { @@ -75,7 +41,7 @@ const char *git_exec_path(void)  		return env;  	} -	return builtin_exec_path(); +	return system_path(GIT_EXEC_PATH);  }  static void add_path(struct strbuf *out, const char *path) @@ -99,7 +65,7 @@ void setup_path(void)  	add_path(&new_path, argv_exec_path);  	add_path(&new_path, getenv(EXEC_PATH_ENVIRONMENT)); -	add_path(&new_path, builtin_exec_path()); +	add_path(&new_path, system_path(GIT_EXEC_PATH));  	add_path(&new_path, argv0_path);  	if (old_path) | 
