Andrew's git
/
gitweb.git
/ diff
summary
|
log
|
commit
| diff |
tree
commit
grep
author
committer
pickaxe
?
re
Win32: patch Windows environment on startup
author
Karsten Blees
<blees@dcon.de>
Thu, 17 Jul 2014 15:38:05 +0000
(17:38 +0200)
committer
Junio C Hamano
<gitster@pobox.com>
Mon, 21 Jul 2014 16:32:50 +0000
(09:32 -0700)
Fix Windows specific environment settings on startup rather than checking
for special values on every getenv call.
As a side effect, this makes the patched environment (i.e. with properly
initialized TMPDIR and TERM) available to child processes.
Signed-off-by: Karsten Blees <blees@dcon.de>
Signed-off-by: Stepan Kasal <kasal@ucw.cz>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
compat/mingw.c
patch
|
blob
|
history
raw
|
patch
|
inline
| side by side (parent:
343ff06
)
diff --git
a/compat/mingw.c
b/compat/mingw.c
index 968e8d3c3ec9b579c77110dc8991b99d7dd7649e..74c6180a201edc578b477ced6557963ce89d1116 100644
(file)
--- a/
compat/mingw.c
+++ b/
compat/mingw.c
@@
-1251,7
+1251,7
@@
static int do_putenv(char **env, const char *name, int size, int free_old)
return size;
}
return size;
}
-
static char *do
_getenv(const char *name)
+
char *mingw
_getenv(const char *name)
{
char *value;
int pos = bsearchenv(environ, name, environ_size - 1);
{
char *value;
int pos = bsearchenv(environ, name, environ_size - 1);
@@
-1261,18
+1261,6
@@
static char *do_getenv(const char *name)
return value ? &value[1] : NULL;
}
return value ? &value[1] : NULL;
}
-char *mingw_getenv(const char *name)
-{
- char *result = do_getenv(name);
- if (!result && !strcmp(name, "TMPDIR")) {
- /* on Windows it is TMP and TEMP */
- result = do_getenv("TMP");
- if (!result)
- result = do_getenv("TEMP");
- }
- return result;
-}
-
int mingw_putenv(const char *namevalue)
{
ALLOC_GROW(environ, (environ_size + 1) * sizeof(char*), environ_alloc);
int mingw_putenv(const char *namevalue)
{
ALLOC_GROW(environ, (environ_size + 1) * sizeof(char*), environ_alloc);
@@
-2114,6
+2102,17
@@
void mingw_startup()
/* sort environment for O(log n) getenv / putenv */
qsort(environ, i, sizeof(char*), compareenv);
/* sort environment for O(log n) getenv / putenv */
qsort(environ, i, sizeof(char*), compareenv);
+ /* fix Windows specific environment settings */
+
+ /* on Windows it is TMP and TEMP */
+ if (!mingw_getenv("TMPDIR")) {
+ const char *tmp = mingw_getenv("TMP");
+ if (!tmp)
+ tmp = mingw_getenv("TEMP");
+ if (tmp)
+ setenv("TMPDIR", tmp, 1);
+ }
+
/* initialize critical section for waitpid pinfo_t list */
InitializeCriticalSection(&pinfo_cs);
/* initialize critical section for waitpid pinfo_t list */
InitializeCriticalSection(&pinfo_cs);