From 2db97690fe53bbf822ba7d7986f8323e46b1cd4a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=A9bastien=20Pierre?= Date: Thu, 3 Oct 2024 11:40:54 +1300 Subject: [PATCH] [Update] io: writable supports bytearray --- src/py/extra/utils/io.py | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/py/extra/utils/io.py b/src/py/extra/utils/io.py index 27bc47e..59aabb3 100644 --- a/src/py/extra/utils/io.py +++ b/src/py/extra/utils/io.py @@ -25,8 +25,8 @@ def asBytes(value: str | bytes) -> bytes: raise ValueError(f"Expected bytes or str, got: {value}") -def asWritable(value: str | bytes | TPrimitive) -> bytes: - if isinstance(value, bytes): +def asWritable(value: str | bytes | bytearray | TPrimitive) -> bytes: + if isinstance(value, bytes) or isinstance(value, bytearray): return value elif isinstance(value, str): return value.encode(DEFAULT_ENCODING) @@ -69,6 +69,7 @@ def feed(self, chunk: bytes, start: int = 0) -> tuple[bytes | None, int]: return None, len(chunk) - start else: self.line = self.buffer[:end] + # FIXME: It may not be .clear()? self.buffer.clear() self.offset = 0 return self.line, (end - pos) + self.eolsize