[Zodb-checkins] CVS: ZODB3/ZODB - utils.py:1.18 transact.py:1.3 fsrecover.py:1.13 fspack.py:1.11 config.py:1.15 cPickleCache.c:1.86 __init__.py:1.24 Transaction.py:1.50 TmpStore.py:1.11 POSException.py:1.21 FileStorage.py:1.138 DemoStorage.py:1.21 DB.py:1.55 Connection.py:1.100 BaseStorage.py:1.36

Jeremy Hylton jeremy at zope.com
Thu Oct 2 14:17:52 EDT 2003


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

Modified Files:
	utils.py transact.py fsrecover.py fspack.py config.py 
	cPickleCache.c __init__.py Transaction.py TmpStore.py 
	POSException.py FileStorage.py DemoStorage.py DB.py 
	Connection.py BaseStorage.py 
Log Message:
Merge changes from Zope-2_7-branch to the trunk.


=== ZODB3/ZODB/utils.py 1.17 => 1.18 ===
--- ZODB3/ZODB/utils.py:1.17	Tue Jun 10 11:46:31 2003
+++ ZODB3/ZODB/utils.py	Thu Oct  2 14:17:19 2003
@@ -96,4 +96,3 @@
         return repr(oid)
 
 serial_repr = oid_repr
-


=== ZODB3/ZODB/transact.py 1.2 => 1.3 ===
--- ZODB3/ZODB/transact.py:1.2	Wed Jun 11 11:05:07 2003
+++ ZODB3/ZODB/transact.py	Thu Oct  2 14:17:19 2003
@@ -34,7 +34,7 @@
     """
 
     # XXX deal with ZEO disconnected errors?
-    
+
     def g(*args, **kwargs):
         n = retries
         while n:


=== ZODB3/ZODB/fsrecover.py 1.12 => 1.13 ===
--- ZODB3/ZODB/fsrecover.py:1.12	Fri May 30 15:59:55 2003
+++ ZODB3/ZODB/fsrecover.py	Thu Oct  2 14:17:19 2003
@@ -227,7 +227,7 @@
     except getopt.error:
         die()
         print __doc__ % argv[0]
-        
+
     force = partial = verbose = 0
     pack = None
     for opt, v in opts:
@@ -321,7 +321,7 @@
                         l = "bp"
                     else:
                         l = len(r.data)
-                        
+
                     print "%7d %s %s" % (u64(r.oid), l, r.version)
                 s = ofs.restore(r.oid, r.serial, r.data, r.version,
                                 r.data_txn, txn)
@@ -372,4 +372,3 @@
 
 if __name__ == "__main__":
     main()
-


=== ZODB3/ZODB/fspack.py 1.10 => 1.11 ===
--- ZODB3/ZODB/fspack.py:1.10	Mon Sep 15 12:29:15 2003
+++ ZODB3/ZODB/fspack.py	Thu Oct  2 14:17:19 2003
@@ -192,7 +192,7 @@
             if dh.plen:
                 self.fail(pos, "data record has back pointer and data")
 
-def DataHeaderFromString(s):            
+def DataHeaderFromString(s):
     return DataHeader(*struct.unpack(DATA_HDR, s))
 
 class DataHeader:
@@ -338,7 +338,7 @@
                 return pos
             pos += h.recordlen()
         return 0
-    
+
     def _restore_pnv(self, oid, prev, version, bp):
         # Find a valid pnv (previous non-version) pointer for this version.
 
@@ -415,7 +415,7 @@
                 self._tfile.write(z64)
         else:
             self._tfile.write(data)
-            
+
 class GC(FileStorageFormatter):
 
     def __init__(self, file, eof, packtime):
@@ -437,7 +437,7 @@
         # second is a dictionary mapping objects to lists of
         # positions; it is used to handle the same number of objects
         # for which we must keep multiple revisions.
-        
+
         self.reachable = fsIndex()
         self.reach_ex = {}
 
@@ -460,7 +460,7 @@
         self.findReachableFromFuture()
         # These mappings are no longer needed and may consume a lot
         # of space.
-        del self.oid2verpos 
+        del self.oid2verpos
         del self.oid2curpos
 
     def buildPackIndex(self):
@@ -528,7 +528,7 @@
         # non-current revision could refer to objects that were
         # otherwise unreachable at the packtime.
         extra_roots = []
-        
+
         pos = self.packpos
         while pos < self.eof:
             th = self._read_txn_header(pos)
@@ -558,7 +558,7 @@
                             extra_roots.append(dh.pnv)
                     else:
                         self.reachable[dh.oid] = dh.back
-                        
+
                 pos += dh.recordlen()
 
             tlen = self._read_num(pos)
@@ -631,7 +631,7 @@
         self._file.seek(0, 2)
         self.file_end = self._file.tell()
         self._file.seek(0)
-        
+
         self.gc = GC(self._file, self.file_end, self._stop)
 
         # The packer needs to acquire the parent's commit lock
@@ -672,7 +672,7 @@
         # Txn and data records contain pointers to previous records.
         # Because these pointers are stored as file offsets, they
         # must be updated when we copy data.
-        
+
         # XXX Need to add sanity checking to pack
 
         self.gc.findReachable()
@@ -730,7 +730,7 @@
                 self._tfile.seek(new_pos - 8)
                 self._tfile.write(p64(tlen))
 
-            
+
             tlen = self._read_num(pos)
             if tlen != th.tlen:
                 self.fail(pos, "redundant transaction length does not "
@@ -757,7 +757,7 @@
 
         Returns position of txn header in output file and position
         of next record in the input file.
-        
+
         If any data records are copied, also write txn header (th).
         """
         copy = 0
@@ -878,4 +878,3 @@
         if self._lock_counter % 20 == 0:
             self._commit_lock_acquire()
         return ipos
-


=== ZODB3/ZODB/config.py 1.14 => 1.15 ===


=== ZODB3/ZODB/cPickleCache.c 1.85 => 1.86 ===
--- ZODB3/ZODB/cPickleCache.c:1.85	Fri May 30 15:20:55 2003
+++ ZODB3/ZODB/cPickleCache.c	Thu Oct  2 14:17:19 2003
@@ -499,6 +499,17 @@
 	Py_DECREF(o);
     }
     self->ring_lock = 0;
+
+    /* Free two references to the Connection, which can't be discovered
+       via garbage collection.
+    */
+
+    Py_XDECREF(self->setklassstate);
+    self->setklassstate = NULL;
+
+    Py_XDECREF(self->jar);
+    self->jar = NULL;
+
     Py_INCREF(Py_None);
     return Py_None;
 }


=== ZODB3/ZODB/__init__.py 1.23 => 1.24 ===
--- ZODB3/ZODB/__init__.py:1.23	Mon Jun 16 17:49:58 2003
+++ ZODB3/ZODB/__init__.py	Thu Oct  2 14:17:19 2003
@@ -12,7 +12,7 @@
 #
 ##############################################################################
 
-__version__ = '3.2b2'
+__version__ = '3.2c1'
 
 import sys
 import cPersistence, Persistence


=== ZODB3/ZODB/Transaction.py 1.49 => 1.50 ===
--- ZODB3/ZODB/Transaction.py:1.49	Tue Jun 10 11:46:31 2003
+++ ZODB3/ZODB/Transaction.py	Thu Oct  2 14:17:19 2003
@@ -43,7 +43,7 @@
     except:
         LOG("TM", WARNING, "jar missing sortKey() method: %s" % j2)
         k2 = id(j2)
-        
+
     return cmp(k1, k2)
 
 class Transaction:
@@ -271,12 +271,12 @@
 
     def _get_jars(self, objects, subtransaction):
         # Returns a list of jars for this transaction.
-        
+
         # Find all the jars and sort them in a globally consistent order.
         # objects is a list of persistent objects and jars.
         # If this is a subtransaction and a jar is not subtransaction aware,
         # it's object gets delayed until the parent transaction commits.
-        
+
         d = {}
         for o in objects:
             jar = getattr(o, '_p_jar', o)
@@ -298,7 +298,7 @@
                     if self._non_st_objects is None:
                         self._non_st_objects = []
                     self._non_st_objects.append(o)
-                
+
         jars = d.values()
         jars.sort(jar_cmp)
 
@@ -406,7 +406,7 @@
 
         # After the tpc_abort(), call abort_sub() on all the
         # subtrans-aware jars to *really* abort the subtransaction.
-        
+
         # Example: For Connection(), the tpc_abort() will abort the
         # subtransaction TmpStore() and abort_sub() will remove the
         # TmpStore.


=== ZODB3/ZODB/TmpStore.py 1.10 => 1.11 ===
--- ZODB3/ZODB/TmpStore.py:1.10	Tue Apr  8 14:48:22 2003
+++ ZODB3/ZODB/TmpStore.py	Thu Oct  2 14:17:19 2003
@@ -42,7 +42,7 @@
 
     def getName(self):
         return self._db.getName()
-    
+
     def getSize(self):
         return self._pos
 


=== ZODB3/ZODB/POSException.py 1.20 => 1.21 ===
--- ZODB3/ZODB/POSException.py:1.20	Tue Jun 10 11:46:31 2003
+++ ZODB3/ZODB/POSException.py	Thu Oct  2 14:17:19 2003
@@ -173,7 +173,7 @@
 
 class MultipleUndoErrors(UndoError):
     """Several undo errors occured during a single transaction."""
-    
+
     def __init__(self, errs):
         # provide a reason and oid for clients that only look at that
         UndoError.__init__(self, *errs[0])


=== ZODB3/ZODB/FileStorage.py 1.137 => 1.138 ===
--- ZODB3/ZODB/FileStorage.py:1.137	Mon Sep 15 12:29:15 2003
+++ ZODB3/ZODB/FileStorage.py	Thu Oct  2 14:17:19 2003
@@ -293,7 +293,7 @@
         self._records_before_save = max(self._records_before_save,
                                         len(self._index))
         self._ltid = tid
-        
+
         # self._pos should always point just past the last
         # transaction.  During 2PC, data is written after _pos.
         # invariant is restored at tpc_abort() or tpc_finish().
@@ -607,7 +607,7 @@
                 self._file.seek(u64(pnv))
                 h_pnv = self._file.read(DATA_VERSION_HDR_LEN)
                 newserial = h_pnv[8:16]
-            
+
             if self._index.get(oid) == srcpos:
                 # This is a current record!
                 self._tindex[oid] = here
@@ -981,7 +981,7 @@
             else:
                 warn("restore could not find previous non-version data "
                      "at %d or %d" % (prev, bp))
-            
+
         return pnv
 
     def supportsUndo(self):
@@ -1075,7 +1075,7 @@
             if fsync is not None: fsync(file.fileno())
 
             self._pos = nextpos
-            
+
             self._index.update(self._tindex)
             self._vindex.update(self._tvindex)
             self._oid2serial.update(self._toid2serial)
@@ -1084,16 +1084,16 @@
                     del self._oid2serial[oid]
                 except KeyError:
                     pass
-            
+
             # Update the number of records that we've written
             # +1 for the transaction record
-            self._records_written += len(self._tindex) + 1 
+            self._records_written += len(self._tindex) + 1
             if self._records_written >= self._records_before_save:
                 self._save_index()
                 self._records_written = 0
                 self._records_before_save = max(self._records_before_save,
                                                 len(self._index))
-                
+
         self._ltid = tid
 
     def _abort(self):
@@ -1538,7 +1538,7 @@
         # If the storage is empty, there's nothing to do.
         if not self._index:
             return
-        
+
         # Record pack time so we don't undo while packing
         self._lock_acquire()
         try:


=== ZODB3/ZODB/DemoStorage.py 1.20 => 1.21 ===


=== ZODB3/ZODB/DB.py 1.54 => 1.55 ===
--- ZODB3/ZODB/DB.py:1.54	Mon Sep 15 12:29:15 2003
+++ ZODB3/ZODB/DB.py	Thu Oct  2 14:17:19 2003
@@ -145,9 +145,9 @@
                 # We need to break circular refs to make it really go.
                 # XXX What objects are involved in the cycle?
                 connection.__dict__.clear()
-                
+
                 return
-                
+
             pool.append(connection)
             if len(pool)==1:
                 # Pool now usable again, unlock it.


=== ZODB3/ZODB/Connection.py 1.99 => 1.100 ===
--- ZODB3/ZODB/Connection.py:1.99	Mon Sep 15 12:29:15 2003
+++ ZODB3/ZODB/Connection.py	Thu Oct  2 14:17:19 2003
@@ -308,12 +308,12 @@
                 method_name, args, kw = self.__onCommitActions.pop(0)
                 getattr(self, method_name)(transaction, *args, **kw)
             return
-        
+
         oid = object._p_oid
         if self._conflicts.has_key(oid):
             self.getTransaction().register(object)
             raise ReadConflictError(object=object)
-        
+
         invalid = self._invalid
         if oid is None or object._p_jar is not self:
             # new object
@@ -625,7 +625,7 @@
         else:
             self.getTransaction().register(obj)
             raise ReadConflictError(object=obj)
-        
+
     def oldstate(self, object, serial):
         oid=object._p_oid
         p = self._storage.loadSerial(oid, serial)
@@ -717,7 +717,7 @@
         # the connection does not match what is written to the
         # database.  Invalidate the object here to guarantee that
         # the new state is read the next time the object is used.
-        
+
         if not store_return:
             return
         if isinstance(store_return, StringType):
@@ -757,7 +757,7 @@
             def callback():
                 d = {}
                 for oid in self._modified:
-                    d[oid] = 1 
+                    d[oid] = 1
                 self._db.invalidate(d, self)
             self._storage.tpc_finish(transaction, callback)
 


=== ZODB3/ZODB/BaseStorage.py 1.35 => 1.36 ===




More information about the Zodb-checkins mailing list