Issue #16628: Fix a memory leak in ctypes.resize().
This commit is contained in:
commit
12f33df4a2
|
@ -104,6 +104,8 @@ Core and Builtins
|
|||
Library
|
||||
-------
|
||||
|
||||
- Issue #16628: Fix a memory leak in ctypes.resize().
|
||||
|
||||
- Issue #13120: Allow to call pdb.set_trace() from thread.
|
||||
Patch by Ilya Sandler.
|
||||
|
||||
|
|
|
@ -2446,7 +2446,7 @@ PyCData_clear(CDataObject *self)
|
|||
assert(dict); /* Cannot be NULL for CDataObject instances */
|
||||
Py_CLEAR(self->b_objects);
|
||||
if ((self->b_needsfree)
|
||||
&& ((size_t)dict->size > sizeof(self->b_value)))
|
||||
&& _CDataObject_HasExternalBuffer(self))
|
||||
PyMem_Free(self->b_ptr);
|
||||
self->b_ptr = NULL;
|
||||
Py_CLEAR(self->b_base);
|
||||
|
|
|
@ -1658,7 +1658,7 @@ resize(PyObject *self, PyObject *args)
|
|||
obj->b_size = size;
|
||||
goto done;
|
||||
}
|
||||
if (obj->b_size <= sizeof(obj->b_value)) {
|
||||
if (!_CDataObject_HasExternalBuffer(obj)) {
|
||||
/* We are currently using the objects default buffer, but it
|
||||
isn't large enough any more. */
|
||||
void *ptr = PyMem_Malloc(size);
|
||||
|
|
|
@ -116,6 +116,7 @@ extern int PyObject_stginfo(PyObject *self, Py_ssize_t *psize, Py_ssize_t *palig
|
|||
extern PyTypeObject PyCData_Type;
|
||||
#define CDataObject_CheckExact(v) ((v)->ob_type == &PyCData_Type)
|
||||
#define CDataObject_Check(v) PyObject_TypeCheck(v, &PyCData_Type)
|
||||
#define _CDataObject_HasExternalBuffer(v) ((v)->b_ptr != (char *)&(v)->b_value)
|
||||
|
||||
extern PyTypeObject PyCSimpleType_Type;
|
||||
#define PyCSimpleTypeObject_CheckExact(v) ((v)->ob_type == &PyCSimpleType_Type)
|
||||
|
|
Loading…
Reference in New Issue