[Zope-Checkins] CVS: Zope3/lib/python/ZODB - Connection.py:1.60.6.11
Jim Fulton
jim@zope.com
Wed, 13 Mar 2002 17:49:28 -0500
Update of /cvs-repository/Zope3/lib/python/ZODB
In directory cvs.zope.org:/tmp/cvs-serv30140
Modified Files:
Tag: Zope-3x-branch
Connection.py
Log Message:
Fixed an incorrect check for a persistent class.
Removed some evil code that unwrapped acquisition-wrapped objects.
Resolved some XXX comments.
=== Zope3/lib/python/ZODB/Connection.py 1.60.6.10 => 1.60.6.11 ===
self._created.append(oid)
else:
- #XXX We should never get here
- #jer: Don't understand previous comment.
+ # We should only get here for the original object passed to commit
if ((self._invalidated.has_key(oid) and
not hasattr(pobject, '_p_resolveConflict'))
or self._invalidated.has_key(None)):
@@ -448,7 +447,7 @@
# It's unclear what exactly this conditional is testing and
# why it takes one branch or the other. It looks like a
# Persistent object will never has it's __getstate__() called.
- if pobject is type:
+ if issubclass(klass, type): # XXX is this a persistent class
dict = {}
dict.update(pobject.__dict__)
# XXX we delete the _p_jar, but not, say, _p_oid?
@@ -456,7 +455,6 @@
args = pobject.__name__, pobject.__bases__, dict
state = None
else:
- # XXX For what kind of object is this path taken?
if hasattr(klass, '__getinitargs__'):
args = pobject.__getinitargs__()
len(args) # XXX Assert it's a sequence
@@ -478,15 +476,7 @@
# Put the object in the cache before handling the
# response, just in case the response contains the
# serial number for a newly created object
- try:
- self._cache[oid] = pobject
- except:
- # Dang, I bet its wrapped:
- # jer: Why does this mean?
- if hasattr(pobject, 'aq_base'):
- self._cache[oid] = pobject.aq_base
- else:
- raise
+ self._cache[oid] = pobject
self._handle_serial(s, oid)
def commit_sub(self, t):
@@ -664,8 +654,9 @@
self.cacheGC() # This is a good time to do some GC
def exchange(self, old, new):
- # XXX This seems to exist only to support ZClasses.
- # replace old's cache entry with new
+ # Replace an existing object with a new one.
+ # This is used by ZClasses to support some deep
+ # hacking to allow base classes to change.
oid = old._p_oid
new._p_oid = oid
new._p_jar = self