1
0
mirror of synced 2025-01-24 15:12:19 +01:00

classes.py: Refactor how raw_bytes is constructed

This commit is contained in:
Viv 2023-07-31 08:55:12 -04:00
parent d7a817b9ea
commit 5e52e5c71d

View File

@ -336,18 +336,17 @@ class FumenHeader:
@property
def raw_bytes(self) -> bytes:
"""Represent the header values as a string of raw bytes."""
value_list = []
format_string = self.order
format_string, value_list = '', []
for byte_field in fields(self):
value = getattr(self, byte_field.name)
if byte_field.name == "order":
pass
format_string = value + format_string
elif byte_field.name == "b000_b431_timing_windows":
value_list.extend(list(value))
format_string += "f" * len(value)
value_list.extend(list(value))
else:
value_list.append(value)
format_string += "i"
value_list.append(value)
raw_bytes = struct.pack(format_string, *value_list)
assert len(raw_bytes) == 520
return raw_bytes