Issue #22201: Command-line interface of the zipfile module now correctly
extracts ZIP files with directory entries. Patch by Ryan Wilson.
This commit is contained in:
commit
95d5c9d5ff
|
@ -1764,18 +1764,7 @@ def main(args = None):
|
|||
sys.exit(1)
|
||||
|
||||
with ZipFile(args[1], 'r') as zf:
|
||||
out = args[2]
|
||||
for path in zf.namelist():
|
||||
if path.startswith('./'):
|
||||
tgt = os.path.join(out, path[2:])
|
||||
else:
|
||||
tgt = os.path.join(out, path)
|
||||
|
||||
tgtdir = os.path.dirname(tgt)
|
||||
if not os.path.exists(tgtdir):
|
||||
os.makedirs(tgtdir)
|
||||
with open(tgt, 'wb') as fp:
|
||||
fp.write(zf.read(path))
|
||||
zf.extractall(args[2])
|
||||
|
||||
elif args[0] == '-c':
|
||||
if len(args) < 3:
|
||||
|
|
|
@ -935,6 +935,9 @@ Tests
|
|||
Tools/Demos
|
||||
-----------
|
||||
|
||||
- Issue #22201: Command-line interface of the zipfile module now correctly
|
||||
extracts ZIP files with directory entries. Patch by Ryan Wilson.
|
||||
|
||||
- Issue #22120: For functions using an unsigned integer return converter,
|
||||
Argument Clinic now generates a cast to that type for the comparison
|
||||
to -1 in the generated code. (This supresses a compilation warning.)
|
||||
|
|
Loading…
Reference in New Issue