* [PATCH 1/2] start_command: do not clobber cmd->env on Windows code path
[not found] ` <1252560077-1725-1-git-send-email-snaury@gmail.com>
@ 2009-09-11 17:40 ` Johannes Sixt
2009-09-11 17:45 ` [PATCH 2/2] pager: set LESS=FRSX also on Windows Johannes Sixt
2009-09-12 4:32 ` [PATCH 1/2] start_command: do not clobber cmd->env on Windows code path Junio C Hamano
0 siblings, 2 replies; 3+ messages in thread
From: Johannes Sixt @ 2009-09-11 17:40 UTC (permalink / raw)
To: Junio C Hamano; +Cc: msysgit, Alexey Borzenkov, git
Previously, it would not be possible to call start_command twice for the
same struct child_process that has env set.
The fix is achieved by moving the loop that modifies the environment block
into a helper function. This also allows us to make two other helper
functions static.
Signed-off-by: Johannes Sixt <j6t@kdbg.org>
---
We don't call start_command twice in a row anywhere in git.git, but
msysgit has a patch that does, and with the next patch the buglet would
be triggered.
Even after this patch, other members of *cmd are clobbered, so it could
be argued that this patch is unnecessary, but at least the Windows code
path now keeps the same members that the Unix code path keeps, and it
makes start_command easier to read by moving a loop into a helper.
-- Hannes
compat/mingw.c | 16 ++++++++++++++--
compat/mingw.h | 3 +--
run-command.c | 7 ++-----
3 files changed, 17 insertions(+), 9 deletions(-)
diff --git a/compat/mingw.c b/compat/mingw.c
index bed4178..36ef8d3 100644
--- a/compat/mingw.c
+++ b/compat/mingw.c
@@ -824,7 +824,7 @@ void mingw_execvp(const char *cmd, char *const *argv)
free_path_split(path);
}
-char **copy_environ()
+static char **copy_environ(void)
{
char **env;
int i = 0;
@@ -861,7 +861,7 @@ static int lookup_env(char **env, const char *name, size_t nmln)
/*
* If name contains '=', then sets the variable, otherwise it unsets it
*/
-char **env_setenv(char **env, const char *name)
+static char **env_setenv(char **env, const char *name)
{
char *eq = strchrnul(name, '=');
int i = lookup_env(env, name, eq-name);
@@ -886,6 +886,18 @@ char **env_setenv(char **env, const char *name)
return env;
}
+/*
+ * Copies global environ and adjusts variables as specified by vars.
+ */
+char **make_augmented_environ(const char *const *vars)
+{
+ char **env = copy_environ();
+
+ while (*vars)
+ env = env_setenv(env, *vars++);
+ return env;
+}
+
/* this is the first function to call into WS_32; initialize it */
#undef gethostbyname
struct hostent *mingw_gethostbyname(const char *host)
diff --git a/compat/mingw.h b/compat/mingw.h
index 948de66..c43917c 100644
--- a/compat/mingw.h
+++ b/compat/mingw.h
@@ -222,9 +222,8 @@ void mingw_open_html(const char *path);
* helpers
*/
-char **copy_environ(void);
+char **make_augmented_environ(const char *const *vars);
void free_environ(char **env);
-char **env_setenv(char **env, const char *name);
/*
* A replacement of main() that ensures that argv[0] has a path
diff --git a/run-command.c b/run-command.c
index f3e7abb..ac314a5 100644
--- a/run-command.c
+++ b/run-command.c
@@ -173,11 +173,8 @@ fail_pipe:
if (cmd->dir)
die("chdir in start_command() not implemented");
- if (cmd->env) {
- env = copy_environ();
- for (; *cmd->env; cmd->env++)
- env = env_setenv(env, *cmd->env);
- }
+ if (cmd->env)
+ env = make_augmented_environ(cmd->env);
if (cmd->git_cmd) {
cmd->argv = prepare_git_cmd(cmd->argv);
--
1.6.5.rc0.28.gfb9b
^ permalink raw reply related [flat|nested] 3+ messages in thread