Total Complexity | 9 |
Total Lines | 39 |
Duplicated Lines | 0 % |
Coverage | 95.45% |
Changes | 0 |
1 | 1 | class BaseStructure: |
|
2 | 1 | __slots__ = [] |
|
3 | |||
4 | 1 | def __eq__(self, other): |
|
5 | 1 | if not isinstance(other, self.__class__): |
|
6 | 1 | return NotImplemented |
|
7 | |||
8 | 1 | if self.__class__ != other.__class__: |
|
9 | return False |
||
10 | |||
11 | 1 | return all([ |
|
12 | getattr(self, x) == getattr(other, x) |
||
13 | for x in self.__slots__ |
||
14 | ]) |
||
15 | |||
16 | 1 | def __ne__(self, other): |
|
17 | 1 | return not (self == other) |
|
18 | |||
19 | 1 | def __hash__(self): |
|
20 | 1 | return hash(tuple( |
|
21 | getattr(self, x) for x in self.__slots__ |
||
22 | )) |
||
23 | |||
24 | 1 | def to_primitive(self, context=None): |
|
25 | 1 | fields = ((key, getattr(self, key)) for key in self.__slots__) |
|
|
|||
26 | 1 | return { |
|
27 | key: self._to_primitive(value, context) |
||
28 | for key, value in fields |
||
29 | } |
||
30 | |||
31 | 1 | @staticmethod |
|
32 | 1 | def _to_primitive(instance, context): |
|
33 | 1 | if hasattr(instance, 'to_primitive'): |
|
34 | 1 | return instance.to_primitive(context) |
|
35 | 1 | elif hasattr(instance, 'isoformat'): |
|
36 | 1 | return instance.isoformat() |
|
37 | else: |
||
38 | return instance |
||
39 |