diff options
author | Dana Powers <dana.powers@rd.io> | 2015-11-28 19:41:06 +0800 |
---|---|---|
committer | Zack Dever <zack.dever@rd.io> | 2015-12-04 11:25:39 -0800 |
commit | a85e09df89a43de5b659a0fa4ed35bec37c60e04 (patch) | |
tree | a539af32fe502006c1f35b96d8ae36225292f7a5 /kafka/protocol/struct.py | |
parent | e24a4d5f5252d6f97ac586e328b95779ef83f4b6 (diff) | |
download | kafka-python-a85e09df89a43de5b659a0fa4ed35bec37c60e04.tar.gz |
Rework protocol type definition: AbstractType, Schema, Struct
Diffstat (limited to 'kafka/protocol/struct.py')
-rw-r--r-- | kafka/protocol/struct.py | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/kafka/protocol/struct.py b/kafka/protocol/struct.py new file mode 100644 index 0000000..77f5fe7 --- /dev/null +++ b/kafka/protocol/struct.py @@ -0,0 +1,52 @@ +from collections import namedtuple +from io import BytesIO + +from .abstract import AbstractType +from .types import Schema + + +class Struct(AbstractType): + SCHEMA = Schema() + + def __init__(self, *args, **kwargs): + if len(args) == len(self.SCHEMA.fields): + for i, name in enumerate(self.SCHEMA.names): + self.__dict__[name] = args[i] + elif len(args) > 0: + raise ValueError('Args must be empty or mirror schema') + else: + self.__dict__.update(kwargs) + + # overloading encode() to support both class and instance + self.encode = self._encode_self + + @classmethod + def encode(cls, item): + bits = [] + for i, field in enumerate(cls.SCHEMA.fields): + bits.append(field.encode(item[i])) + return b''.join(bits) + + def _encode_self(self): + return self.SCHEMA.encode( + [self.__dict__[name] for name in self.SCHEMA.names] + ) + + @classmethod + def decode(cls, data): + if isinstance(data, bytes): + data = BytesIO(data) + return cls(*[field.decode(data) for field in cls.SCHEMA.fields]) + + def __repr__(self): + key_vals =['%s=%r' % (name, self.__dict__[name]) + for name in self.SCHEMA.names] + return self.__class__.__name__ + '(' + ', '.join(key_vals) + ')' + +""" +class MetaStruct(type): + def __new__(cls, clsname, bases, dct): + nt = namedtuple(clsname, [name for (name, _) in dct['SCHEMA']]) + bases = tuple([Struct, nt] + list(bases)) + return super(MetaStruct, cls).__new__(cls, clsname, bases, dct) +""" |