From 741da90906e004ab3203625cb648dbe509277eb4 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Sat, 28 Dec 2024 07:37:57 +1100 Subject: [PATCH] Added type hints --- Tests/test_image.py | 38 ++++++++++++++++++++++++-------------- src/PIL/GifImagePlugin.py | 2 +- src/PIL/Image.py | 8 ++++++-- src/PIL/JpegImagePlugin.py | 2 +- src/PIL/PngImagePlugin.py | 2 +- src/PIL/WebPImagePlugin.py | 2 +- 6 files changed, 34 insertions(+), 20 deletions(-) diff --git a/Tests/test_image.py b/Tests/test_image.py index ca522cf38..3f28d4e38 100644 --- a/Tests/test_image.py +++ b/Tests/test_image.py @@ -514,21 +514,31 @@ class TestImage: im = hopper() im.save(temp_file, convert_mode=True) - def test_convert_mode(self) -> None: - for mode, modes in [["P", []], ["P", ["P"]]]: # no modes, same mode - im = Image.new(mode, (100, 100)) - assert im._convert_mode(modes) is None + @pytest.mark.parametrize( + "mode, modes", + ( + ("P", ["RGB"]), + ("P", ["L"]), # converting to a non-preferred mode + ("LA", ["P"]), + ("I", ["L"]), + ("RGB", ["L"]), + ("RGB", ["CMYK"]), + ), + ) + def test_convert_mode(self, mode: str, modes: list[str]) -> None: + im = Image.new(mode, (100, 100)) + assert im._convert_mode(modes) is not None - for mode, modes in [ - ["P", ["RGB"]], - ["P", ["L"]], # converting to a non-preferred mode - ["LA", ["P"]], - ["I", ["L"]], - ["RGB", ["L"]], - ["RGB", ["CMYK"]], - ]: - im = Image.new(mode, (100, 100)) - assert im._convert_mode(modes) is not None + @pytest.mark.parametrize( + "mode, modes", + ( + ("P", []), # no mode + ("P", ["P"]), # same mode + ), + ) + def test_convert_mode_noop(self, mode: str, modes: list[str]) -> None: + im = Image.new(mode, (100, 100)) + assert im._convert_mode(modes) is None def test_effect_mandelbrot(self) -> None: # Arrange diff --git a/src/PIL/GifImagePlugin.py b/src/PIL/GifImagePlugin.py index 09f1fb7f4..74d48ea0e 100644 --- a/src/PIL/GifImagePlugin.py +++ b/src/PIL/GifImagePlugin.py @@ -1181,7 +1181,7 @@ def getdata( return fp.data -def _supported_modes(): +def _supported_modes() -> list[str]: return ["RGB", "RGBA", "P", "I", "F", "LA", "L", "1"] diff --git a/src/PIL/Image.py b/src/PIL/Image.py index a5ada6c50..d2eff91d7 100644 --- a/src/PIL/Image.py +++ b/src/PIL/Image.py @@ -2618,9 +2618,11 @@ class Image: if open_fp: fp.close() - def _convert_mode(self, modes, params={}): + def _convert_mode( + self, modes: list[str], params: dict[str, Any] = {} + ) -> Image | None: if not modes or self.mode in modes: - return + return None if self.mode == "P": preferred_modes = [] if "A" in self.im.getpalettemode(): @@ -2674,6 +2676,8 @@ class Image: elif new_mode: return self.convert(new_mode) + return None + def seek(self, frame: int) -> None: """ Seeks to the given frame in this sequence file. If you seek diff --git a/src/PIL/JpegImagePlugin.py b/src/PIL/JpegImagePlugin.py index 97fc5747f..cc02b29c9 100644 --- a/src/PIL/JpegImagePlugin.py +++ b/src/PIL/JpegImagePlugin.py @@ -891,7 +891,7 @@ def jpeg_factory( return im -def _supported_modes(): +def _supported_modes() -> list[str]: return ["RGB", "CMYK", "YCbCr", "RGBX", "L", "1"] diff --git a/src/PIL/PngImagePlugin.py b/src/PIL/PngImagePlugin.py index 244db4545..543a7c170 100644 --- a/src/PIL/PngImagePlugin.py +++ b/src/PIL/PngImagePlugin.py @@ -1532,7 +1532,7 @@ def getchunks(im: Image.Image, **params: Any) -> list[tuple[bytes, bytes, bytes] return chunks -def _supported_modes(): +def _supported_modes() -> list[str]: return ["RGB", "RGBA", "P", "I", "LA", "L", "1"] diff --git a/src/PIL/WebPImagePlugin.py b/src/PIL/WebPImagePlugin.py index 2d951d23e..ee7c9e747 100644 --- a/src/PIL/WebPImagePlugin.py +++ b/src/PIL/WebPImagePlugin.py @@ -314,7 +314,7 @@ def _save(im: Image.Image, fp: IO[bytes], filename: str | bytes) -> None: fp.write(data) -def _supported_modes(): +def _supported_modes() -> list[str]: return [ "RGB", "RGBA",