mirror of
https://github.com/python-pillow/Pillow.git
synced 2025-01-13 18:56:17 +03:00
Only close __fp if not fp
This commit is contained in:
parent
41fba67fb0
commit
71b64dcf73
BIN
Tests/images/hopper_unknown_pixel_mode.tif
Normal file
BIN
Tests/images/hopper_unknown_pixel_mode.tif
Normal file
Binary file not shown.
|
@ -220,6 +220,10 @@ class TestFileTiff(PillowTestCase):
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
im.getextrema(), (-3.140936851501465, 3.140684127807617))
|
im.getextrema(), (-3.140936851501465, 3.140684127807617))
|
||||||
|
|
||||||
|
def test_unknown_pixel_mode(self):
|
||||||
|
self.assertRaises(
|
||||||
|
IOError, Image.open, 'Tests/images/hopper_unknown_pixel_mode.tif')
|
||||||
|
|
||||||
def test_n_frames(self):
|
def test_n_frames(self):
|
||||||
for path, n_frames in [
|
for path, n_frames in [
|
||||||
['Tests/images/multipage-lastframe.tif', 1],
|
['Tests/images/multipage-lastframe.tif', 1],
|
||||||
|
|
|
@ -83,6 +83,7 @@ class DcxImageFile(PcxImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -159,6 +159,7 @@ class FliImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -304,6 +304,7 @@ class GifImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -292,6 +292,7 @@ class ImImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -594,10 +594,10 @@ class Image(object):
|
||||||
:ref:`file-handling` for more information.
|
:ref:`file-handling` for more information.
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
self.fp.close()
|
|
||||||
self.fp = None
|
|
||||||
if hasattr(self, "_close__fp"):
|
if hasattr(self, "_close__fp"):
|
||||||
self._close__fp()
|
self._close__fp()
|
||||||
|
self.fp.close()
|
||||||
|
self.fp = None
|
||||||
except Exception as msg:
|
except Exception as msg:
|
||||||
logger.debug("Error closing: %s", msg)
|
logger.debug("Error closing: %s", msg)
|
||||||
|
|
||||||
|
@ -611,12 +611,12 @@ class Image(object):
|
||||||
|
|
||||||
if sys.version_info.major >= 3:
|
if sys.version_info.major >= 3:
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
|
if hasattr(self, "_close__fp"):
|
||||||
|
self._close__fp()
|
||||||
if (hasattr(self, 'fp') and hasattr(self, '_exclusive_fp')
|
if (hasattr(self, 'fp') and hasattr(self, '_exclusive_fp')
|
||||||
and self.fp and self._exclusive_fp):
|
and self.fp and self._exclusive_fp):
|
||||||
self.fp.close()
|
self.fp.close()
|
||||||
self.fp = None
|
self.fp = None
|
||||||
if hasattr(self, "_close__fp"):
|
|
||||||
self._close__fp()
|
|
||||||
|
|
||||||
def _copy(self):
|
def _copy(self):
|
||||||
self.load()
|
self.load()
|
||||||
|
|
|
@ -99,6 +99,7 @@ class MicImageFile(TiffImagePlugin.TiffImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -86,6 +86,7 @@ class MpoImageFile(JpegImagePlugin.JpegImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -195,6 +195,7 @@ class SpiderImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -1361,6 +1361,7 @@ class TiffImageFile(ImageFile.ImageFile):
|
||||||
|
|
||||||
def _close__fp(self):
|
def _close__fp(self):
|
||||||
try:
|
try:
|
||||||
|
if self.__fp != self.fp:
|
||||||
self.__fp.close()
|
self.__fp.close()
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
pass
|
pass
|
||||||
|
|
Loading…
Reference in New Issue
Block a user