summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAmaury Forgeot d'Arc <amauryfa@gmail.com>2009-01-18 20:27:45 (GMT)
committerAmaury Forgeot d'Arc <amauryfa@gmail.com>2009-01-18 20:27:45 (GMT)
commit945fdd6e6d0e27e1a39da748c12816a9b7a3785c (patch)
tree52b6484f427724cb32cd0b919c38b972ae7707c8
parentafd7eaadb082aac48bc6fbd21b39a371b718f8c0 (diff)
downloadcpython-945fdd6e6d0e27e1a39da748c12816a9b7a3785c.zip
cpython-945fdd6e6d0e27e1a39da748c12816a9b7a3785c.tar.gz
cpython-945fdd6e6d0e27e1a39da748c12816a9b7a3785c.tar.bz2
Merged revisions 68678 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r68678 | amaury.forgeotdarc | 2009-01-17 23:43:50 +0100 (Sat, 17 Jan 2009) | 3 lines follow-up of #3997: since 0xFFFF numbers are not enough to indicate a zip64 format, always try to read the "zip64 end of directory structure". ........
-rw-r--r--Lib/zipfile.py17
1 files changed, 6 insertions, 11 deletions
diff --git a/Lib/zipfile.py b/Lib/zipfile.py
index 933c957..85012d8 100644
--- a/Lib/zipfile.py
+++ b/Lib/zipfile.py
@@ -196,13 +196,9 @@ def _EndRecData(fpin):
# Append a blank comment and record start offset
endrec.append("")
endrec.append(filesize - sizeEndCentDir)
- if endrec[_ECD_OFFSET] == 0xffffffff:
- # the value for the "offset of the start of the central directory"
- # indicates that there is a "Zip64 end of central directory"
- # structure present, so go look for it
- return _EndRecData64(fpin, -sizeEndCentDir, endrec)
- return endrec
+ # Try to read the "Zip64 end of central directory" structure
+ return _EndRecData64(fpin, -sizeEndCentDir, endrec)
# Either this is not a ZIP file, or it is a ZIP file with an archive
# comment. Search the end of the file for the "end of central directory"
@@ -223,11 +219,10 @@ def _EndRecData(fpin):
# Append the archive comment and start offset
endrec.append(comment)
endrec.append(maxCommentStart + start)
- if endrec[_ECD_OFFSET] == 0xffffffff:
- # There is apparently a "Zip64 end of central directory"
- # structure present, so go look for it
- return _EndRecData64(fpin, start - filesize, endrec)
- return endrec
+
+ # Try to read the "Zip64 end of central directory" structure
+ return _EndRecData64(fpin, maxCommentStart + start - filesize,
+ endrec)
# Unable to find a valid end of central directory structure
return