[Zope-Checkins] CVS: ZODB3/ZODB - Connection.py:1.96

Jeremy Hylton jeremy@zope.com
Fri, 13 Jun 2003 13:00:05 -0400


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

Modified Files:
	Connection.py 
Log Message:
Eliminate duplicate code in _handle_serials().


=== ZODB3/ZODB/Connection.py 1.95 => 1.96 ===
--- ZODB3/ZODB/Connection.py:1.95	Fri Jun 13 12:54:43 2003
+++ ZODB3/ZODB/Connection.py	Fri Jun 13 13:00:04 2003
@@ -725,31 +725,24 @@
         if not store_return:
             return
         if isinstance(store_return, StringType):
-            # This code is duplicated in the body of the for loop below.
             assert oid is not None
-            serial = store_return
-            obj = self._cache.get(oid, None)
-            if obj is None:
-                return
-            if serial == ResolvedSerial:
-                del obj._p_changed # transition from changed to ghost
-            else:
-                if change:
-                    obj._p_changed = 0 # transition from changed to uptodate
-                obj._p_serial = serial
+            self._handle_one_serial(oid, store_return, change)
         else:
             for oid, serial in store_return:
-                if not isinstance(serial, StringType):
-                    raise serial
-                obj = self._cache.get(oid, None)
-                if obj is None:
-                    continue
-                if serial == ResolvedSerial:
-                    del obj._p_changed # transition from changed to ghost
-                else:
-                    if change:
-                        obj._p_changed = 0 # trans. from changed to uptodate
-                    obj._p_serial = serial
+                self._handle_one_serial(oid, serial, change)
+
+    def _handle_one_serial(self, oid, serial, change):
+        if not isinstance(serial, StringType):
+            raise serial
+        obj = self._cache.get(oid, None)
+        if obj is None:
+            return
+        if serial == ResolvedSerial:
+            del obj._p_changed # transition from changed to ghost
+        else:
+            if change:
+                obj._p_changed = 0 # trans. from changed to uptodate
+            obj._p_serial = serial
 
     def tpc_finish(self, transaction):
         # It's important that the storage call the function we pass