From 109de5d605d08b7954d0af4bc98f0268cb84d289 Mon Sep 17 00:00:00 2001 From: Andrew Murray Date: Thu, 19 Dec 2024 22:21:32 +1100 Subject: [PATCH] Only read until the offset of the next tile --- src/PIL/ImageFile.py | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/src/PIL/ImageFile.py b/src/PIL/ImageFile.py index 9836cd68884..72a195e42fa 100644 --- a/src/PIL/ImageFile.py +++ b/src/PIL/ImageFile.py @@ -263,7 +263,7 @@ def load(self) -> Image.core.PixelAccess | None: self.tile, lambda tile: (tile[0], tile[1], tile[3]) ) ] - for decoder_name, extents, offset, args in self.tile: + for i, (decoder_name, extents, offset, args) in enumerate(self.tile): seek(offset) decoder = Image._getdecoder( self.mode, decoder_name, args, self.decoderconfig @@ -276,8 +276,13 @@ def load(self) -> Image.core.PixelAccess | None: else: b = prefix while True: + read_bytes = self.decodermaxblock + if i + 1 < len(self.tile): + next_offset = self.tile[i + 1].offset + if next_offset > offset: + read_bytes = next_offset - offset try: - s = read(self.decodermaxblock) + s = read(read_bytes) except (IndexError, struct.error) as e: # truncated png/gif if LOAD_TRUNCATED_IMAGES: