[Zope-Checkins] CVS: Zope3/lib/python/ZODB - Connection.py:1.60.6.14 DB.py:1.34.4.8

Jeremy Hylton jeremy@zope.com
Wed, 20 Mar 2002 15:25:08 -0500


Update of /cvs-repository/Zope3/lib/python/ZODB
In directory cvs.zope.org:/tmp/cvs-serv2608

Modified Files:
      Tag: Zope-3x-branch
	Connection.py DB.py 
Log Message:
Simplify connection between DB and Connection.

The DB object is passed as the first arg to Connection.  Instead of
calling registerDB() every time the Connection is used, do most
initialization in the constructor.  When a Connection is re-used from
the pool, call reset().

Also, remove indirection in DB to create a Connection.





=== Zope3/lib/python/ZODB/Connection.py 1.60.6.13 => 1.60.6.14 ===
     # when we close by putting something here.
 
-    def __init__(self, version='', cache_size=400,
+    def __init__(self, db, version='', cache_size=400,
                  cache_deactivate_after=60):
         """Create a new Connection"""
+        self._db = db
+        self._storage = db._storage
+        self.new_oid = db._storage.new_oid
         self._version = version
         self._cache = cache = Cache(cache_size, cache_deactivate_after)
         self.cacheGC = cache.incrgc
@@ -105,9 +108,6 @@
         
         self._cache_timestamp = _cache_timestamp # set from global
 
-    def db(self):
-        return self._db
-
     def getVersion(self):
         return self._version
         
@@ -286,11 +286,7 @@
         # required by the IPersistentDataManager interface, but unimplemented
         return None
 
-    def registerDB(self, odb):
-        # defined by ZODB.IConnection
-        self._db = odb
-        self._storage = s = odb._storage
-        self.new_oid = s.new_oid
+    def reset(self):
         if self._cache_timestamp != _cache_timestamp:
             # New code is in place.  Start a new cache.
             self._resetCache()
@@ -300,21 +296,12 @@
             self._invalidated.clear()
         self._opened = time.time()
 
-        return self
-
     def close(self):
         self.cacheGC() # This is a good time to do some GC
-        db = self._db
         self.applyCloseCallbacks()
-        # XXX Is it possible for a connection instance to be
-        # associated with different DBs over its lifetime?
-        self._db = None
-        self._storage = None
-        self._tmp = None
-        self.new_oid = None
         self._opened = None
         # Return the connection to the pool.
-        db._closeConnection(self)
+        self._db._closeConnection(self)
 
     # XXX not sure what the callbacks are for, but they're used by Mount
                         


=== Zope3/lib/python/ZODB/DB.py 1.34.4.7 => 1.34.4.8 ===
     of managing objects is done by the connections.
     """
-    klass = Connection
-
     def __init__(self, storage,
                  pool_size=7,
                  cache_size=400,
@@ -368,17 +366,15 @@
                 # This is a temporary connection.
                 # We won't bother with the pools.  This will be
                 # a one-use connection.
-                c=self.klass(
-                    version=version,
-                    cache_size=self._version_cache_size,
-                    cache_deactivate_after=
-                    self._version_cache_deactivate_after)
-                c.registerDB(self)
+                c = Connection(self, version,
+                               cache_size=self._version_cache_size,
+                               cache_deactivate_after=
+                               self._version_cache_deactivate_after)
                 self._temps.append(c)
-                if transaction is not None: transaction[id(c)]=c
+                if transaction is not None:
+                    transaction[id(c)] = c
                 return c
 
-
             pools,pooll=self._pools
 
             # pools is a mapping object:
@@ -419,19 +415,17 @@
                 c=None
                 if version:
                     if self._version_pool_size > len(allocated) or force:
-                        c=self.klass(
-                            version=version,
-                            cache_size=self._version_cache_size,
-                            cache_deactivate_after=
-                            self._version_cache_deactivate_after)
+                        c = Connection(self, version,
+                                       cache_size=self._version_cache_size,
+                                       cache_deactivate_after=
+                                       self._version_cache_deactivate_after)
                         allocated.append(c)
                         pool.append(c)
                 elif self._pool_size > len(allocated) or force:
-                    c=self.klass(
-                        version=version,
-                        cache_size=self._cache_size,
-                        cache_deactivate_after=
-                        self._cache_deactivate_after)
+                    c = Connection(self, version,
+                                   cache_size=self._cache_size,
+                                   cache_deactivate_after=
+                                   self._cache_deactivate_after)
                     allocated.append(c)
                     pool.append(c)
                     
@@ -462,7 +456,7 @@
 
             c=pool[-1]
             del pool[-1]
-            c.registerDB(self)
+            c.reset()
             for pool, allocated in pooll:
                 for cc in pool:
                     cc.cacheGC()