[Zope-Checkins] CVS: ZODB3/Persistence - cPickleCache.c:1.85.8.9 cPersistence.c:1.72.8.22
Jeremy Hylton
jeremy@zope.com
Tue, 8 Jul 2003 15:27:48 -0400
Update of /cvs-repository/ZODB3/Persistence
In directory cvs.zope.org:/tmp/cvs-serv7872
Modified Files:
Tag: zodb33-devel-branch
cPickleCache.c cPersistence.c
Log Message:
Change cc_oid_unreferenced() to set cache to NULL after DECREF.
The caller can't be sure that cc_oid_unreferenced() aka percachedel
will DECREF the cache pointer. So the caller does an XDECREF.
Also, don't call ghostify() from deallocated() for a non-ghost. If
we're already getting deallocated, it doesn't make sense to DECREF
ourselves at the end.
=== ZODB3/Persistence/cPickleCache.c 1.85.8.8 => 1.85.8.9 ===
--- ZODB3/Persistence/cPickleCache.c:1.85.8.8 Tue Jul 8 14:19:45 2003
+++ ZODB3/Persistence/cPickleCache.c Tue Jul 8 15:27:41 2003
@@ -492,6 +492,7 @@
if (PyDict_DelItem(self->data, oid) < 0)
return -1;
Py_DECREF((ccobject *)((cPersistentObject *)v)->cache);
+ ((cPersistentObject *)v)->cache = NULL;
if (v->ob_refcnt != 1) {
PyErr_SetString(PyExc_ValueError,
@@ -850,7 +851,7 @@
/* The DelItem below will account for the reference
held by the list. */
} else {
- /* This is a ghost object, so we havent kept a reference
+ /* This is a ghost object, so we haven't kept a reference
count on it. For it have stayed alive this long
someone else must be keeping a reference to
it. Therefore we need to temporarily give it back a
=== ZODB3/Persistence/cPersistence.c 1.72.8.21 => 1.72.8.22 ===
--- ZODB3/Persistence/cPersistence.c:1.72.8.21 Tue Jul 8 15:23:43 2003
+++ ZODB3/Persistence/cPersistence.c Tue Jul 8 15:27:42 2003
@@ -123,20 +123,8 @@
}
static void
-ghostify(cPersistentObject *self)
+unlink_from_ring(cPersistentObject *self)
{
- PyObject **dictptr;
-
- /* are we already a ghost? */
- if (self->state == cPersistent_GHOST_STATE)
- return;
-
- /* XXX is it ever possible to not have a cache? */
- if (self->cache == NULL) {
- self->state = cPersistent_GHOST_STATE;
- return;
- }
-
/* If the cache has been cleared, then a non-ghost object
isn't in the ring any longer.
*/
@@ -151,6 +139,24 @@
self->ring.prev->next = self->ring.next;
self->ring.prev = NULL;
self->ring.next = NULL;
+}
+
+static void
+ghostify(cPersistentObject *self)
+{
+ PyObject **dictptr;
+
+ /* are we already a ghost? */
+ if (self->state == cPersistent_GHOST_STATE)
+ return;
+
+ /* XXX is it ever possible to not have a cache? */
+ if (self->cache == NULL) {
+ self->state = cPersistent_GHOST_STATE;
+ return;
+ }
+
+ unlink_from_ring(self);
self->state = cPersistent_GHOST_STATE;
dictptr = _PyObject_GetDictPtr((PyObject *)self);
if (dictptr && *dictptr) {
@@ -171,7 +177,7 @@
deallocated(cPersistentObject *self)
{
if (self->state >= 0)
- ghostify(self);
+ unlink_from_ring(self);
if (self->cache) {
/* XXX Not sure if it ever makes sense for this function to fail. */
int status = cPersistenceCAPI->percachedel(self->cache, self->oid);