From: Georg Brandl Date: Sat, 17 Oct 2009 08:57:43 +0000 (+0000) Subject: Fix refleaks in _ctypes PyCSimpleType_New, which fixes the refleak seen in test___all__. X-Git-Tag: v2.7a1~327 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e363b1434d6d659bdb94ab522a9da78f1f5a8bef;p=python Fix refleaks in _ctypes PyCSimpleType_New, which fixes the refleak seen in test___all__. --- diff --git a/Modules/_ctypes/_ctypes.c b/Modules/_ctypes/_ctypes.c index c4f73ba451..4d2302d8ae 100644 --- a/Modules/_ctypes/_ctypes.c +++ b/Modules/_ctypes/_ctypes.c @@ -1889,17 +1889,16 @@ PyCSimpleType_new(PyTypeObject *type, PyObject *args, PyObject *kwds) } fmt = _ctypes_get_fielddesc(PyString_AS_STRING(proto)); if (fmt == NULL) { - Py_DECREF(result); PyErr_Format(PyExc_ValueError, "_type_ '%s' not supported", PyString_AS_STRING(proto)); - return NULL; + goto error; } stgdict = (StgDictObject *)PyObject_CallObject( (PyObject *)&PyCStgDict_Type, NULL); if (!stgdict) - return NULL; + goto error; stgdict->ffi_type_pointer = *fmt->pffi_type; stgdict->align = fmt->pffi_type->alignment; @@ -1914,6 +1913,7 @@ PyCSimpleType_new(PyTypeObject *type, PyObject *args, PyObject *kwds) #endif if (stgdict->format == NULL) { Py_DECREF(result); + Py_DECREF(proto); Py_DECREF((PyObject *)stgdict); return NULL; }