Merge pull request #7797 from radarhere/tga_palette

This commit is contained in:
Hugo van Kemenade 2024-03-11 17:37:20 +02:00 committed by GitHub
commit d8c8075061
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 15 additions and 2 deletions

BIN
Tests/images/p_8.tga Normal file

Binary file not shown.

View File

@ -7,7 +7,7 @@ from pathlib import Path
import pytest import pytest
from PIL import Image from PIL import Image, UnidentifiedImageError
from .helper import assert_image_equal, assert_image_equal_tofile, hopper from .helper import assert_image_equal, assert_image_equal_tofile, hopper
@ -65,6 +65,11 @@ def test_sanity(mode: str, tmp_path: Path) -> None:
roundtrip(original_im) roundtrip(original_im)
def test_palette_depth_8(tmp_path: Path) -> None:
with pytest.raises(UnidentifiedImageError):
Image.open("Tests/images/p_8.tga")
def test_palette_depth_16(tmp_path: Path) -> None: def test_palette_depth_16(tmp_path: Path) -> None:
with Image.open("Tests/images/p_16.tga") as im: with Image.open("Tests/images/p_16.tga") as im:
assert_image_equal_tofile(im.convert("RGB"), "Tests/images/p_16.png") assert_image_equal_tofile(im.convert("RGB"), "Tests/images/p_16.png")
@ -133,6 +138,11 @@ def test_small_palette(tmp_path: Path) -> None:
assert reloaded.getpalette() == colors assert reloaded.getpalette() == colors
def test_missing_palette() -> None:
with Image.open("Tests/images/dilation4.lut") as im:
assert im.mode == "L"
def test_save_wrong_mode(tmp_path: Path) -> None: def test_save_wrong_mode(tmp_path: Path) -> None:
im = hopper("PA") im = hopper("PA")
out = str(tmp_path / "temp.tga") out = str(tmp_path / "temp.tga")

View File

@ -85,7 +85,7 @@ class TgaImageFile(ImageFile.ImageFile):
elif depth == 16: elif depth == 16:
self._mode = "LA" self._mode = "LA"
elif imagetype in (1, 9): elif imagetype in (1, 9):
self._mode = "P" self._mode = "P" if colormaptype else "L"
elif imagetype in (2, 10): elif imagetype in (2, 10):
self._mode = "RGB" self._mode = "RGB"
if depth == 32: if depth == 32:
@ -128,6 +128,9 @@ class TgaImageFile(ImageFile.ImageFile):
self.palette = ImagePalette.raw( self.palette = ImagePalette.raw(
"BGRA", b"\0" * 4 * start + self.fp.read(4 * size) "BGRA", b"\0" * 4 * start + self.fp.read(4 * size)
) )
else:
msg = "unknown TGA map depth"
raise SyntaxError(msg)
# setup tile descriptor # setup tile descriptor
try: try: