From: Andrew M. Kuchling Date: Tue, 3 Oct 2006 18:32:25 +0000 (+0000) Subject: [Backport r50678 | neal.norwitz] X-Git-Tag: v2.4.4c1~73 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=1c0d8f0fec23517563d5c50c27040b6a2730d5d9;p=thirdparty%2FPython%2Fcpython.git [Backport r50678 | neal.norwitz] Fix memory leak under some conditions. Reported by Klocwork, #98. --- diff --git a/Python/import.c b/Python/import.c index 5033819d8c45..fff4b836b8bf 100644 --- a/Python/import.c +++ b/Python/import.c @@ -1847,11 +1847,10 @@ PyImport_ImportFrozenModule(char *name) if (co == NULL) return -1; if (!PyCode_Check(co)) { - Py_DECREF(co); PyErr_Format(PyExc_TypeError, "frozen object %.200s is not a code object", name); - return -1; + goto err_return; } if (ispackage) { /* Set __path__ to the package name */ @@ -1859,22 +1858,25 @@ PyImport_ImportFrozenModule(char *name) int err; m = PyImport_AddModule(name); if (m == NULL) - return -1; + goto err_return; d = PyModule_GetDict(m); s = PyString_InternFromString(name); if (s == NULL) - return -1; + goto err_return; err = PyDict_SetItemString(d, "__path__", s); Py_DECREF(s); if (err != 0) - return err; + goto err_return; } m = PyImport_ExecCodeModuleEx(name, co, ""); - Py_DECREF(co); if (m == NULL) - return -1; + goto err_return; + Py_DECREF(co); Py_DECREF(m); return 1; +err_return: + Py_DECREF(co); + return -1; }