Source code for eolib.protocol.pub.esf

# Generated from the eo-protocol XML specification.
#
# This file should not be modified.
# Changes will be lost when code is regenerated.

from __future__ import annotations
from collections.abc import Iterable
from .esf_record import EsfRecord
from ...serialization_error import SerializationError
from ....data.eo_writer import EoWriter
from ....data.eo_reader import EoReader

[docs] class Esf: """ Endless Skill File """ _byte_size: int = 0 _rid: tuple[int, ...] _total_skills_count: int _version: int _skills: tuple[EsfRecord, ...]
[docs] def __init__(self, *, rid: Iterable[int], total_skills_count: int, version: int, skills: Iterable[EsfRecord]): """ Create a new instance of Esf. Args: rid: (Length must be `2`.) (Element value range is 0-64008.) total_skills_count: (Value range is 0-64008.) version: (Value range is 0-252.) skills: """ self._rid = tuple(rid) self._total_skills_count = total_skills_count self._version = version self._skills = tuple(skills)
@property def byte_size(self) -> int: """ The size of the data that this was deserialized from. """ return self._byte_size @property def rid(self) -> tuple[int, ...]: """ The `rid` field. """ return self._rid @property def total_skills_count(self) -> int: """ The `total_skills_count` field. """ return self._total_skills_count @property def version(self) -> int: """ The `version` field. """ return self._version @property def skills(self) -> tuple[EsfRecord, ...]: """ The `skills` field. """ return self._skills
[docs] @staticmethod def serialize(writer: EoWriter, data: "Esf") -> None: """ Serializes an instance of `Esf` to the provided `EoWriter`. Args: writer (EoWriter): The writer that the data will be serialized to. data (Esf): The data to serialize. """ old_string_sanitization_mode: bool = writer.string_sanitization_mode try: writer.add_fixed_string("ESF", 3, False) if data._rid is None: raise SerializationError("rid must be provided.") if len(data._rid) != 2: raise SerializationError(f"Expected length of rid to be exactly 2, got {len(data._rid)}.") for i in range(2): writer.add_short(data._rid[i]) if data._total_skills_count is None: raise SerializationError("total_skills_count must be provided.") writer.add_short(data._total_skills_count) if data._version is None: raise SerializationError("version must be provided.") writer.add_char(data._version) if data._skills is None: raise SerializationError("skills must be provided.") for i in range(len(data._skills)): EsfRecord.serialize(writer, data._skills[i]) finally: writer.string_sanitization_mode = old_string_sanitization_mode
[docs] @staticmethod def deserialize(reader: EoReader) -> "Esf": """ Deserializes an instance of `Esf` from the provided `EoReader`. Args: reader (EoReader): The writer that the data will be serialized to. Returns: The data to serialize. """ old_chunked_reading_mode: bool = reader.chunked_reading_mode try: reader_start_position: int = reader.position reader.get_fixed_string(3, False) rid = [] for i in range(2): rid.append(reader.get_short()) total_skills_count = reader.get_short() version = reader.get_char() skills = [] while reader.remaining > 0: skills.append(EsfRecord.deserialize(reader)) result = Esf(rid=rid, total_skills_count=total_skills_count, version=version, skills=skills) result._byte_size = reader.position - reader_start_position return result finally: reader.chunked_reading_mode = old_chunked_reading_mode
def __repr__(self): return f"Esf(byte_size={repr(self._byte_size)}, rid={repr(self._rid)}, total_skills_count={repr(self._total_skills_count)}, version={repr(self._version)}, skills={repr(self._skills)})"