mirror of
https://github.com/python/cpython.git
synced 2025-10-24 02:13:49 +00:00
refactor to fix refleaks
This commit is contained in:
parent
6fba3dbce0
commit
b72406b8fa
2 changed files with 49 additions and 27 deletions
|
@ -499,12 +499,10 @@ def isSimpleType(self, field):
|
|||
def visitField(self, field, name, sum=None, prod=None, depth=0):
|
||||
ctype = get_c_type(field.type)
|
||||
if field.opt:
|
||||
add_check = " && _PyObject_GetAttrId(obj, &PyId_%s) != Py_None" \
|
||||
% (field.name)
|
||||
check = "exists_not_none(obj, &PyId_%s)" % (field.name,)
|
||||
else:
|
||||
add_check = str()
|
||||
self.emit("if (_PyObject_HasAttrId(obj, &PyId_%s)%s) {"
|
||||
% (field.name, add_check), depth, reflow=False)
|
||||
check = "_PyObject_HasAttrId(obj, &PyId_%s)" % (field.name,)
|
||||
self.emit("if (%s) {" % (check,), depth, reflow=False)
|
||||
self.emit("int res;", depth+1)
|
||||
if field.seq:
|
||||
self.emit("Py_ssize_t len;", depth+1)
|
||||
|
@ -931,6 +929,18 @@ def visitModule(self, mod):
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int exists_not_none(PyObject *obj, _Py_Identifier *id)
|
||||
{
|
||||
PyObject *attr = _PyObject_GetAttrId(obj, id);
|
||||
if (!attr) {
|
||||
PyErr_Clear();
|
||||
return 0;
|
||||
}
|
||||
int isnone = attr == Py_None;
|
||||
Py_DECREF(attr);
|
||||
return !isnone;
|
||||
}
|
||||
|
||||
""", 0, reflow=False)
|
||||
|
||||
self.emit("static int init_types(void)",0)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue