[Zope-Checkins] CVS: Zope/lib/python/ZODB - coptimizations.c:1.17.60.3
Jeremy Hylton
jeremy@zope.com
Fri, 13 Dec 2002 16:27:39 -0500
Update of /cvs-repository/Zope/lib/python/ZODB
In directory cvs.zope.org:/tmp/cvs-serv11305
Modified Files:
Tag: Zope-2_6-branch
coptimizations.c
Log Message:
Add some more comments and add XDECREFs to avoid leaks.
Remove redundant check of ExtensionClass in get_class().
=== Zope/lib/python/ZODB/coptimizations.c 1.17.60.2 => 1.17.60.3 ===
--- Zope/lib/python/ZODB/coptimizations.c:1.17.60.2 Thu Dec 12 14:04:13 2002
+++ Zope/lib/python/ZODB/coptimizations.c Fri Dec 13 16:27:38 2002
@@ -81,14 +81,17 @@
PyErr_Clear();
return 0;
}
- if (!PyExtensionClass_Check(class) ||
- !(((PyExtensionClass*)class)->class_flags
+ /* The __class__ must be an extension class. */
+ if (!(((PyExtensionClass*)class)->class_flags
& PERSISTENT_TYPE_FLAG)) {
Py_DECREF(class);
return 0;
}
}
else
+ /* Most objects will exit via this path. They are neither
+ extension classes nor instances of them.
+ */
return 0;
}
*out_class = class;
@@ -156,21 +159,20 @@
static PyObject *
persistent_id_call(persistent_id *self, PyObject *args, PyObject *kwargs)
{
- PyObject *object, *oid, *klass=NULL;
+ PyObject *object, *oid=NULL, *klass=NULL;
PyObject *t1, *t2;
int setjar = 0;
if (!PyArg_ParseTuple(args, "O", &object))
return NULL;
- /* If it is an extension class, get the class. */
+ /* If it is not an extension class, get the object's class. */
if (!get_class(object, &klass))
goto return_none;
oid = PyObject_GetAttr(object, py__p_oid);
if (!oid) {
PyErr_Clear();
- Py_XDECREF(klass);
goto return_none;
}
@@ -203,7 +205,8 @@
|| PyObject_HasAttr(klass, py___getinitargs__))
goto return_oid;
- if (!klass) /* pass through ZClass special case */
+ /* If this is an extension class, just return _p_oid. */
+ if (!klass)
goto return_oid;
t2 = get_class_tuple(klass, oid);
if (!t2)
@@ -230,6 +233,8 @@
return oid;
return_none:
+ Py_XDECREF(oid);
+ Py_XDECREF(klass);
Py_INCREF(Py_None);
return Py_None;
}