filename = filename.replace(os.altsep, "/")
return filename
+def _read_local_file_header(fp):
+ fheader = fp.read(sizeFileHeader)
+ if len(fheader) != sizeFileHeader:
+ raise BadZipFile("Truncated file header")
+ fheader = struct.unpack(structFileHeader, fheader)
+ if fheader[_FH_SIGNATURE] != stringFileHeader:
+ raise BadZipFile("Bad magic number for file header")
+ return fheader
+
class ZipInfo:
"""Class with attributes describing each file in the ZIP archive."""
def _validate_local_file_entry(self, fp, offset, end_offset):
fp.seek(offset)
try:
- fheader = self._read_local_file_header(fp)
+ fheader = _read_local_file_header(fp)
except BadZipFile:
return None
return entry_size
- def _read_local_file_header(self, fp):
- fheader = fp.read(sizeFileHeader)
- if len(fheader) != sizeFileHeader:
- raise BadZipFile("Truncated file header")
- fheader = struct.unpack(structFileHeader, fheader)
- if fheader[_FH_SIGNATURE] != stringFileHeader:
- raise BadZipFile("Bad magic number for file header")
- return fheader
-
def _scan_data_descriptor(self, fp, offset, end_offset, zip64):
dd_fmt = '<LLQQ' if zip64 else '<LLLL'
dd_size = struct.calcsize(dd_fmt)
def _calc_local_file_entry_size(self, fp, zinfo):
fp.seek(zinfo.header_offset)
- fheader = self._read_local_file_header(fp)
+ fheader = _read_local_file_header(fp)
if zinfo.flag_bits & _MASK_USE_DATA_DESCRIPTOR:
zip64 = fheader[_FH_UNCOMPRESSED_SIZE] == 0xffffffff
self._fpclose, self._lock, lambda: self._writing)
try:
# Skip the file header:
- fheader = zef_file.read(sizeFileHeader)
- if len(fheader) != sizeFileHeader:
- raise BadZipFile("Truncated file header")
- fheader = struct.unpack(structFileHeader, fheader)
- if fheader[_FH_SIGNATURE] != stringFileHeader:
- raise BadZipFile("Bad magic number for file header")
+ fheader = _read_local_file_header(zef_file)
fname = zef_file.read(fheader[_FH_FILENAME_LENGTH])
if fheader[_FH_EXTRA_FIELD_LENGTH]: