Commit f6a4756f authored by Jim Fulton's avatar Jim Fulton

Added exception handler around the pickle loading code.

This at least makes errors visible during debugging,
but I need to figure out a better way to handle these.
parent 2e4feb03
...@@ -84,15 +84,15 @@ ...@@ -84,15 +84,15 @@
############################################################################## ##############################################################################
"""Database connection support """Database connection support
$Id: Connection.py,v 1.8 1999/06/11 18:24:02 jim Exp $""" $Id: Connection.py,v 1.9 1999/06/24 19:33:12 jim Exp $"""
__version__='$Revision: 1.8 $'[11:-2] __version__='$Revision: 1.9 $'[11:-2]
from cPickleCache import PickleCache from cPickleCache import PickleCache
from POSException import ConflictError, ExportError from POSException import ConflictError, ExportError
from cStringIO import StringIO from cStringIO import StringIO
from cPickle import Unpickler, Pickler from cPickle import Unpickler, Pickler
from ExtensionClass import Base from ExtensionClass import Base
import Transaction, string, ExportImport import Transaction, string, ExportImport, sys, traceback
ExtensionKlass=Base.__class__ ExtensionKlass=Base.__class__
...@@ -352,8 +352,13 @@ class Connection(ExportImport.ExportImport): ...@@ -352,8 +352,13 @@ class Connection(ExportImport.ExportImport):
file=StringIO(p) file=StringIO(p)
unpickler=Unpickler(file) unpickler=Unpickler(file)
unpickler.persistent_load=self._persistent_load unpickler.persistent_load=self._persistent_load
unpickler.load() try:
state = unpickler.load() unpickler.load()
state = unpickler.load()
except:
t, v =sys.exc_info()[:2]
raise
if hasattr(object, '__setstate__'): if hasattr(object, '__setstate__'):
object.__setstate__(state) object.__setstate__(state)
else: else:
......
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