mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
bpo-4833: Add ZipFile.mkdir (GH-32160)
This commit is contained in:
parent
9e88b572fb
commit
050a8f94c6
4 changed files with 101 additions and 17 deletions
|
@ -1772,6 +1772,7 @@ class ZipFile:
|
|||
if zinfo.is_dir():
|
||||
zinfo.compress_size = 0
|
||||
zinfo.CRC = 0
|
||||
self.mkdir(zinfo)
|
||||
else:
|
||||
if compress_type is not None:
|
||||
zinfo.compress_type = compress_type
|
||||
|
@ -1783,23 +1784,6 @@ class ZipFile:
|
|||
else:
|
||||
zinfo._compresslevel = self.compresslevel
|
||||
|
||||
if zinfo.is_dir():
|
||||
with self._lock:
|
||||
if self._seekable:
|
||||
self.fp.seek(self.start_dir)
|
||||
zinfo.header_offset = self.fp.tell() # Start of header bytes
|
||||
if zinfo.compress_type == ZIP_LZMA:
|
||||
# Compressed data includes an end-of-stream (EOS) marker
|
||||
zinfo.flag_bits |= _MASK_COMPRESS_OPTION_1
|
||||
|
||||
self._writecheck(zinfo)
|
||||
self._didModify = True
|
||||
|
||||
self.filelist.append(zinfo)
|
||||
self.NameToInfo[zinfo.filename] = zinfo
|
||||
self.fp.write(zinfo.FileHeader(False))
|
||||
self.start_dir = self.fp.tell()
|
||||
else:
|
||||
with open(filename, "rb") as src, self.open(zinfo, 'w') as dest:
|
||||
shutil.copyfileobj(src, dest, 1024*8)
|
||||
|
||||
|
@ -1844,6 +1828,41 @@ class ZipFile:
|
|||
with self.open(zinfo, mode='w') as dest:
|
||||
dest.write(data)
|
||||
|
||||
def mkdir(self, zinfo_or_directory_name, mode=511):
|
||||
"""Creates a directory inside the zip archive."""
|
||||
if isinstance(zinfo_or_directory_name, ZipInfo):
|
||||
zinfo = zinfo_or_directory_name
|
||||
if not zinfo.is_dir():
|
||||
raise ValueError("The given ZipInfo does not describe a directory")
|
||||
elif isinstance(zinfo_or_directory_name, str):
|
||||
directory_name = zinfo_or_directory_name
|
||||
if not directory_name.endswith("/"):
|
||||
directory_name += "/"
|
||||
zinfo = ZipInfo(directory_name)
|
||||
zinfo.compress_size = 0
|
||||
zinfo.CRC = 0
|
||||
zinfo.external_attr = ((0o40000 | mode) & 0xFFFF) << 16
|
||||
zinfo.file_size = 0
|
||||
zinfo.external_attr |= 0x10
|
||||
else:
|
||||
raise TypeError("Expected type str or ZipInfo")
|
||||
|
||||
with self._lock:
|
||||
if self._seekable:
|
||||
self.fp.seek(self.start_dir)
|
||||
zinfo.header_offset = self.fp.tell() # Start of header bytes
|
||||
if zinfo.compress_type == ZIP_LZMA:
|
||||
# Compressed data includes an end-of-stream (EOS) marker
|
||||
zinfo.flag_bits |= _MASK_COMPRESS_OPTION_1
|
||||
|
||||
self._writecheck(zinfo)
|
||||
self._didModify = True
|
||||
|
||||
self.filelist.append(zinfo)
|
||||
self.NameToInfo[zinfo.filename] = zinfo
|
||||
self.fp.write(zinfo.FileHeader(False))
|
||||
self.start_dir = self.fp.tell()
|
||||
|
||||
def __del__(self):
|
||||
"""Call the "close()" method in case the user forgot."""
|
||||
self.close()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue