diff options
| author | Jason R. Coombs <jaraco@jaraco.com> | 2014-05-17 22:50:41 -0400 |
|---|---|---|
| committer | Jason R. Coombs <jaraco@jaraco.com> | 2014-05-17 22:50:41 -0400 |
| commit | f49559970b7e551f045b59c9530733b1bd1ed0e6 (patch) | |
| tree | a32b1b2f602411b63c0ad013e8e404b8fd262d2a /ez_setup.py | |
| parent | 24d18354d9a2646d5192f959434c1044f7e7fbd4 (diff) | |
| download | python-setuptools-git-f49559970b7e551f045b59c9530733b1bd1ed0e6.tar.gz | |
Update ContextualZipFile to use a single constructor
Diffstat (limited to 'ez_setup.py')
| -rw-r--r-- | ez_setup.py | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/ez_setup.py b/ez_setup.py index 53350e45..df3848a3 100644 --- a/ez_setup.py +++ b/ez_setup.py @@ -80,14 +80,13 @@ class ContextualZipFile(zipfile.ZipFile): def __exit__(self, type, value, traceback): self.close() - @classmethod - def compat(cls, *args, **kwargs): + def __new__(cls, *args, **kwargs): """ Construct a ZipFile or ContextualZipFile as appropriate """ - zf_has_exit = hasattr(zipfile.ZipFile, '__exit__') - class_ = zipfile.ZipFile if zf_has_exit else cls - return class_(*args, **kwargs) + if hasattr(zipfile.ZipFile, '__exit__'): + return zipfile.ZipFile(*args, **kwargs) + return super(ContextualZipFile, cls).__new__(cls, *args, **kwargs) @contextlib.contextmanager @@ -98,7 +97,7 @@ def archive_context(filename): old_wd = os.getcwd() try: os.chdir(tmpdir) - with ContextualZipFile.compat(filename) as archive: + with ContextualZipFile(filename) as archive: archive.extractall() # going in the directory |
