mirror of
https://github.com/python/cpython.git
synced 2025-10-04 06:06:44 +00:00
Merged revisions 76381 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r76381 | lars.gustaebel | 2009-11-18 21:24:54 +0100 (Wed, 18 Nov 2009) | 3 lines Issue #7341: Close the internal file object in the TarFile constructor in case of an error. ........
This commit is contained in:
parent
8920d957d6
commit
7cf2c80467
2 changed files with 27 additions and 18 deletions
|
@ -1565,6 +1565,7 @@ class TarFile(object):
|
||||||
self.inodes = {} # dictionary caching the inodes of
|
self.inodes = {} # dictionary caching the inodes of
|
||||||
# archive members already added
|
# archive members already added
|
||||||
|
|
||||||
|
try:
|
||||||
if self.mode == "r":
|
if self.mode == "r":
|
||||||
self.firstmember = None
|
self.firstmember = None
|
||||||
self.firstmember = self.next()
|
self.firstmember = self.next()
|
||||||
|
@ -1586,6 +1587,11 @@ class TarFile(object):
|
||||||
buf = self.tarinfo.create_pax_global_header(self.pax_headers.copy())
|
buf = self.tarinfo.create_pax_global_header(self.pax_headers.copy())
|
||||||
self.fileobj.write(buf)
|
self.fileobj.write(buf)
|
||||||
self.offset += len(buf)
|
self.offset += len(buf)
|
||||||
|
except:
|
||||||
|
if not self._extfileobj:
|
||||||
|
self.fileobj.close()
|
||||||
|
self.closed = True
|
||||||
|
raise
|
||||||
|
|
||||||
def _getposix(self):
|
def _getposix(self):
|
||||||
return self.format == USTAR_FORMAT
|
return self.format == USTAR_FORMAT
|
||||||
|
|
|
@ -26,6 +26,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #7341: Close the internal file object in the TarFile constructor in
|
||||||
|
case of an error.
|
||||||
|
|
||||||
- Issue #7328: pydoc no longer corrupts sys.path when run with the '-m' switch
|
- Issue #7328: pydoc no longer corrupts sys.path when run with the '-m' switch
|
||||||
|
|
||||||
- Issue #7318: multiprocessing now uses a timeout when it fails to establish
|
- Issue #7318: multiprocessing now uses a timeout when it fails to establish
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue