Win32: fix environment memory leaks

All functions that modify the environment have memory leaks.

Disable gitunsetenv in the Makefile and use env_setenv (via mingw_putenv)
instead (this frees removed environment entries).

Move xstrdup from env_setenv to make_augmented_environ, so that
mingw_putenv no longer copies the environment entries (according to POSIX
[1], "the string [...] shall become part of the environment"). This also
fixes the memory leak in gitsetenv, which expects a POSIX compliant putenv.

[1] http://pubs.opengroup.org/onlinepubs/009695399/functions/putenv.html

Note: This patch depends on taking control of char **environ and having
our own mingw_putenv (both introduced in "Win32: Unicode environment
(incoming)").

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>
This commit is contained in:
Karsten Blees 2014-07-17 17:37:57 +02:00 committed by Junio C Hamano
parent b729f98fa5
commit e96942e821
3 changed files with 7 additions and 6 deletions

View file

@ -1220,14 +1220,14 @@ static char **env_setenv(char **env, const char *name)
for (i = 0; env[i]; i++) for (i = 0; env[i]; i++)
; ;
env = xrealloc(env, (i+2)*sizeof(*env)); env = xrealloc(env, (i+2)*sizeof(*env));
env[i] = xstrdup(name); env[i] = (char*) name;
env[i+1] = NULL; env[i+1] = NULL;
} }
} }
else { else {
free(env[i]); free(env[i]);
if (*eq) if (*eq)
env[i] = xstrdup(name); env[i] = (char*) name;
else else
for (; env[i]; i++) for (; env[i]; i++)
env[i] = env[i+1]; env[i] = env[i+1];
@ -1242,8 +1242,10 @@ char **make_augmented_environ(const char *const *vars)
{ {
char **env = copy_environ(); char **env = copy_environ();
while (*vars) while (*vars) {
env = env_setenv(env, *vars++); const char *v = *vars++;
env = env_setenv(env, strchr(v, '=') ? xstrdup(v) : v);
}
return env; return env;
} }

View file

@ -209,6 +209,7 @@ char *mingw_getenv(const char *name);
#define getenv mingw_getenv #define getenv mingw_getenv
int mingw_putenv(const char *namevalue); int mingw_putenv(const char *namevalue);
#define putenv mingw_putenv #define putenv mingw_putenv
#define unsetenv mingw_putenv
int mingw_gethostname(char *host, int namelen); int mingw_gethostname(char *host, int namelen);
#define gethostname mingw_gethostname #define gethostname mingw_gethostname

View file

@ -326,7 +326,6 @@ ifeq ($(uname_S),Windows)
NO_IPV6 = YesPlease NO_IPV6 = YesPlease
NO_UNIX_SOCKETS = YesPlease NO_UNIX_SOCKETS = YesPlease
NO_SETENV = YesPlease NO_SETENV = YesPlease
NO_UNSETENV = YesPlease
NO_STRCASESTR = YesPlease NO_STRCASESTR = YesPlease
NO_STRLCPY = YesPlease NO_STRLCPY = YesPlease
NO_MEMMEM = YesPlease NO_MEMMEM = YesPlease
@ -479,7 +478,6 @@ ifneq (,$(findstring MINGW,$(uname_S)))
NO_SYMLINK_HEAD = YesPlease NO_SYMLINK_HEAD = YesPlease
NO_UNIX_SOCKETS = YesPlease NO_UNIX_SOCKETS = YesPlease
NO_SETENV = YesPlease NO_SETENV = YesPlease
NO_UNSETENV = YesPlease
NO_STRCASESTR = YesPlease NO_STRCASESTR = YesPlease
NO_STRLCPY = YesPlease NO_STRLCPY = YesPlease
NO_MEMMEM = YesPlease NO_MEMMEM = YesPlease