[Zope-Checkins] CVS: ZODB3/ZODB - Connection.py:1.98.6.5 DB.py:1.53.4.3
Jeremy Hylton
jeremy@zope.com
Mon, 7 Jul 2003 14:11:27 -0400
Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv25817/ZODB
Modified Files:
Tag: zodb33-devel-branch
Connection.py DB.py
Log Message:
Remove some circular reference band-aids from the ZODB trunk.
Get rid of dodgy _breakcr() code, which was causing segfaults in weird
places. We'll rely on GC instead.
Remove clear() method on cache, since it was only called from _breakcr().
Call ghostify() from Per_clear() to attempt to free references in a
clean way. This may not be necessary when the rest of GC support gets
implemented.
Make DB and Connection new-style classes to aid in debugging.
=== ZODB3/ZODB/Connection.py 1.98.6.4 => 1.98.6.5 ===
--- ZODB3/ZODB/Connection.py:1.98.6.4 Tue Jul 1 17:03:43 2003
+++ ZODB3/ZODB/Connection.py Mon Jul 7 14:11:21 2003
@@ -42,7 +42,7 @@
global global_code_timestamp
global_code_timestamp = time()
-class Connection(ExportImport.ExportImport):
+class Connection(ExportImport.ExportImport, object):
"""Object managers for individual object space.
An object space is a version of collection of objects. In a
@@ -125,17 +125,6 @@
else:
ver = ''
return '<Connection at %08x%s>' % (id(self), ver)
-
- def _breakcr(self):
- # Persistent objects and the cache don't participate in GC.
- # Explicitly remove references from the connection to its
- # cache and to the root object, because they refer back to the
- # connection.
- self._cache.clear()
- self._cache = None
- self._incrgc = None
- self.cacheGC = None
- self._root_ = None
def __getitem__(self, oid):
obj = self._cache.get(oid, None)
=== ZODB3/ZODB/DB.py 1.53.4.2 => 1.53.4.3 ===
--- ZODB3/ZODB/DB.py:1.53.4.2 Tue Jul 1 16:57:18 2003
+++ ZODB3/ZODB/DB.py Mon Jul 7 14:11:21 2003
@@ -32,7 +32,7 @@
d[elt] = 1
return d
-class DB(UndoLogCompatible.UndoLogCompatible):
+class DB(UndoLogCompatible.UndoLogCompatible, object):
"""The Object Database
The Object database coordinates access to and interaction of one
@@ -267,9 +267,6 @@
def close(self):
self._storage.close()
- for x, allocated in self._pools[1]:
- for c in allocated:
- c._breakcr()
def commitVersion(self, source, destination='', transaction=None):
if transaction is None: