Commit 403321d4 authored by Jim Fulton's avatar Jim Fulton

Changed to log any error when loading an objects state, including

storage errors.
parent 96d783ca
...@@ -84,8 +84,8 @@ ...@@ -84,8 +84,8 @@
############################################################################## ##############################################################################
"""Database connection support """Database connection support
$Id: Connection.py,v 1.27 1999/10/07 14:17:50 jim Exp $""" $Id: Connection.py,v 1.28 1999/10/07 22:41:01 jim Exp $"""
__version__='$Revision: 1.27 $'[11:-2] __version__='$Revision: 1.28 $'[11:-2]
from cPickleCache import PickleCache from cPickleCache import PickleCache
from POSException import ConflictError, ExportError from POSException import ConflictError, ExportError
...@@ -384,32 +384,30 @@ class Connection(ExportImport.ExportImport): ...@@ -384,32 +384,30 @@ class Connection(ExportImport.ExportImport):
def root(self): return self['\0\0\0\0\0\0\0\0'] def root(self): return self['\0\0\0\0\0\0\0\0']
def setstate(self,object): def setstate(self,object):
# Note, we no longer mess with the object's state
# flag, _p_changed. This is the object's job.
oid=object._p_oid
invalid=self._invalid
if invalid(oid) or invalid(None): raise ConflictError, oid
p, serial = self._storage.load(oid, self._version)
file=StringIO(p)
unpickler=Unpickler(file)
unpickler.persistent_load=self._persistent_load
try: try:
oid=object._p_oid
invalid=self._invalid
if invalid(oid) or invalid(None): raise ConflictError, oid
p, serial = self._storage.load(oid, self._version)
file=StringIO(p)
unpickler=Unpickler(file)
unpickler.persistent_load=self._persistent_load
unpickler.load() unpickler.load()
state = unpickler.load() state = unpickler.load()
if hasattr(object, '__setstate__'):
object.__setstate__(state)
else:
d=object.__dict__
for k,v in state.items(): d[k]=v
object._p_serial=serial
except: except:
t, v =sys.exc_info()[:2] t, v =sys.exc_info()[:2]
LOG('ZODB',ERROR, LOG('ZODB',ERROR, "Couldn't load state for %s" % `oid`,
"Couldn't unnpickle %s" % `oid`,
error=sys.exc_info()) error=sys.exc_info())
raise raise
if hasattr(object, '__setstate__'):
object.__setstate__(state)
else:
d=object.__dict__
for k,v in state.items(): d[k]=v
object._p_serial=serial
def setklassstate(self, object, def setklassstate(self, object,
tt=type(()), ct=type(HelperClass)): tt=type(()), ct=type(HelperClass)):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment