[Zope-Checkins] CVS: StandaloneZODB/ZODB - FileStorage.py:1.86

Jeremy Hylton jeremy@zope.com
Fri, 29 Mar 2002 17:46:48 -0500


Update of /cvs-repository/StandaloneZODB/ZODB
In directory cvs.zope.org:/tmp/cvs-serv1019

Modified Files:
	FileStorage.py 
Log Message:
Do some reformatting and un-optimization on undoLog()


=== StandaloneZODB/ZODB/FileStorage.py 1.85 => 1.86 ===
     def undoLog(self, first=0, last=-20, filter=None):
         if last < 0:
-            last=first-last+1
+            last = first - last + 1
         self._lock_acquire()
         try:
-            packt = self._packt
-            if packt is None:
+            if self._packt is None:
                 raise UndoError(
                     'Undo is currently disabled for database maintenance.<p>')
-            pos=self._pos
+            pos = self._pos
             # BAW: Why 39 please?  This makes no sense (see also below).
             if pos < 39:
                 return []
             file=self._file
             seek=file.seek
             read=file.read
-            unpack=struct.unpack
-            strip=string.strip
-            encode=base64.encodestring
-            r=[]
-            append=r.append
-            i=0
+            r = []
+            i = 0
             while i < last and pos > 39:
-                seek(pos-8)
-                pos=pos-U64(read(8))-8
-                seek(pos)
-                h=read(TRANS_HDR_LEN)
-                tid, tl, status, ul, dl, el = unpack(">8s8scHHH", h)
-                if tid < packt:
+                self._file.seek(pos - 8)
+                pos = pos - U64(self._file.read(8)) - 8
+                self._file.seek(pos)
+                h = self._file.read(TRANS_HDR_LEN)
+                tid, tl, status, ul, dl, el = struct.unpack(">8s8scHHH", h)
+                if tid < self._packt:
                     break
                 if status != ' ':
                     continue
-                u=ul and read(ul) or ''
-                d=dl and read(dl) or ''
+                d = u = ''
+                if ul:
+                    u = self._file.read(ul)
+                if dl:
+                    d = self._file.read(dl)
                 e = {}
                 if el:
                     try:
@@ -1231,15 +1229,15 @@
                     id = tid + p64(pos)
                 else:
                     id = tid + p64(pos) + next
-                d={'id': encode(id).rstrip(),
-                   'time': TimeStamp(tid).timeTime(),
-                   'user_name': u,
-                   'description': d}
+                d = {'id': base64.encodestring(id).rstrip(),
+                     'time': TimeStamp(tid).timeTime(),
+                     'user_name': u,
+                     'description': d}
                 d.update(e)
                 if filter is None or filter(d):
                     if i >= first:
-                        append(d)
-                    i=i+1
+                        r.append(d)
+                    i += 1
             return r
         finally:
             self._lock_release()