mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-27 17:54:32 +03:00
Merge pull request #4240 from radarhere/mpo
Raise a specific exception if no data is found for an MPO frame
This commit is contained in:
commit
a776255a90
BIN
Tests/images/sugarshack_no_data.mpo
Normal file
BIN
Tests/images/sugarshack_no_data.mpo
Normal file
Binary file not shown.
After Width: | Height: | Size: 117 KiB |
|
@ -113,6 +113,13 @@ class TestFileMpo(PillowTestCase):
|
||||||
self.assertEqual(mpinfo[45056], b"0100")
|
self.assertEqual(mpinfo[45056], b"0100")
|
||||||
self.assertEqual(mpinfo[45057], 2)
|
self.assertEqual(mpinfo[45057], 2)
|
||||||
|
|
||||||
|
def test_mp_no_data(self):
|
||||||
|
# This image has been manually hexedited to have the second frame
|
||||||
|
# beyond the end of the file
|
||||||
|
with Image.open("Tests/images/sugarshack_no_data.mpo") as im:
|
||||||
|
with self.assertRaises(ValueError):
|
||||||
|
im.seek(1)
|
||||||
|
|
||||||
def test_mp_attribute(self):
|
def test_mp_attribute(self):
|
||||||
for test_file in test_files:
|
for test_file in test_files:
|
||||||
with Image.open(test_file) as im:
|
with Image.open(test_file) as im:
|
||||||
|
|
|
@ -82,7 +82,10 @@ class MpoImageFile(JpegImagePlugin.JpegImageFile):
|
||||||
self.offset = self.__mpoffsets[frame]
|
self.offset = self.__mpoffsets[frame]
|
||||||
|
|
||||||
self.fp.seek(self.offset + 2) # skip SOI marker
|
self.fp.seek(self.offset + 2) # skip SOI marker
|
||||||
if i16(self.fp.read(2)) == 0xFFE1: # APP1
|
segment = self.fp.read(2)
|
||||||
|
if not segment:
|
||||||
|
raise ValueError("No data found for frame")
|
||||||
|
if i16(segment) == 0xFFE1: # APP1
|
||||||
n = i16(self.fp.read(2)) - 2
|
n = i16(self.fp.read(2)) - 2
|
||||||
self.info["exif"] = ImageFile._safe_read(self.fp, n)
|
self.info["exif"] = ImageFile._safe_read(self.fp, n)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user