o
    i)                     @   s   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Zd dlZddlm	Z	 dgZ
dd Zdd ZejZ	 d	d
 ZG dd dZG dd deejZG dd deZdddZG dd dZdS )    N   text_encodingPathc                 C   s   t t| ddS )a2  
    Given a path with elements separated by
    posixpath.sep, generate all parents of that path.

    >>> list(_parents('b/d'))
    ['b']
    >>> list(_parents('/b/d/'))
    ['/b']
    >>> list(_parents('b/d/f/'))
    ['b/d', 'b']
    >>> list(_parents('b'))
    []
    >>> list(_parents(''))
    []
    r   N)	itertoolsislice	_ancestry)path r
   H/var/www/edux/Edux_v2/venv/lib/python3.10/site-packages/zipp/__init__.py_parents   s   r   c                 c   sN    |  tj} | r!| tjkr%| V  t| \} }| r#| tjksdS dS dS dS )aR  
    Given a path with elements separated by
    posixpath.sep, generate all elements of that path

    >>> list(_ancestry('b/d'))
    ['b/d', 'b']
    >>> list(_ancestry('/b/d/'))
    ['/b/d', '/b']
    >>> list(_ancestry('b/d/f/'))
    ['b/d/f', 'b/d', 'b']
    >>> list(_ancestry('b'))
    ['b']
    >>> list(_ancestry(''))
    []
    N)rstrip	posixpathsepsplit)r	   tailr
   r
   r   r   #   s   r   c                 C   s   t t|j| S )zZ
    Return items in minuend not in subtrahend, retaining order
    with O(1) lookup.
    )r   filterfalseset__contains__)minuend
subtrahendr
   r
   r   _difference=   s   r   c                       s4   e Zd ZdZ fddZdd Z fddZ  ZS )InitializedStatez?
    Mix-in to save the initialization state for pickling.
    c                    s"   || _ || _t j|i | d S N)_InitializedState__args_InitializedState__kwargssuper__init__)selfargskwargs	__class__r
   r   r   J   s   zInitializedState.__init__c                 C   s   | j | jfS r   )r   r   r   r
   r
   r   __getstate__O      zInitializedState.__getstate__c                    s   |\}}t  j|i | d S r   )r   r   )r   stater   r    r!   r
   r   __setstate__R   s   zInitializedState.__setstate__)__name__
__module____qualname____doc__r   r$   r'   __classcell__r
   r
   r!   r   r   E   s
    r   c                       sT   e Zd ZdZedd Z fddZdd Zdd	 Z fd
dZ	e
dd Z  ZS )CompleteDirsa8  
    A ZipFile subclass that ensures that implied directories
    are always included in the namelist.

    >>> list(CompleteDirs._implied_dirs(['foo/bar.txt', 'foo/bar/baz.txt']))
    ['foo/', 'foo/bar/']
    >>> list(CompleteDirs._implied_dirs(['foo/bar.txt', 'foo/bar/baz.txt', 'foo/bar/']))
    ['foo/']
    c                 C   s.   t jtt| }dd |D }tt|| S )Nc                 s   s    | ]}|t j V  qd S r   )r   r   ).0pr
   r
   r   	<genexpr>e   s    z-CompleteDirs._implied_dirs.<locals>.<genexpr>)r   chainfrom_iterablemapr   _deduper   )namesparentsas_dirsr
   r
   r   _implied_dirsb   s   zCompleteDirs._implied_dirsc                    s   t   }|t| | S r   )r   namelistlistr8   )r   r5   r!   r
   r   r9   h   s   
zCompleteDirs.namelistc                 C   s   t |  S r   )r   r9   r#   r
   r
   r   	_name_setl   r%   zCompleteDirs._name_setc                 C   s,   |   }|d }||vo||v }|r|S |S )zx
        If the name represents a directory, return that name
        as a directory (with the trailing slash).
        /)r;   )r   namer5   dirname	dir_matchr
   r
   r   resolve_diro   s   zCompleteDirs.resolve_dirc                    sF   zt  |W S  ty"   |dr||  vr tj|d Y S w )z6
        Supplement getinfo for implied dirs.
        r<   )filename)r   getinfoKeyErrorendswithr;   zipfileZipInfo)r   r=   r!   r
   r   rB   y   s   zCompleteDirs.getinfoc                 C   s:   t |tr|S t |tjs| |S d|jvrt} | |_|S )zl
        Given a source (filename or zipfile), return an
        appropriate CompleteDirs subclass.
        r)
isinstancer-   rE   ZipFilemoder"   )clssourcer
   r
   r   make   s   

zCompleteDirs.make)r(   r)   r*   r+   staticmethodr8   r9   r;   r@   rB   classmethodrM   r,   r
   r
   r!   r   r-   W   s    


r-   c                       s,   e Zd ZdZ fddZ fddZ  ZS )
FastLookupzV
    ZipFile subclass to ensure implicit
    dirs exist and are resolved rapidly.
    c                    B   t t | jW  d    S 1 sw   Y  t  | _| jS r   )
contextlibsuppressAttributeError_FastLookup__namesr   r9   r#   r!   r
   r   r9      
    zFastLookup.namelistc                    rQ   r   )rR   rS   rT   _FastLookup__lookupr   r;   r#   r!   r
   r   r;      rV   zFastLookup._name_set)r(   r)   r*   r+   r9   r;   r,   r
   r
   r!   r   rP      s    rP   c                 O   s   t | d||fS )N   r   )encodingr   r    r
   r
   r   _extract_text_encoding   s   rZ   c                   @   s  e Zd ZdZdZd=ddZdd Zdd	 Zd>ddddZe	dd Z
e	dd Ze	dd Ze	dd Ze	dd Zdd Zdd Zdd Zdd  Zd!d" Zd#d$ Zd%d& Zd'd( Zd)d* Zd+d, Zd-d. Zd/d0 Zd1d2 Zd3d4 Zd5d6 Zd7d8 Zd9d: ZeZ e	d;d< Z!dS )?r   uD  
    A pathlib-compatible interface for zip files.

    Consider a zip file with this structure::

        .
        ├── a.txt
        └── b
            ├── c.txt
            └── d
                └── e.txt

    >>> data = io.BytesIO()
    >>> zf = zipfile.ZipFile(data, 'w')
    >>> zf.writestr('a.txt', 'content of a')
    >>> zf.writestr('b/c.txt', 'content of c')
    >>> zf.writestr('b/d/e.txt', 'content of e')
    >>> zf.filename = 'mem/abcde.zip'

    Path accepts the zipfile object itself or a filename

    >>> root = Path(zf)

    From there, several path operations are available.

    Directory iteration (including the zip file itself):

    >>> a, b = root.iterdir()
    >>> a
    Path('mem/abcde.zip', 'a.txt')
    >>> b
    Path('mem/abcde.zip', 'b/')

    name property:

    >>> b.name
    'b'

    join with divide operator:

    >>> c = b / 'c.txt'
    >>> c
    Path('mem/abcde.zip', 'b/c.txt')
    >>> c.name
    'c.txt'

    Read text:

    >>> c.read_text(encoding='utf-8')
    'content of c'

    existence:

    >>> c.exists()
    True
    >>> (b / 'missing.txt').exists()
    False

    Coercion to string:

    >>> import os
    >>> str(c).replace(os.sep, posixpath.sep)
    'mem/abcde.zip/b/c.txt'

    At the root, ``name``, ``filename``, and ``parent``
    resolve to the zipfile. Note these attributes are not
    valid and will raise a ``ValueError`` if the zipfile
    has no filename.

    >>> root.name
    'abcde.zip'
    >>> str(root.filename).replace(os.sep, posixpath.sep)
    'mem/abcde.zip'
    >>> str(root.parent)
    'mem'
    z>{self.__class__.__name__}({self.root.filename!r}, {self.at!r}) c                 C   s   t || _|| _dS )aX  
        Construct a Path from a ZipFile or filename.

        Note: When the source is an existing ZipFile object,
        its type (__class__) will be mutated to a
        specialized type. If the caller wishes to retain the
        original type, the caller should either create a
        separate ZipFile object or pass a filename.
        N)rP   rM   rootat)r   r\   r]   r
   r
   r   r      s   

zPath.__init__c                 C   s(   | j |j urtS | j| jf|j|jfkS )zU
        >>> Path(zipfile.ZipFile(io.BytesIO(), 'w')) == 'foo'
        False
        )r"   NotImplementedr\   r]   )r   otherr
   r
   r   __eq__  s   zPath.__eq__c                 C   s   t | j| jfS r   )hashr\   r]   r#   r
   r
   r   __hash__     zPath.__hash__rG   Npwdc                O   s   |   rt| |d }|  s|dkrt| | jj| j||d}d|v r0|s*|r.td|S t|i |\}}}t	j
||g|R i |S )z
        Open this entry as text or binary following the semantics
        of ``pathlib.Path.open()`` by passing arguments through
        to io.TextIOWrapper().
        r   rG   rd   bz*encoding args invalid for binary operation)is_dirIsADirectoryErrorexistsFileNotFoundErrorr\   openr]   
