summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Lib/zipfile.py13
-rw-r--r--Misc/NEWS3
2 files changed, 4 insertions, 12 deletions
diff --git a/Lib/zipfile.py b/Lib/zipfile.py
index ee228b1475..c57765753f 100644
--- a/Lib/zipfile.py
+++ b/Lib/zipfile.py
@@ -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:
diff --git a/Misc/NEWS b/Misc/NEWS
index c6bf6b7dc1..18137d03a7 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -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.)