2000-10-12 00:16:45 +02:00
|
|
|
"""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
|
1997-05-20 20:03:22 +02:00
|
|
|
|
2001-01-20 20:54:20 +01:00
|
|
|
__all__ = ["pickle","constructor"]
|
|
|
|
|
1997-04-09 19:44:11 +02:00
|
|
|
dispatch_table = {}
|
|
|
|
safe_constructors = {}
|
|
|
|
|
2000-10-12 00:16:45 +02:00
|
|
|
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")
|
1997-04-09 19:44:11 +02:00
|
|
|
dispatch_table[ob_type] = pickle_function
|
|
|
|
|
1997-05-20 20:03:22 +02:00
|
|
|
if constructor_ob is not None:
|
1997-04-09 19:44:11 +02:00
|
|
|
constructor(constructor_ob)
|
|
|
|
|
|
|
|
def constructor(object):
|
2000-10-12 00:16:45 +02:00
|
|
|
if not callable(object):
|
|
|
|
raise TypeError("constructors must be callable")
|
1997-04-09 19:44:11 +02:00
|
|
|
safe_constructors[object] = 1
|
|
|
|
|
1997-05-20 20:03:22 +02:00
|
|
|
# Example: provide pickling support for complex numbers.
|
|
|
|
|
1997-04-09 19:44:11 +02:00
|
|
|
def pickle_complex(c):
|
1997-05-20 20:03:22 +02:00
|
|
|
return complex, (c.real, c.imag)
|
1997-04-09 19:44:11 +02:00
|
|
|
|
1997-05-20 20:03:22 +02:00
|
|
|
pickle(type(1j), pickle_complex, complex)
|