mirror of
https://github.com/python/cpython.git
synced 2025-09-27 10:50:04 +00:00
bpo-35529: Fix a reference counting bug in PyCFuncPtr_FromDll(). (GH-11229)
"dll" would leak if an error occurred in _validate_paramflags() or GenericPyCData_new().
This commit is contained in:
parent
b13a20f507
commit
d77d97c9a1
1 changed files with 8 additions and 5 deletions
|
@ -3483,20 +3483,23 @@ PyCFuncPtr_FromDll(PyTypeObject *type, PyObject *args, PyObject *kwds)
|
|||
return NULL;
|
||||
}
|
||||
#endif
|
||||
Py_INCREF(dll); /* for KeepRef */
|
||||
Py_DECREF(ftuple);
|
||||
if (!_validate_paramflags(type, paramflags))
|
||||
if (!_validate_paramflags(type, paramflags)) {
|
||||
Py_DECREF(ftuple);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
self = (PyCFuncPtrObject *)GenericPyCData_new(type, args, kwds);
|
||||
if (!self)
|
||||
if (!self) {
|
||||
Py_DECREF(ftuple);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
Py_XINCREF(paramflags);
|
||||
self->paramflags = paramflags;
|
||||
|
||||
*(void **)self->b_ptr = address;
|
||||
|
||||
Py_INCREF(dll);
|
||||
Py_DECREF(ftuple);
|
||||
if (-1 == KeepRef((CDataObject *)self, 0, dll)) {
|
||||
Py_DECREF((PyObject *)self);
|
||||
return NULL;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue