diff options
| author | Serhiy Storchaka <storchaka@gmail.com> | 2020-01-24 19:55:52 +0200 | 
|---|---|---|
| committer | Ethan Furman <ethan@stoneleaf.us> | 2020-01-24 09:55:52 -0800 | 
| commit | 9017e0bd5e124ae6d2ed94b9e9cacb2e86270980 (patch) | |
| tree | dc0c524bf18c6d0c7bae08d1423512632cc4a56f /Lib/tarfile.py | |
| parent | 656c45ec9a9dc2e94cec199ebde553a6979e0e05 (diff) | |
| download | cpython-git-9017e0bd5e124ae6d2ed94b9e9cacb2e86270980.tar.gz | |
bpo-39430: Fix race condition in lazy imports in tarfile. (GH-18161)
Use `from ... import ...` to ensure module is fully loaded before accessing its attributes.
Diffstat (limited to 'Lib/tarfile.py')
| -rwxr-xr-x | Lib/tarfile.py | 18 | 
1 files changed, 8 insertions, 10 deletions
| diff --git a/Lib/tarfile.py b/Lib/tarfile.py index d0b748cea1..90a2c95b31 100755 --- a/Lib/tarfile.py +++ b/Lib/tarfile.py @@ -1655,13 +1655,12 @@ class TarFile(object):              raise ValueError("mode must be 'r', 'w' or 'x'")          try: -            import gzip -            gzip.GzipFile -        except (ImportError, AttributeError): +            from gzip import GzipFile +        except ImportError:              raise CompressionError("gzip module is not available")          try: -            fileobj = gzip.GzipFile(name, mode + "b", compresslevel, fileobj) +            fileobj = GzipFile(name, mode + "b", compresslevel, fileobj)          except OSError:              if fileobj is not None and mode == 'r':                  raise ReadError("not a gzip file") @@ -1689,12 +1688,11 @@ class TarFile(object):              raise ValueError("mode must be 'r', 'w' or 'x'")          try: -            import bz2 +            from bz2 import BZ2File          except ImportError:              raise CompressionError("bz2 module is not available") -        fileobj = bz2.BZ2File(fileobj or name, mode, -                              compresslevel=compresslevel) +        fileobj = BZ2File(fileobj or name, mode, compresslevel=compresslevel)          try:              t = cls.taropen(name, mode, fileobj, **kwargs) @@ -1718,15 +1716,15 @@ class TarFile(object):              raise ValueError("mode must be 'r', 'w' or 'x'")          try: -            import lzma +            from lzma import LZMAFile, LZMAError          except ImportError:              raise CompressionError("lzma module is not available") -        fileobj = lzma.LZMAFile(fileobj or name, mode, preset=preset) +        fileobj = LZMAFile(fileobj or name, mode, preset=preset)          try:              t = cls.taropen(name, mode, fileobj, **kwargs) -        except (lzma.LZMAError, EOFError): +        except (LZMAError, EOFError):              fileobj.close()              if mode == 'r':                  raise ReadError("not an lzma file") | 
