From 2ae4871a8f391ffbb267abfed78e38c430afba55 Mon Sep 17 00:00:00 2001 From: Gert van Dijk Date: Sat, 30 Sep 2023 17:41:19 +0200 Subject: [PATCH] mypy: comply with strict mode and resolve all 'type: ignore' cases Tested with mypy 1.5.1 on Python 3.11. This changes `ByteString` into `Union[bytes, bytearray, memoryview]`. See https://github.com/python/cpython/issues/91896. Python 3.11 documentation on `typing.ByteString`: > Deprecated since version 3.9, will be removed in version 3.14: Prefer > typing_extensions.Buffer, or a union like > `bytes | bytearray | memoryview`. Python 3.8 documentation on `typing.ByteString` [2]: > This type represents the types `bytes`, `bytearray`, and `memoryview` > of byte sequences. > > As a shorthand for this type, `bytes` can be used to annotate > arguments of any of the types mentioned above. While at it, also add the return types for special methods which are still optional in mypy strict mode (Ruff's ANN024 rule [3]). [1]: https://docs.python.org/3.11/library/typing.html#typing.ByteString [2]: https://docs.python.org/3.8/library/typing.html#typing.ByteString [3]: https://docs.astral.sh/ruff/rules/missing-return-type-special-method/ --- crc.py | 57 ++++++++++++++++++++++++++++++++++++++++----------------- 1 file changed, 40 insertions(+), 17 deletions(-) diff --git a/crc.py b/crc.py index 9f001cb..c6bb509 100644 --- a/crc.py +++ b/crc.py @@ -11,7 +11,6 @@ from dataclasses import dataclass from typing import ( BinaryIO, - ByteString, Iterable, Iterator, List, @@ -27,7 +26,7 @@ class Byte(numbers.Number): BIT_LENGTH: int = 8 BIT_MASK: int = 0xFF - def __init__(self, value: int = 0x00): + def __init__(self, value: int = 0x00) -> None: self._value = value & Byte.BIT_MASK def __add__(self, other: "Byte") -> "Byte": @@ -62,7 +61,7 @@ def __getitem__(self, index: int) -> int: def __iter__(self) -> Iterator[int]: return (self[i] for i in range(0, len(self))) - def __int__(self): + def __int__(self) -> int: return self.value @property @@ -70,7 +69,7 @@ def value(self) -> int: return self._value & Byte.BIT_MASK @value.setter - def value(self, value) -> None: + def value(self, value: int) -> None: self._value = value & Byte.BIT_MASK def reversed(self) -> "Byte": @@ -91,7 +90,7 @@ class AbstractRegister(metaclass=abc.ABCMeta): """ @abc.abstractmethod - def init(self): + def init(self) -> None: """ Initializes the crc register. """ @@ -164,7 +163,7 @@ class BasicRegister(AbstractRegister): an overwrite for the _process_byte method. """ - def __init__(self, configuration: Configuration): + def __init__(self, configuration: Configuration) -> None: """ Create a new BasicRegister. @@ -174,7 +173,7 @@ def __init__(self, configuration: Configuration): if isinstance(configuration, enum.Enum): configuration = configuration.value self._topbit = 1 << (configuration.width - 1) - self._bitmask = 2**configuration.width - 1 + self._bitmask = int(2**configuration.width - 1) self._config = configuration self._register = configuration.init_value & self._bitmask @@ -259,7 +258,7 @@ def register(self) -> int: return self._register & self._bitmask @register.setter - def register(self, value) -> None: + def register(self, value: int) -> None: self._register = value & self._bitmask @@ -294,7 +293,7 @@ class TableBasedRegister(BasicRegister): register like `Register`. """ - def __init__(self, configuration: Configuration): + def __init__(self, configuration: Configuration) -> None: """ Creates a new table based crc register. @@ -345,7 +344,7 @@ def create_lookup_table(width: int, polynomial: int) -> List[int]: class Calculator: - def __init__(self, configuration: Configuration, optimized: bool = False): + def __init__(self, configuration: Configuration, optimized: bool = False) -> None: """ Creates a new Calculator. @@ -364,7 +363,15 @@ def __init__(self, configuration: Configuration, optimized: bool = False): self._crc_register = klass(configuration) def checksum( - self, data: Union[int, ByteString, BinaryIO, Iterable[ByteString]] + self, + data: Union[ + int, + bytes, + bytearray, + memoryview, + BinaryIO, + Iterable[Union[bytes, bytearray, memoryview]], + ], ) -> int: """ Calculates the checksum for the given data. @@ -382,7 +389,14 @@ def checksum( def verify( self, - data: Union[int, ByteString, BinaryIO, Iterable[ByteString]], + data: Union[ + int, + bytes, + bytearray, + memoryview, + BinaryIO, + Iterable[Union[bytes, bytearray, memoryview]], + ], expected: int, ) -> bool: """ @@ -400,13 +414,22 @@ def verify( def _bytes_generator( - data: Union[int, ByteString, BinaryIO, Iterable[ByteString]] # type: ignore + data: Union[ + int, + bytes, + bytearray, + memoryview, + BinaryIO, + Iterable[Union[bytes, bytearray, memoryview]], + ] ) -> Iterable[bytes]: if isinstance(data, int): yield data.to_bytes(1, "big") - elif isinstance(data, ByteString): # type: ignore - yield bytes(data) # type: ignore - elif isinstance(data, (Iterable, BinaryIO)): # type: ignore + elif isinstance(data, bytes): + yield data + elif isinstance(data, (bytearray, memoryview)): + yield bytes(data) + elif isinstance(data, (Iterable, BinaryIO)): yield from (bytes(e) for e in data) else: raise TypeError(f"Unsupported parameter type: {type(data)}") @@ -598,7 +621,7 @@ def table(args: argparse.Namespace) -> bool: return True -def main(argv: Optional[List[str]] = None): +def main(argv: Optional[List[str]] = None) -> None: parser = _argument_parser() args = parser.parse_args(argv) if "func" in args: