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

Jeremy Hylton cvs-admin at zope.org
Sat Nov 22 00:05:50 EST 2003


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

Modified Files:
      Tag: ZODB3-mvcc-2-branch
	FileStorage.py 
Log Message:
Fix loadNonCurrent() for the abort version case,

but add an optimization that avoids seek+read for the txn header for
cases where it is safe to just use the serialno.


=== ZODB3/ZODB/FileStorage/FileStorage.py 1.1.2.13 => 1.1.2.14 ===
--- ZODB3/ZODB/FileStorage/FileStorage.py:1.1.2.13	Thu Nov 20 16:01:10 2003
+++ ZODB3/ZODB/FileStorage/FileStorage.py	Sat Nov 22 00:05:45 2003
@@ -542,7 +542,7 @@
             pos = self._lookup_pos(oid)
             h = self._read_data_header(pos, oid)
             if h.version and h.version != version:
-                # Retrun data and serial from pnv (non-version data).
+                # Return data and serial from pnv (non-version data).
 
                 # If we return the old record's transaction id, then
                 # it will look to the cache like old data is current.
@@ -603,11 +603,29 @@
         end_tid = None
         while True:
             h = self._read_data_header(pos, oid)
-            # XXX abort version?
-            if h.serial < tid and not h.version:
-                break
+            # Is this the first data record written before tid?
+            #
+            # In most cases, we can just use the serial number which
+            # is more efficient.  In the presence of abort version,
+            # the record's serial number will be the tid of the old
+            # non-version txn.  So we can only use the serial test
+            # if there is no backpointer; abortVersion always writes
+            # a backpointer.
+
+            # The logic is a bit complicated, so explicitly track
+            # whether we need to read the txn header.
+            th = None
+            if not h.version:
+                if not h.back:
+                    if h.serial < tid:
+                        break
+                else:
+                    th = self._read_txn_header(h.tloc)
+                    if th.tid < tid:
+                        break
+            if th is None:
+                th = self._read_txn_header(h.tloc)
             pos = h.prev
-            th = self._read_txn_header(h.tloc)
             end_tid = th.tid
             if not pos:
                 return None




More information about the Zope-Checkins mailing list