File: //usr/lib/python2.7/site-packages/setuptools/archive_util.pyc
�
�fc           @   s�   d  Z  d d l Z d d l Z d d l Z d d l Z d d l Z d d l Z d d l m Z d d l	 m
 Z
 d d d d d	 d
 d g Z d	 e f d �  �  YZ d
 �  Z
 e
 d d � Z e
 d � Z e
 d � Z e
 d � Z e e e f Z d S(   s/   Utilities for extracting common archive formatsi����N(   t   DistutilsError(   t   ensure_directoryt   unpack_archivet   unpack_zipfilet   unpack_tarfilet   default_filtert   UnrecognizedFormatt   extraction_driverst   unpack_directoryc           B   s   e  Z d  Z RS(   s#   Couldn't recognize the archive type(   t   __name__t
   __module__t   __doc__(    (    (    s;   /usr/lib/python2.7/site-packages/setuptools/archive_util.pyR      s   c         C   s   | S(   s@   The default progress/filter callback; returns True for all files(    (   t   srct   dst(    (    s;   /usr/lib/python2.7/site-packages/setuptools/archive_util.pyR      s    c         C   sZ   xS | p t  D]5 } y | |  | | � Wn t k
 r= q
 q
 Xd Sq
 Wt d |  � � d S(   s�  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.
    Ns!   Not a recognized archive type: %s(   R   R   (   t   filenamet   extract_dirt   progress_filtert   driverst   driver(    (    s;   /usr/lib/python2.7/site-packages/setuptools/archive_util.pyR      s    
c         C   s:  t  j j |  � s% t d |  � � n  i d | f |  6} x� t  j |  � D]� \ } } } | | \ } } xD | D]<