Files
deb-python-kafka/kafka/protocol/pickle.py
2015-12-10 18:37:03 -08:00

30 lines
702 B
Python

from __future__ import absolute_import
try:
import copyreg
except ImportError:
import copy_reg as copyreg # python2
import types
def _pickle_method(method):
func_name = method.im_func.__name__
obj = method.im_self
cls = method.im_class
return _unpickle_method, (func_name, obj, cls)
def _unpickle_method(func_name, obj, cls):
for cls in cls.mro():
try:
func = cls.__dict__[func_name]
except KeyError:
pass
else:
break
return func.__get__(obj, cls)
# https://bytes.com/topic/python/answers/552476-why-cant-you-pickle-instancemethods
copyreg.pickle(types.MethodType, _pickle_method, _unpickle_method)