]> granicus.if.org Git - php/commitdiff
revert patch that causes invalid reads/crashes on Linux
authorAntony Dovgal <tony2001@php.net>
Mon, 12 May 2008 08:46:49 +0000 (08:46 +0000)
committerAntony Dovgal <tony2001@php.net>
Mon, 12 May 2008 08:46:49 +0000 (08:46 +0000)
ext/standard/basic_functions.c

index 7b29618b27f3604d79e9144b5f1db1aca12174ce..358e8e821e44f34220a9e63ac97a81cf51a199ad 100644 (file)
@@ -3822,7 +3822,9 @@ static void php_putenv_destructor(putenv_entry *pe) /* {{{ */
                SetEnvironmentVariable(pe->key, "bugbug");
 #endif
                putenv(pe->previous_value);
+# if defined(PHP_WIN32)
                efree(pe->previous_value);
+# endif
        } else {
 # if HAVE_UNSETENV
                unsetenv(pe->key);
@@ -4386,8 +4388,12 @@ PHP_FUNCTION(putenv)
                pe.previous_value = NULL;
                for (env = environ; env != NULL && *env != NULL; env++) {
                        if (!strncmp(*env, pe.key, pe.key_len) && (*env)[pe.key_len] == '=') {  /* found it */
-                               /* must copy previous value because putenv can free the string without notice */
+#if defined(PHP_WIN32)
+                               /* must copy previous value because MSVCRT's putenv can free the string without notice */
                                pe.previous_value = estrdup(*env);
+#else
+                               pe.previous_value = *env;
+#endif
                                break;
                        }
                }