mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-26 09:14:27 +03:00
Merge pull request #2141 from wiredfool/tiff_fd
Move libtiff fd duplication to _load_libtiff
This commit is contained in:
commit
2db3f00e92
|
@ -1039,8 +1039,28 @@ class TiffImageFile(ImageFile.ImageFile):
|
||||||
# (self._compression, (extents tuple),
|
# (self._compression, (extents tuple),
|
||||||
# 0, (rawmode, self._compression, fp))
|
# 0, (rawmode, self._compression, fp))
|
||||||
extents = self.tile[0][1]
|
extents = self.tile[0][1]
|
||||||
args = self.tile[0][3] + (self.tag_v2.offset,)
|
args = list(self.tile[0][3]) + [self.tag_v2.offset]
|
||||||
decoder = Image._getdecoder(self.mode, 'libtiff', args,
|
|
||||||
|
# To be nice on memory footprint, if there's a
|
||||||
|
# file descriptor, use that instead of reading
|
||||||
|
# into a string in python.
|
||||||
|
# libtiff closes the file descriptor, so pass in a dup.
|
||||||
|
try:
|
||||||
|
fp = hasattr(self.fp, "fileno") and os.dup(self.fp.fileno())
|
||||||
|
# flush the file descriptor, prevents error on pypy 2.4+
|
||||||
|
# should also eliminate the need for fp.tell for py3
|
||||||
|
# in _seek
|
||||||
|
if hasattr(self.fp, "flush"):
|
||||||
|
self.fp.flush()
|
||||||
|
except IOError:
|
||||||
|
# io.BytesIO have a fileno, but returns an IOError if
|
||||||
|
# it doesn't use a file descriptor.
|
||||||
|
fp = False
|
||||||
|
|
||||||
|
if fp:
|
||||||
|
args[2] = fp
|
||||||
|
|
||||||
|
decoder = Image._getdecoder(self.mode, 'libtiff', tuple(args),
|
||||||
self.decoderconfig)
|
self.decoderconfig)
|
||||||
try:
|
try:
|
||||||
decoder.setimage(self.im, extents)
|
decoder.setimage(self.im, extents)
|
||||||
|
@ -1193,24 +1213,6 @@ class TiffImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
self.use_load_libtiff = True
|
self.use_load_libtiff = True
|
||||||
|
|
||||||
# To be nice on memory footprint, if there's a
|
|
||||||
# file descriptor, use that instead of reading
|
|
||||||
# into a string in python.
|
|
||||||
|
|
||||||
# libtiff closes the file descriptor, so pass in a dup.
|
|
||||||
try:
|
|
||||||
fp = hasattr(self.fp, "fileno") and \
|
|
||||||
os.dup(self.fp.fileno())
|
|
||||||
# flush the file descriptor, prevents error on pypy 2.4+
|
|
||||||
# should also eliminate the need for fp.tell for py3
|
|
||||||
# in _seek
|
|
||||||
if hasattr(self.fp, "flush"):
|
|
||||||
self.fp.flush()
|
|
||||||
except IOError:
|
|
||||||
# io.BytesIO have a fileno, but returns an IOError if
|
|
||||||
# it doesn't use a file descriptor.
|
|
||||||
fp = False
|
|
||||||
|
|
||||||
# libtiff handles the fillmode for us, so 1;IR should
|
# libtiff handles the fillmode for us, so 1;IR should
|
||||||
# actually be 1;I. Including the R double reverses the
|
# actually be 1;I. Including the R double reverses the
|
||||||
# bits, so stripes of the image are reversed. See
|
# bits, so stripes of the image are reversed. See
|
||||||
|
@ -1236,7 +1238,7 @@ class TiffImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
# Offset in the tile tuple is 0, we go from 0,0 to
|
# Offset in the tile tuple is 0, we go from 0,0 to
|
||||||
# w,h, and we only do this once -- eds
|
# w,h, and we only do this once -- eds
|
||||||
a = (rawmode, self._compression, fp)
|
a = (rawmode, self._compression, False)
|
||||||
self.tile.append(
|
self.tile.append(
|
||||||
(self._compression,
|
(self._compression,
|
||||||
(0, 0, w, ysize),
|
(0, 0, w, ysize),
|
||||||
|
|
BIN
Tests/images/g4-multi.tiff
Normal file
BIN
Tests/images/g4-multi.tiff
Normal file
Binary file not shown.
|
@ -505,6 +505,24 @@ class TestFileLibTiff(LibTiffTestCase):
|
||||||
# Should not divide by zero
|
# Should not divide by zero
|
||||||
im.save(outfile)
|
im.save(outfile)
|
||||||
|
|
||||||
|
def test_fd_duplication(self):
|
||||||
|
# https://github.com/python-pillow/Pillow/issues/1651
|
||||||
|
|
||||||
|
tmpfile = self.tempfile("temp.tif")
|
||||||
|
with open(tmpfile, 'wb') as f:
|
||||||
|
with open("Tests/images/g4-multi.tiff", 'rb') as src:
|
||||||
|
f.write(src.read())
|
||||||
|
|
||||||
|
im = Image.open(tmpfile)
|
||||||
|
count = im.n_frames
|
||||||
|
im.close()
|
||||||
|
try:
|
||||||
|
os.remove(tmpfile) # Windows PermissionError here!
|
||||||
|
except:
|
||||||
|
self.fail("Should not get permission error here")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
unittest.main()
|
unittest.main()
|
||||||
|
|
Loading…
Reference in New Issue
Block a user