[Zope-Checkins] CVS: ZODB3/BTrees - BTreeTemplate.c:1.74.10.4

Tim Peters tim.one@comcast.net
Mon, 7 Jul 2003 16:07:24 -0400


Update of /cvs-repository/ZODB3/BTrees
In directory cvs.zope.org:/tmp/cvs-serv10524/BTrees

Modified Files:
      Tag: zodb33-devel-branch
	BTreeTemplate.c 
Log Message:
BTree_tp_clear(), BTree_traverse():  Call the base class's tp_traverse
and tp_clear slots too.


=== ZODB3/BTrees/BTreeTemplate.c 1.74.10.3 => 1.74.10.4 ===
--- ZODB3/BTrees/BTreeTemplate.c:1.74.10.3	Mon Jul  7 15:56:03 2003
+++ ZODB3/BTrees/BTreeTemplate.c	Mon Jul  7 16:07:20 2003
@@ -1928,8 +1928,11 @@
     if (self->ob_type == &BTreeType)
 	assert(self->ob_type->tp_dictoffset == 0);
 
-    /* Per_traverse isn't implementated yet. */
-    /* err = PyPersist_TYPE->tp_traverse((PyObject *)self, visit, arg); */
+    /* Call our base type's traverse function.  Because BTrees are
+     * subclasses of Peristent, there must be one.
+     */
+    assert(self->ob_type->tp_base->tp_traverse);
+    err = self->ob_type->tp_base->tp_traverse((PyObject *)self, visit, arg);
     if (err)
 	goto Done;
 
@@ -1964,8 +1967,11 @@
 static int
 BTree_tp_clear(BTree *self)
 {
-    /* Per_clear isn't implementated yet. */
-    /* PyPersist_TYPE->tp_clear((PyObject *)self); */
+    /* Call our base type's clear function.  Because BTrees are
+     * subclasses of Peristent, there must be one.
+     */
+    assert(self->ob_type->tp_base->tp_clear);
+    self->ob_type->tp_base->tp_clear((PyObject *)self);
     if (self->state != cPersistent_GHOST_STATE)
 	_BTree_clear(self);
     return 0;