mirror of
https://github.com/python/cpython.git
synced 2025-12-04 08:34:25 +00:00
In the module docstring, clarify that this is used to register pickle
support for extension types, not classes.
pickle(): If the type is a class or if the reduction function is not
callable, raise a TypeError.
constructor(): If the constructor is not callable, raise TypeError.
This (partially) closes SourceForge patch #101859.
This commit is contained in:
parent
06fdd2d9e8
commit
78a6a36964
1 changed files with 15 additions and 3 deletions
|
|
@ -1,15 +1,28 @@
|
||||||
"""Helper to provide extensibility for pickle/cPickle."""
|
"""Helper to provide extensibility for pickle/cPickle.
|
||||||
|
|
||||||
|
This is only useful to add pickle support for extension types defined in
|
||||||
|
C, not for instances of user-defined classes.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from types import ClassType as _ClassType
|
||||||
|
|
||||||
dispatch_table = {}
|
dispatch_table = {}
|
||||||
safe_constructors = {}
|
safe_constructors = {}
|
||||||
|
|
||||||
def pickle(ob_type, pickle_function, constructor_ob = None):
|
def pickle(ob_type, pickle_function, constructor_ob=None):
|
||||||
|
if type(ob_type) is _ClassType:
|
||||||
|
raise TypeError("copy_reg is not intended for use with classes")
|
||||||
|
|
||||||
|
if not callable(pickle_function):
|
||||||
|
raise TypeError("reduction functions must be callable")
|
||||||
dispatch_table[ob_type] = pickle_function
|
dispatch_table[ob_type] = pickle_function
|
||||||
|
|
||||||
if constructor_ob is not None:
|
if constructor_ob is not None:
|
||||||
constructor(constructor_ob)
|
constructor(constructor_ob)
|
||||||
|
|
||||||
def constructor(object):
|
def constructor(object):
|
||||||
|
if not callable(object):
|
||||||
|
raise TypeError("constructors must be callable")
|
||||||
safe_constructors[object] = 1
|
safe_constructors[object] = 1
|
||||||
|
|
||||||
# Example: provide pickling support for complex numbers.
|
# Example: provide pickling support for complex numbers.
|
||||||
|
|
@ -18,4 +31,3 @@ def pickle_complex(c):
|
||||||
return complex, (c.real, c.imag)
|
return complex, (c.real, c.imag)
|
||||||
|
|
||||||
pickle(type(1j), pickle_complex, complex)
|
pickle(type(1j), pickle_complex, complex)
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue