summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1997-03-14 04:21:10 (GMT)
committerGuido van Rossum <guido@python.org>1997-03-14 04:21:10 (GMT)
commitefd3a3a843b15c05696ba4ac8c23b00d9d9a24ce (patch)
tree5bccfb7667fde613ce9c9962e08e4dd0c3b2e301
parentc69955343c8cad265aeafe93b6afc4f1589fd084 (diff)
downloadcpython-efd3a3a843b15c05696ba4ac8c23b00d9d9a24ce.zip
cpython-efd3a3a843b15c05696ba4ac8c23b00d9d9a24ce.tar.gz
cpython-efd3a3a843b15c05696ba4ac8c23b00d9d9a24ce.tar.bz2
Implement find_class() without exec statement.
-rw-r--r--Lib/pickle.py6
1 files changed, 2 insertions, 4 deletions
diff --git a/Lib/pickle.py b/Lib/pickle.py
index 28f8f90..bfe49f9 100644
--- a/Lib/pickle.py
+++ b/Lib/pickle.py
@@ -465,14 +465,12 @@ class Unpickler:
dispatch[CLASS] = load_class
def find_class(self, module, name):
- env = {}
try:
- exec 'from %s import %s' % (module, name) in env
- except ImportError:
+ klass = getattr(__import__(module), name)
+ except (ImportError, AttributeError):
raise SystemError, \
"Failed to import class %s from module %s" % \
(name, module)
- klass = env[name]
if type(klass) is BuiltinFunctionType:
raise SystemError, \
"Imported object %s from module %s is not a class" % \