[Zope-Checkins] CVS: Zope/lib/python/Products/Transience - Transience.py:1.31
Chris McDonough
chrism@zope.com
Thu, 9 Jan 2003 11:38:06 -0500
Update of /cvs-repository/Zope/lib/python/Products/Transience
In directory cvs.zope.org:/tmp/cvs-serv7983
Modified Files:
Transience.py
Log Message:
Work around cases where BTrees lie about their keys.
=== Zope/lib/python/Products/Transience/Transience.py 1.30 => 1.31 ===
--- Zope/lib/python/Products/Transience/Transience.py:1.30 Sat Oct 26 11:42:23 2002
+++ Zope/lib/python/Products/Transience/Transience.py Thu Jan 9 11:38:03 2003
@@ -513,7 +513,7 @@
# these keys, deindexing buckets as necessary when they're older
# than the timeout.
# XXX - fixme! range search doesn't always work (btrees bug)
- for k in data.keys(deindex_next, pprev):
+ for k in list(data.keys(deindex_next, pprev)):
if k < deindex_next:
DEBUG and TLOG(
'broken range search: key %s < min %s'
@@ -549,19 +549,26 @@
# if the bucket has keys, deindex them and add them to the
# notify queue (destruction notification happens during
# garbage collection)
- bucket = data[k]
- keys = bucket.keys()
+ bucket = data.get(k, _marker)
+ if bucket is _marker:
+ DEBUG and TLOG(
+ 'data IOBTree lied about keys: %s doesnt exist' % k
+ )
+ continue
+
+ keys = list(bucket.keys())
for key in keys:
ob = bucket.get(key, _marker)
if ob is _marker:
DEBUG and TLOG(
- 'OOBTree lied about %s keys: %s doesnt exist' %
- (bucket, key)
+ 'bucket OOBTree lied about keys: %s doesnt exist' %
+ key
)
continue
self.notify_queue.put((key, ob))
DEBUG and TLOG(
- '_getCurrentBucket: deindexing keys %s' % list(keys))
+ '_getCurrentBucket: deindexing keys %s' % keys
+ )
keys and self._deindex(keys)
# set the "last deindexed" pointer to k + period
deindex_next = k+period
@@ -685,7 +692,12 @@
% (k, delete_end)
)
continue
- bucket = data[k]
+ bucket = data.get(k, _marker)
+ if bucket is _marker:
+ DEBUG and TLOG(
+ 'bucket OOBTree lied about keys: %s doesnt exist' % k
+ )
+ continue
# delete the bucket from _data
del data[k]
DEBUG and TLOG('_housekeep: deleted data[%s]' % k)