ValueErrorrZ   ioTextIOWrapper)r   rJ   re   r   r    zip_modestreamrY   r
   r
   r   rk     s   z	Path.openc                 C      t | jjp
| jjS r   )pathlibr   r]   r=   rA   r#   r
   r
   r   r=   -     z	Path.namec                 C   rq   r   )rr   r   r]   suffixrA   r#   r
   r
   r   rt   1  rs   zPath.suffixc                 C   rq   r   )rr   r   r]   suffixesrA   r#   r
   r
   r   ru   5  rs   zPath.suffixesc                 C   rq   r   )rr   r   r]   stemrA   r#   r
   r
   r   rv   9  rs   z	Path.stemc                 C   s   t | jj| jS r   )rr   r   r\   rA   joinpathr]   r#   r
   r
   r   rA   =  rs   zPath.filenamec                 O   sZ   t |i |\}}}| jd|g|R i |}| W  d    S 1 s&w   Y  d S )NrG   )rZ   rk   read)r   r   r    rY   strmr
   r
   r   	read_textA  s   $zPath.read_textc                 C   s6   |  d}| W  d    S 1 sw   Y  d S )Nrb)rk   rx   )r   ry   r
   r
   r   
read_bytesF  s   $zPath.read_bytesc                 C   s   t |jd| jdkS Nr<   )r   r>   r]   r   )r   r	   r
   r
   r   	_is_childJ  s   zPath._is_childc                 C   s   |  | j|S r   )r"   r\   )r   r]   r
   r
   r   _nextM     z
Path._nextc                 C   s   | j  p	| j dS r}   )r]   rD   r#   r
   r
   r   rg   P  s   zPath.is_dirc                 C   s   |   o|   S r   )ri   rg   r#   r
   r
   r   is_fileS     zPath.is_filec                 C   s   | j | j v S r   )r]   r\   r;   r#   r
   r
   r   ri   V  rc   zPath.existsc                 C   s.   |   stdt| j| j }t| j|S )NzCan't listdir a file)rg   rl   r3   r   r\   r9   filterr~   )r   subsr
   r
   r   iterdirY  s   zPath.iterdirc                 C   s   t | j|S r   )rr   r   r]   match)r   path_patternr
   r
   r   r   _  r   z
Path.matchc                 C   s   dS )z]
        Return whether this path is a symlink. Always false (python/cpython#82102).
        Fr
   r#   r
   r
   r   
is_symlinkb  s   zPath.is_symlinkc                 c   s0    |   D ]}|V  | r| E d H  qd S r   )r   rg   _descendants)r   childr
   r
   r   r   h  s   zPath._descendantsc                    s<   |s	t d|tt|j  fdd D S )NzUnacceptable pattern: c                 3   s&    | ]} t |r|V  qd S r   )strrelative_to)r.   r   matchesr   r
   r   r0   s  s    
zPath.glob.<locals>.<genexpr>)rl   recompilefnmatch	translate	fullmatchr   r   patternr
   r   r   globn  s   z	Path.globc                 C   s   |  d| S )Nz**/)r   r   r
   r
   r   rgloby  rc   z
Path.rglobc                 G   s   t t| t|j| S r   )r   relpathr   rw   )r   r_   extrar
   r
   r   r   |  s   zPath.relative_toc                 C   s   t | jj| jS r   )r   joinr\   rA   r]   r#   r
   r
   r   __str__  r   zPath.__str__c                 C   s   | j j| dS )Nr#   )_Path__reprformatr#   r
   r
   r   __repr__  r   zPath.__repr__c                 G   s&   t j| jg|R  }| | j|S r   )r   r   r]   r   r\   r@   )r   r_   nextr
   r
   r   rw     s   zPath.joinpathc                 C   s6   | j s| jjS t| j d}|r|d7 }| |S r}   )r]   rA   parentr   r>   r   r   )r   	parent_atr
   r
   r   r     s   
zPath.parent)r[   )rG   )"r(   r)   r*   r+   r   r   r`   rb   rk   propertyr=   rt   ru   rv   rA   rz   r|   r~   r   rg   r   ri   r   r   r   r   r   r   r   r   r   rw   __truediv__r   r
   r
   r
   r   r      sJ    M
	




r   )rm   r   rE   r   rR   rr   r   r   py310compatr   __all__r   r   dictfromkeysr4   r   r   rI   r-   rP   rZ   r   r
   r
   r
   r   <module>   s(    A
