[Zope-Checkins] CVS: Zope/lib/python/persistent -
cPickleCache.c:1.91
Jeremy Hylton
jeremy at zope.com
Tue Mar 2 17:13:55 EST 2004
Update of /cvs-repository/Zope/lib/python/persistent
In directory cvs.zope.org:/tmp/cvs-serv10892
Modified Files:
cPickleCache.c
Log Message:
Call _p_invalidate() instead of indirecting through _p_changed.
=== Zope/lib/python/persistent/cPickleCache.c 1.90 => 1.91 ===
--- Zope/lib/python/persistent/cPickleCache.c:1.90 Tue Mar 2 10:37:38 2004
+++ Zope/lib/python/persistent/cPickleCache.c Tue Mar 2 17:13:54 2004
@@ -311,8 +311,20 @@
static void
_invalidate(ccobject *self, PyObject *key)
{
+ static PyObject *_p_invalidate;
PyObject *v = PyDict_GetItem(self->data, key);
+ if (!_p_invalidate) {
+ _p_invalidate = PyString_InternFromString("_p_invalidate");
+ if (!_p_invalidate) {
+ /* It doesn't make any sense to ignore this error, but
+ the caller ignores all errors.
+ */
+ PyErr_Clear();
+ return;
+ }
+ }
+
if (!v)
return;
if (PyType_Check(v)) {
@@ -336,7 +348,16 @@
PyErr_Clear();
}
} else {
- if (PyObject_DelAttr(v, py__p_changed) < 0)
+ PyObject *meth, *err;
+
+ meth = PyObject_GetAttr(v, _p_invalidate);
+ if (!meth) {
+ PyErr_Clear();
+ return;
+ }
+ err = PyObject_CallObject(meth, NULL);
+ Py_DECREF(meth);
+ if (!err)
PyErr_Clear();
}
}
More information about the Zope-Checkins
mailing list