diff options
author | Guido van Rossum <guido@python.org> | 2003-02-18 22:05:12 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2003-02-18 22:05:12 (GMT) |
commit | c53f009f94a5758530e6f35d8e7ed64c8efcb74b (patch) | |
tree | e39099602182ef895a382a640dc49872619d64b7 /Lib/pickle.py | |
parent | 2b0643a95db568ef9293cc51708d72b121c5d734 (diff) | |
download | cpython-c53f009f94a5758530e6f35d8e7ed64c8efcb74b.zip cpython-c53f009f94a5758530e6f35d8e7ed64c8efcb74b.tar.gz cpython-c53f009f94a5758530e6f35d8e7ed64c8efcb74b.tar.bz2 |
Introducing __reduce_ex__, which is called with a protocol number argument
if it exists in preference over __reduce__. Now Tim can go implement this
in cPickle.c.
Diffstat (limited to 'Lib/pickle.py')
-rw-r--r-- | Lib/pickle.py | 29 |
1 files changed, 14 insertions, 15 deletions
diff --git a/Lib/pickle.py b/Lib/pickle.py index c62bddc..f997f38 100644 --- a/Lib/pickle.py +++ b/Lib/pickle.py @@ -304,21 +304,20 @@ class Pickler: # Check copy_reg.dispatch_table reduce = dispatch_table.get(t) - if not reduce: - # Check for a __reduce__ method. - # Subtle: get the unbound method from the class, so that - # protocol 2 can override the default __reduce__ that all - # classes inherit from object. This has the added - # advantage that the call always has the form reduce(obj) - reduce = getattr(t, "__reduce__", None) - if self.proto >= 2: - # Protocol 2 can do better than the default __reduce__ - if reduce is object.__reduce__: - reduce = _better_reduce - if not reduce: - raise PicklingError("Can't pickle %r object: %r" % - (t.__name__, obj)) - rv = reduce(obj) + if reduce: + rv = reduce(obj) + else: + # Check for a __reduce_ex__ method, fall back to __reduce__ + reduce = getattr(obj, "__reduce_ex__", None) + if reduce: + rv = reduce(self.proto) + else: + reduce = getattr(obj, "__reduce__", None) + if reduce: + rv = reduce() + else: + raise PicklingError("Can't pickle %r object: %r" % + (t.__name__, obj)) # Check for string returned by reduce(), meaning "save as global" if type(rv) is StringType: |