Kaydet (Commit) 6a619f44 authored tarafından Guido van Rossum's avatar Guido van Rossum

It turns out that modifying the environment strings is not safe.

Treat them as read-only, and make a copy as appropriately.  This was
first reported by Bill Janssend and later by Craig Rowland and Ron
Sedlmeyer.  This fix is mine.
üst 46ab6dfa
......@@ -290,19 +290,29 @@ convertenviron()
return NULL;
if (environ == NULL)
return d;
/* XXX This part ignores errors */
/* This part ignores errors */
for (e = environ; *e != NULL; e++) {
PyObject *k;
PyObject *v;
char *p = strchr(*e, '=');
if (p == NULL)
continue;
k = PyString_FromStringAndSize(*e, (int)(p-*e));
if (k == NULL) {
PyErr_Clear();
continue;
}
v = PyString_FromString(p+1);
if (v == NULL)
if (v == NULL) {
PyErr_Clear();
Py_DECREF(k);
continue;
*p = '\0';
if (PyDict_GetItemString(d, *e) == NULL)
(void) PyDict_SetItemString(d, *e, v);
*p = '=';
}
if (PyDict_GetItem(d, k) == NULL) {
if (PyDict_SetItem(d, k, v) != 0)
PyErr_Clear();
}
Py_DECREF(k);
Py_DECREF(v);
}
#if defined(PYOS_OS2)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment