[Zope-Checkins] CVS: ZODB3/ZODB - Connection.py:1.113
Jeremy Hylton
jeremy at zope.com
Tue Jan 6 12:01:02 EST 2004
Update of /cvs-repository/ZODB3/ZODB
In directory cvs.zope.org:/tmp/cvs-serv16270/ZODB
Modified Files:
Connection.py
Log Message:
Another fix for non-current objects.
In the branches that call loadBefore() or raise ConflictError, make
sure we always return. Either case satisfies the original call to
setstate() and we don't want to load the current state.
=== ZODB3/ZODB/Connection.py 1.112 => 1.113 ===
--- ZODB3/ZODB/Connection.py:1.112 Mon Jan 5 22:44:53 2004
+++ ZODB3/ZODB/Connection.py Tue Jan 6 12:01:00 2004
@@ -477,10 +477,8 @@
if (obj._p_oid in self._invalidated
and not myhasattr(obj, "_p_independent")):
# If the object has _p_independent(), we will handle it below.
- if not (self._mvcc and self._setstate_noncurrent(obj)):
- self.getTransaction().register(obj)
- self._conflicts[obj._p_oid] = 1
- raise ReadConflictError(object=obj)
+ self._load_before_or_conflict(obj)
+ return
p, serial = self._storage.load(obj._p_oid, self._version)
self._load_count += 1
@@ -496,13 +494,20 @@
# This call will raise a ReadConflictError if something
# goes wrong
self._handle_independent(obj)
- elif not (self._mvcc and self._setstate_noncurrent(obj)):
- self.getTransaction().register(obj)
- self._conflicts[obj._p_oid] = 1
- raise ReadConflictError(object=obj)
+ else:
+ self._load_before_or_conflict(obj)
+ return
self._reader.setGhostState(obj, p)
obj._p_serial = serial
+
+ def _load_before_or_conflict(self, obj):
+ """Load non-current state for obj or raise ReadConflictError."""
+
+ if not (self._mvcc and self._setstate_noncurrent(obj)):
+ self.getTransaction().register(obj)
+ self._conflicts[obj._p_oid] = 1
+ raise ReadConflictError(object=obj)
def _setstate_noncurrent(self, obj):
"""Set state using non-current data.
More information about the Zope-Checkins
mailing list