[Zope-Checkins] CVS: ZODB3/ZODB - FileStorage.py:1.105.2.6

Jeremy Hylton jeremy@zope.com
Thu, 14 Nov 2002 12:01:45 -0500


Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv5883

Modified Files:
      Tag: ZODB3-3_1-branch
	FileStorage.py 
Log Message:
Various small cleanups to help make code understandable.

Move abortVersion() closer to commitVersion().
Replace seek() with read().
Add assertion about where file is point in abortVersion().
Replace variable p in abortVersion with data and bp, because
    p was holding two different things.


=== ZODB3/ZODB/FileStorage.py 1.105.2.5 => 1.105.2.6 ===
--- ZODB3/ZODB/FileStorage.py:1.105.2.5	Tue Nov  5 16:21:44 2002
+++ ZODB3/ZODB/FileStorage.py	Thu Nov 14 12:01:45 2002
@@ -309,9 +309,6 @@
         # hook to use something other than builtin dict
         return {}, {}, {}, {}
 
-    def abortVersion(self, src, transaction):
-        return self.commitVersion(src, '', transaction, abort=1)
-
     def _save_index(self):
         """Write the database index to a file to support quick startup
         """
@@ -441,6 +438,9 @@
             # XXX should log the error, though
             pass # We don't care if this fails.
 
+    def abortVersion(self, src, transaction):
+        return self.commitVersion(src, '', transaction, abort=1)
+
     def commitVersion(self, src, dest, transaction, abort=None):
         # We are going to commit by simply storing back pointers.
         if self._is_read_only:
@@ -521,6 +521,9 @@
                 here += heredelta
 
                 current_oids[oid] = 1
+                # Once we've found the data we are looking for,
+                # we can stop chasing backpointers.
+                break
 
             else:
                 # Hm.  This is a non-current record.  Is there a
@@ -2155,7 +2158,8 @@
         doid, serial, prev, tloc, vlen, plen = unpack(DATA_HDR, h)
 
         if vlen:
-            file.seek(vlen + 16, 1)
+            file.read(16)
+            version = file.read(vlen)
         if plen != z64:
             return file.read(U64(plen)), serial, old, tloc
         back = file.read(8) # We got a back pointer!
@@ -2407,6 +2411,11 @@
             else:
                 version = ''
 
+            datapos = pos + DATA_HDR_LEN
+            if vlen:
+                datapos += 16 + vlen
+            assert self._file.tell() == datapos, (self._file.tell(), datapos)
+
             if pos + dlen > self._tend or tloc != self._tpos:
                 warn("%s data record exceeds transaction record at %s",
                      file.name, pos)
@@ -2415,21 +2424,21 @@
             self._pos = pos + dlen
             tid = None
             if plen:
-                p = self._file.read(plen)
+                data = self._file.read(plen)
             else:
-                p = self._file.read(8)
-                if p == z64:
+                bp = self._file.read(8)
+                if bp == z64:
                     # If the backpointer is 0 (encoded as z64), then
                     # this transaction undoes the object creation.  It
                     # either aborts the version that created the
                     # object or undid the transaction that created it.
                     # Return None instead of a pickle to indicate
                     # this.
-                    p = None
+                    data = None
                 else:
-                    p, _s, tid = _loadBackTxn(self._file, oid, p)
+                    data, _s, tid = _loadBackTxn(self._file, oid, bp)
 
-            r = Record(oid, serial, version, p, tid)
+            r = Record(oid, serial, version, data, tid)
 
             return r