diff options
| author | PJ Eby <distutils-sig@python.org> | 2005-06-15 02:11:09 +0000 | 
|---|---|---|
| committer | PJ Eby <distutils-sig@python.org> | 2005-06-15 02:11:09 +0000 | 
| commit | 0398b84fb305563ce2506c626f87c8a2ff56a82c (patch) | |
| tree | 9b4dce6ae5374efb407d5c735ff7808181fee434 | |
| parent | d4efc98aded77e7d2fa8597412f5a05be8760c60 (diff) | |
| download | python-setuptools-git-0398b84fb305563ce2506c626f87c8a2ff56a82c.tar.gz | |
Enhance unpack_* utilities to allow on-the-fly redirection of where files
are extracted to.
--HG--
branch : setuptools
extra : convert_revision : svn%3A6015fed2-1504-0410-9fe1-9d1591cc4771/sandbox/trunk/setuptools%4041066
| -rwxr-xr-x | setuptools/archive_util.py | 32 | 
1 files changed, 16 insertions, 16 deletions
| diff --git a/setuptools/archive_util.py b/setuptools/archive_util.py index f39d073e..4def0a70 100755 --- a/setuptools/archive_util.py +++ b/setuptools/archive_util.py @@ -13,9 +13,9 @@ class UnrecognizedFormat(RuntimeError):      """Couldn't recognize the archive type"""  def default_filter(src,dst): -    """The default progress/filter callback; returns True for all files""" -     -    return True +    """The default progress/filter callback; returns True for all files"""    +    return dst + @@ -46,10 +46,11 @@ def unpack_archive(filename, extract_dir, progress_filter=default_filter,      `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 a true value, or else that -    file or directory will be skipped.  The callback can thus be used to -    report on the progress of the extraction, as well as to filter the items -    extracted. +    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 @@ -79,7 +80,6 @@ def unpack_archive(filename, extract_dir, progress_filter=default_filter, -  def unpack_zipfile(filename, extract_dir, progress_filter=default_filter):      """Unpack zip `filename` to `extract_dir` @@ -100,8 +100,9 @@ def unpack_zipfile(filename, extract_dir, progress_filter=default_filter):              if name.startswith('/') or '..' in name:                  continue -            target = os.path.join(extract_dir,name) -            if not progress_filter(name,target): +            target = os.path.join(extract_dir, *name.split('/')) +            target = progress_filter(name, target) +            if not target:                  continue              if name.endswith('/'):                  # directory @@ -120,7 +121,6 @@ def unpack_zipfile(filename, extract_dir, progress_filter=default_filter):          z.close() -  def unpack_tarfile(filename, extract_dir, progress_filter=default_filter):      """Unpack tar/tar.gz/tar.bz2 `filename` to `extract_dir` @@ -144,8 +144,11 @@ def unpack_tarfile(filename, extract_dir, progress_filter=default_filter):                  # don't extract absolute paths or ones with .. in them                  if not name.startswith('/') and '..' not in name:                      dst = os.path.join(extract_dir, *name.split('/'))                 -                    if progress_filter(name, dst): -                        tarobj.extract(member,extract_dir) +                    dst = progress_filter(name, dst) +                    if dst: +                        if dst.endswith(os.sep): +                            dst = dst[:-1] +                        tarobj._extract_member(member,dst)  # XXX Ugh          return True      finally:          tarobj.close() @@ -159,6 +162,3 @@ extraction_drivers = unpack_zipfile, unpack_tarfile - - - | 
