From: Wez Furlong Date: Thu, 22 Apr 2004 14:26:03 +0000 (+0000) Subject: The fix for the vc7 libc putenv bug is also needed here to avoid a crash. X-Git-Tag: php-5.0.0RC2~25 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=73f49c16f4b97341a4c26f237e3f82bf2b842902;p=php The fix for the vc7 libc putenv bug is also needed here to avoid a crash. --- diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c index 18d799fdd3..3106022f3d 100644 --- a/ext/standard/basic_functions.c +++ b/ext/standard/basic_functions.c @@ -886,6 +886,13 @@ zend_module_entry basic_functions_module = { static void php_putenv_destructor(putenv_entry *pe) { if (pe->previous_value) { +#if _MSC_VER >= 1300 + /* VS.Net has a bug in putenv() when setting a variable that + * is already set; if the SetEnvironmentVariable() API call + * fails, the Crt will double free() a string. + * We try to avoid this by setting our own value first */ + SetEnvironmentVariable(pe->key, "bugbug"); +#endif putenv(pe->previous_value); } else { # if HAVE_UNSETENV