golden hour
/lib/python2.7/site-packages/setuptools
⬆️ Go Up
Upload
File/Folder
Size
Actions
__init__.py
4.92 KB
Del
OK
__init__.pyc
6.63 KB
Del
OK
__init__.pyo
6.63 KB
Del
OK
archive_util.py
6.46 KB
Del
OK
archive_util.pyc
6.02 KB
Del
OK
archive_util.pyo
6.02 KB
Del
OK
build_meta.py
4.64 KB
Del
OK
build_meta.pyc
5.88 KB
Del
OK
build_meta.pyo
5.76 KB
Del
OK
command
-
Del
OK
config.py
15.93 KB
Del
OK
config.pyc
16.46 KB
Del
OK
config.pyo
16.46 KB
Del
OK
dep_util.py
935 B
Del
OK
dep_util.pyc
965 B
Del
OK
dep_util.pyo
965 B
Del
OK
depends.py
5.7 KB
Del
OK
depends.pyc
6.37 KB
Del
OK
depends.pyo
6.37 KB
Del
OK
dist.py
39.42 KB
Del
OK
dist.pyc
38.99 KB
Del
OK
dist.pyo
38.93 KB
Del
OK
extension.py
1.69 KB
Del
OK
extension.pyc
2.36 KB
Del
OK
extension.pyo
2.36 KB
Del
OK
extern
-
Del
OK
glob.py
5.08 KB
Del
OK
glob.pyc
4.71 KB
Del
OK
glob.pyo
4.64 KB
Del
OK
launch.py
787 B
Del
OK
launch.pyc
1006 B
Del
OK
launch.pyo
1006 B
Del
OK
lib2to3_ex.py
1.97 KB
Del
OK
lib2to3_ex.pyc
2.93 KB
Del
OK
lib2to3_ex.pyo
2.93 KB
Del
OK
monkey.py
5.66 KB
Del
OK
monkey.pyc
6.2 KB
Del
OK
monkey.pyo
6.2 KB
Del
OK
msvc.py
39.93 KB
Del
OK
msvc.pyc
39.41 KB
Del
OK
msvc.pyo
39.41 KB
Del
OK
namespaces.py
3.12 KB
Del
OK
namespaces.pyc
4.92 KB
Del
OK
namespaces.pyo
4.92 KB
Del
OK
package_index.py
39.03 KB
Del
OK
package_index.pyc
39.08 KB
Del
OK
package_index.pyo
39.08 KB
Del
OK
py26compat.py
679 B
Del
OK
py26compat.pyc
1.27 KB
Del
OK
py26compat.pyo
1.27 KB
Del
OK
py27compat.py
536 B
Del
OK
py27compat.pyc
1.02 KB
Del
OK
py27compat.pyo
1.02 KB
Del
OK
py31compat.py
1.61 KB
Del
OK
py31compat.pyc
2.33 KB
Del
OK
py31compat.pyo
2.33 KB
Del
OK
py33compat.py
998 B
Del
OK
py33compat.pyc
1.47 KB
Del
OK
py33compat.pyo
1.47 KB
Del
OK
py36compat.py
2.82 KB
Del
OK
py36compat.pyc
2.8 KB
Del
OK
py36compat.pyo
2.8 KB
Del
OK
sandbox.py
14.21 KB
Del
OK
sandbox.pyc
18.69 KB
Del
OK
sandbox.pyo
18.69 KB
Del
OK
script (dev).tmpl
201 B
Del
OK
script.tmpl
138 B
Del
OK
site-patch.py
2.25 KB
Del
OK
site-patch.pyc
1.7 KB
Del
OK
site-patch.pyo
1.7 KB
Del
OK
ssl_support.py
8.03 KB
Del
OK
ssl_support.pyc
8.18 KB
Del
OK
ssl_support.pyo
8.18 KB
Del
OK
unicode_utils.py
996 B
Del
OK
unicode_utils.pyc
1.44 KB
Del
OK
unicode_utils.pyo
1.44 KB
Del
OK
version.py
144 B
Del
OK
version.pyc
322 B
Del
OK
version.pyo
322 B
Del
OK
windows_support.py
714 B
Del
OK
windows_support.pyc
1.24 KB
Del
OK
windows_support.pyo
1.24 KB
Del
OK
Edit: archive_util.py
"""Utilities for extracting common archive formats""" import zipfile import tarfile import os import shutil import posixpath import contextlib from distutils.errors import DistutilsError from pkg_resources import ensure_directory, ContextualZipFile __all__ = [ "unpack_archive", "unpack_zipfile", "unpack_tarfile", "default_filter", "UnrecognizedFormat", "extraction_drivers", "unpack_directory", ] class UnrecognizedFormat(DistutilsError): """Couldn't recognize the archive type""" def default_filter(src, dst): """The default progress/filter callback; returns True for all files""" return dst def unpack_archive(filename, extract_dir, progress_filter=default_filter, drivers=None): """Unpack `filename` to `extract_dir`, or raise ``UnrecognizedFormat`` `progress_filter` is a function taking two arguments: a source path internal to the archive ('/'-separated), and a filesystem path where it will be extracted. The callback must return the desired extract path (which may be the same as the one passed in), or else ``None`` to skip that file or directory. The callback can thus be used to report on the progress of the extraction, as well as to filter the items extracted or alter their extraction paths. `drivers`, if supplied, must be a non-empty sequence of functions with the same signature as this function (minus the `drivers` argument), that raise ``UnrecognizedFormat`` if they do not support extracting the designated archive type. The `drivers` are tried in sequence until one is found that does not raise an error, or until all are exhausted (in which case ``UnrecognizedFormat`` is raised). If you do not supply a sequence of drivers, the module's ``extraction_drivers`` constant will be used, which means that ``unpack_zipfile`` and ``unpack_tarfile`` will be tried, in that order. """ for driver in drivers or extraction_drivers: try: driver(filename, extract_dir, progress_filter) except UnrecognizedFormat: continue else: return else: raise UnrecognizedFormat( "Not a recognized archive type: %s" % filename ) def unpack_directory(filename, extract_dir, progress_filter=default_filter): """"Unpack" a directory, using the same interface as for archives Raises ``UnrecognizedFormat`` if `filename` is not a directory """ if not os.path.isdir(filename): raise UnrecognizedFormat("%s is not a directory" % filename) paths = { filename: ('', extract_dir), } for base, dirs, files in os.walk(filename): src, dst = paths[base] for d in dirs: paths[os.path.join(base, d)] = src + d + '/', os.path.join(dst, d) for f in files: target = os.path.join(dst, f) target = progress_filter(src + f, target) if not target: # skip non-files continue ensure_directory(target) f = os.path.join(base, f) shutil.copyfile(f, target) shutil.copystat(f, target) def unpack_zipfile(filename, extract_dir, progress_filter=default_filter): """Unpack zip `filename` to `extract_dir` Raises ``UnrecognizedFormat`` if `filename` is not a zipfile (as determined by ``zipfile.is_zipfile()``). See ``unpack_archive()`` for an explanation of the `progress_filter` argument. """ if not zipfile.is_zipfile(filename): raise UnrecognizedFormat("%s is not a zip file" % (filename,)) with ContextualZipFile(filename) as z: for info in z.infolist(): name = info.filename # don't extract absolute paths or ones with .. in them if name.startswith('/') or '..' in name.split('/'): continue target = os.path.join(extract_dir, *name.split('/')) target = progress_filter(name, target) if not target: continue if name.endswith('/'): # directory ensure_directory(target) else: # file ensure_directory(target) data = z.read(info.filename) with open(target, 'wb') as f: f.write(data) unix_attributes = info.external_attr >> 16 if unix_attributes: os.chmod(target, unix_attributes) def unpack_tarfile(filename, extract_dir, progress_filter=default_filter): """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` Raises ``UnrecognizedFormat`` if `filename` is not a tarfile (as determined by ``tarfile.open()``). See ``unpack_archive()`` for an explanation of the `progress_filter` argument. """ try: tarobj = tarfile.open(filename) except tarfile.TarError: raise UnrecognizedFormat( "%s is not a compressed or uncompressed tar file" % (filename,) ) with contextlib.closing(tarobj): # don't do any chowning! tarobj.chown = lambda *args: None for member in tarobj: name = member.name # don't extract absolute paths or ones with .. in them if not name.startswith('/') and '..' not in name.split('/'): prelim_dst = os.path.join(extract_dir, *name.split('/')) # resolve any links and to extract the link targets as normal # files while member is not None and (member.islnk() or member.issym()): linkpath = member.linkname if member.issym(): base = posixpath.dirname(member.name) linkpath = posixpath.join(base, linkpath) linkpath = posixpath.normpath(linkpath) member = tarobj._getmember(linkpath) if member is not None and (member.isfile() or member.isdir()): final_dst = progress_filter(name, prelim_dst) if final_dst: if final_dst.endswith(os.sep): final_dst = final_dst[:-1] try: # XXX Ugh tarobj._extract_member(member, final_dst) except tarfile.ExtractError: # chown/chmod/mkfifo/mknode/makedev failed pass return True extraction_drivers = unpack_directory, unpack_zipfile, unpack_tarfile
Save