[Zope-Checkins] CVS: ZODB3/BDBStorage - BDBFullStorage.py:1.44.4.6

Barry Warsaw barry@zope.com
Thu, 24 Jul 2003 14:46:47 -0400


Update of /cvs-repository/ZODB3/BDBStorage
In directory cvs.zope.org:/tmp/cvs-serv6898/BDBStorage

Modified Files:
      Tag: ZODB3-3_1-branch
	BDBFullStorage.py 
Log Message:
Back port a few changes from ZODB 3 head:

_doabort(): Protect from deleting non-existant pickles
  Only clean up the currentVersions tabl when vid <> ZERO
  Minor local variable naming consistency

getSerial(): Raise KeyError when the object has been uncreated.

_TransactionsIterator.iterator(): Add this, which just returns self,
meaning it can be used as the `other' arg to copyTransactionsFrom().


=== ZODB3/BDBStorage/BDBFullStorage.py 1.44.4.5 => 1.44.4.6 ===
--- ZODB3/BDBStorage/BDBFullStorage.py:1.44.4.5	Fri Jun 13 16:46:27 2003
+++ ZODB3/BDBStorage/BDBFullStorage.py	Thu Jul 24 14:46:42 2003
@@ -338,7 +338,10 @@
                 revid = oid+tid
                 vid = self._metadata[revid][:8]
                 self._metadata.delete(revid, txn=txn)
-                self._pickles.delete(revid, txn=txn)
+                try:
+                    self._pickles.delete(revid, txn=txn)
+                except db.DBNotFoundError:
+                    pass
                 # Clean up the object revisions table
                 try:
                     cr.set(oid+tid)
@@ -347,11 +350,8 @@
                 else:
                     cr.delete()
                 # Now we have to clean up the currentVersions table
-                try:
+                if vid <> ZERO:
                     cv.set_both(vid, revid)
-                except db.DBNotFoundError:
-                    pass
-                else:
                     cv.delete()
         finally:
             # There's a small window of opportunity for leaking cursors here,
@@ -362,17 +362,17 @@
             if cv: cv.close()
             if cr: cr.close()
         # Now clean up the vids and versions tables
-        cv = self._pvids.cursor(txn=txn)
+        cpv = self._pvids.cursor(txn=txn)
         try:
-            rec = cv.first()
+            rec = cpv.first()
             while rec:
                 vid = rec[0]
-                rec = cv.next()
+                rec = cpv.next()
                 version = self._versions[vid]
                 self._versions.delete(vid, txn=txn)
                 self._vids.delete(version, txn=txn)
         finally:
-            cv.close()
+            cpv.close()
         # Now clean up the tid indexed table, and the temporary log tables
         self._txnMetadata.delete(tid, txn=txn)
         self._oids.truncate(txn)
@@ -1053,6 +1053,10 @@
         self._lock_acquire()
         try:
             serial, tid = self._getSerialAndTid(oid)
+            # See if the object has been uncreated
+            lrevid = unpack('>8s', self._metadata[oid+tid][16:24])[0]
+            if lrevid == DNE:
+                raise KeyError
             return serial
         finally:
             self._lock_release()
@@ -1794,6 +1798,13 @@
         # This is a lie.  It's here only for Python 2.1 support for
         # list()-ifying these objects.
         return 0
+
+    # This allows us to pass an iterator as the `other' argument to
+    # copyTransactionsFrom() in BaseStorage.  The advantage here is that we
+    # can create the iterator manually, e.g. setting start and stop, and then
+    # just let copyTransactionsFrom() do its thing.
+    def iterator(self):
+        return self
 
     def next(self):
         """Return the ith item in the sequence of transaction data.