U
    ek.                     @   s  d Z ddlZddlZddlZddlmZmZmZ ddlm	Z	 ddl
mZ ddlmZ ddlmZ eeeef\ZZZZejZedd	 d
D Zedd	 dD ZedZzerddlZneW n ek
r   dZY n2X zej dd W n e!k
r   e   Y nX d6ddZ"G dd de#Z$G dd de#Z%G dd de#Z&G dd de&Z'G dd de&Z(G dd de&Z)dd Z*d d! Z+d"d# Z,d$d% Z-d&d' Z.d(d) Z/d*d+ Z0d,d- Z1d.d/ Z2d0d1 Z3d2d3 Z4d4d5 Z5dS )7z*
General helpers required for `tqdm.std`.
    N)partialpartialmethodwraps)	signatureeast_asian_width)warnproxyc                 c   s   | ]}t |V  qd S NCUR_OS
startswith.0i r   i/mounts/lovelace/software/anaconda3/envs/qiime2-amplicon-2024.2/lib/python3.8/site-packages/tqdm/utils.py	<genexpr>   s     r   )win32cygwinc                 c   s   | ]}t |V  qd S r   r   r   r   r   r   r      s     )aixlinuxdarwinz\x1b\[[;\d]*[A-Za-z]F)stripc                    sN   dkri t fddtj D  |r6tnt fdd}|S )a  
    Override parameter defaults via `os.environ[prefix + param_name]`.
    Maps UPPER_CASE env vars map to lower_case param names.
    camelCase isn't supported (because Windows ignores case).

    Precedence (highest first):

    - call (`foo(a=3)`)
    - environ (`FOO_A=2`)
    - signature (`def foo(a=1)`)

    Parameters
    ----------
    prefix  : str
        Env var prefix, e.g. "FOO_"
    types  : dict, optional
        Fallback mappings `{'param_name': type, ...}` if types cannot be
        inferred from function signature.
        Consider using `types=collections.defaultdict(lambda: ast.literal_eval)`.
    is_method  : bool, optional
        Whether to use `functools.partialmethod`. If (default: False) use `functools.partial`.

    Examples
    --------
    ```
    $ cat foo.py
    from tqdm.utils import envwrap
    @envwrap("FOO_")
    def test(a=1, b=2, c=3):
        print(f"received: a={a}, b={b}, c={c}")

    $ FOO_A=42 FOO_C=1337 python -c 'import foo; foo.test(c=99)'
    received: a=42, b=2, c=99
    ```
    Nc                    s,   i | ]$\}}| r| d   |qS r   )r   lowerr   kv)r   prefixr   r   
<dictcomp>I   s     
  zenvwrap.<locals>.<dictcomp>c              
      s   t | j  fdd D }|D ]} | }|j|jk	rt|jd|jfD ]2}z||| ||< W n tk
rz   Y qNX  qqNq$|jd k	rt|j|| ||< q$z| || ||< W q$ t	k
r   Y q$X q$| f|S )Nc                    s   i | ]\}}| kr||qS r   r   r   paramsr   r   r    O   s       z)envwrap.<locals>.wrap.<locals>.<dictcomp>__args__)
r   
parametersitems
annotationemptygetattr	ExceptiondefaulttypeKeyError)func	overridesr   paramtyp)env_overridesparttypesr!   r   wrapL   s$    

zenvwrap.<locals>.wrap)lenosenvironr%   r   r   )r   r3   	is_methodr4   r   )r1   r   r2   r   r3   r   envwrap"   s    $r9   c                   @   s"   e Zd ZdZdddZdd ZdS )	FormatReplacezN
    >>> a = FormatReplace('something')
    >>> f"{a:5d}"
    'something'
     c                 C   s   || _ d| _d S Nr   )replaceformat_called)selfr=   r   r   r   __init__l   s    zFormatReplace.__init__c                 C   s   |  j d7  _ | jS )N   )r>   r=   )r?   _r   r   r   
__format__p   s    zFormatReplace.__format__N)r;   )__name__
__module____qualname____doc__r@   rC   r   r   r   r   r:   f   s   
r:   c                   @   s@   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d Zdd Z	dS )
Comparablez1Assumes child has self._comparable attr/@propertyc                 C   s   | j |j k S r   _comparabler?   otherr   r   r   __lt__w   s    zComparable.__lt__c                 C   s   | |k p| |kS r   r   rK   r   r   r   __le__z   s    zComparable.__le__c                 C   s   | j |j kS r   rI   rK   r   r   r   __eq__}   s    zComparable.__eq__c                 C   s
   | |k S r   r   rK   r   r   r   __ne__   s    zComparable.__ne__c                 C   s
   | |k S r   r   rK   r   r   r   __gt__   s    zComparable.__gt__c                 C   s
   | |k  S r   r   rK   r   r   r   __ge__   s    zComparable.__ge__N)
rD   rE   rF   rG   rM   rN   rO   rP   rQ   rR   r   r   r   r   rH   u   s   rH   c                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )ObjectWrapperc                 C   s   t | j|S r   )r(   _wrappedr?   namer   r   r   __getattr__   s    zObjectWrapper.__getattr__c                 C   s   t | j||S r   )setattrrT   r?   rV   valuer   r   r   __setattr__   s    zObjectWrapper.__setattr__c                 C   s2   zt | |W S  tk
r,   t| | Y S X dS )z7Actual `self.getattr` rather than self._wrapped.getattrN)objectrW   AttributeErrorr(   rU   r   r   r   wrapper_getattr   s    zObjectWrapper.wrapper_getattrc                 C   s   t | ||S )z7Actual `self.setattr` rather than self._wrapped.setattr)r\   r[   rY   r   r   r   wrapper_setattr   s    zObjectWrapper.wrapper_setattrc                 C   s   |  d| dS )z4
        Thin wrapper around a given object
        rT   N)r_   )r?   wrappedr   r   r   r@      s    zObjectWrapper.__init__N)rD   rE   rF   rW   r[   r^   r_   r@   r   r   r   r   rS      s
   rS   c                       s0   e Zd ZdZ fddZdd Zdd Z  ZS )SimpleTextIOWrapperz
    Change only `.write()` of the wrapped object by encoding the passed
    value and passing the result to the wrapped object's `.write()` method.
    c                    s    t t| | | d| d S )Nencoding)superra   r@   r_   )r?   r`   rb   	__class__r   r   r@      s    zSimpleTextIOWrapper.__init__c                 C   s   | j || dS )zP
        Encode `s` and pass to the wrapped object's `.write()` method.
        rb   )rT   writeencoder^   )r?   sr   r   r   rf      s    zSimpleTextIOWrapper.writec                 C   s   | j t|d|kS NrT   rT   r(   rK   r   r   r   rO      s    zSimpleTextIOWrapper.__eq__)rD   rE   rF   rG   r@   rf   rO   __classcell__r   r   rd   r   ra      s   ra   c                       s4   e Zd ZdZedd Z fddZdd Z  ZS )DisableOnWriteErrorzO
    Disable the given `tqdm_instance` upon `write()` or `flush()` errors.
    c                    s   t  fdd}|S )zV
        Quietly set `tqdm_instance.miniters=inf` if `func` raises `errno=5`.
        c                     s   z | |W S  t k
r^ } z4|jdkr* ztd_W n tk
rL   Y nX W 5 d }~X Y nT tk
r } z6dt|kr| ztd_W n tk
r   Y nX W 5 d }~X Y nX d S )N   infclosed)OSErrorerrnofloatminitersReferenceError
ValueErrorstr)argskwargser-   tqdm_instancer   r   inner   s     
z7DisableOnWriteError.disable_on_exception.<locals>.innerr	   )r{   r-   r|   r   rz   r   disable_on_exception   s    z(DisableOnWriteError.disable_on_exceptionc                    sT   t t| | t|dr0| d| ||j t|drP| d| ||j d S )Nrf   flush)rc   rl   r@   hasattrr_   r}   rf   r~   )r?   r`   r{   rd   r   r   r@      s    
 
 zDisableOnWriteError.__init__c                 C   s   | j t|d|kS ri   rj   rK   r   r   r   rO      s    zDisableOnWriteError.__eq__)	rD   rE   rF   rG   staticmethodr}   r@   rO   rk   r   r   rd   r   rl      s
   
	rl   c                       s   e Zd Zd fdd	Z  ZS )CallbackIOWrapperreadc                    s~   t t| | t|||dkrFt fdd}| d| n4|dkrrt fdd}| d| ntddS )	z{
        Wrap a given `file`-like object's `read()` or `write()` to report
        lengths to the given `callback`
        rf   c                    s    | f||} t |  |S r   r5   )datarw   rx   rescallbackr-   r   r   rf      s    z)CallbackIOWrapper.__init__.<locals>.writer   c                     s   | |} t | |S r   r   )rw   rx   r   r   r   r   r      s    
z(CallbackIOWrapper.__init__.<locals>.readz Can only wrap read/write methodsN)rc   r   r@   r(   r   r_   r,   )r?   r   streammethodrf   r   rd   r   r   r@      s    
zCallbackIOWrapper.__init__)r   )rD   rE   rF   r@   rk   r   r   rd   r   r      s   r   c                 C   sv   zd |  W n^ tk
r$   Y dS  tk
rl   z|  dpHd| kW  Y S  tk
rf   Y Y dS X Y nX dS d S )Nu   █▉Fzutf-ZU8T)rg   UnicodeEncodeErrorr)   r   r   )rb   r   r   r   _is_utf   s    r   c                 C   s(   zt | jW S  tk
r"   Y dS X d S )NF)r   rb   r]   fpr   r   r   _supports_unicode
  s    r   c                 C   s2   t | tr*| D ]}t|dkr dS qdS t| S )N   FT)
isinstancerv   ordr   )rh   cr   r   r   	_is_ascii  s    
r   c                  C   s$   d} t rt} | dkrt} tr t} | S )zy
    Return a function which returns console dimensions (width, height).
    Supported: linux, osx, windows, cygwin.
    N)IS_WIN_screen_shape_windows_screen_shape_tputIS_NIX_screen_shape_linux)Z_screen_shaper   r   r   _screen_shape_wrapper  s    r   c                 C   s   zdd l }ddlm}m} ddlm}m} d}| |kr<d}n| |krHd}|j|}|d}|j	||}	|	r|
d|j\}
}}}}}}}}}}|| || fW S W n tk
r   Y nX d	S )
Nr   )create_string_bufferwindll)stdinstdoutiii   ZhhhhHhhhhhhNN)structctypesr   r   sysr   r   kernel32GetStdHandleGetConsoleScreenBufferInfounpackrawr)   )r   r   r   r   r   r   Z	io_handlehcsbir   Z_bufxZ_bufyZ_curxZ_curyZ_wattrlefttoprightbottomZ_maxxZ_maxyr   r   r   r   )  s*     r   c                     sD   z*ddl ddlm   fdddD W S  tk
r>   Y nX dS )zcygwin xterm (windows)r   N)
check_callc                    s&   g | ]}t  d | d qS )ztput rA   )intsplitr   r   shlexr   r   
<listcomp>F  s   z&_screen_shape_tput.<locals>.<listcomp>)colslinesr   )r   
subprocessr   r)   )rB   r   r   r   r   A  s    r   c                 C   s   z(ddl m } ddlm} ddlm} W n tk
r>   Y dS X z(|d|| |dd d \}}||fW S  tk
r   zd	d
 dD W  Y S  ttfk
r   Y Y dS X Y nX d S )Nr   )array)ioctl)
TIOCGWINSZr   r   z           c                 S   s   g | ]}t tj| d  qS )rA   )r   r6   r7   r   r   r   r   r   [  s     z'_screen_shape_linux.<locals>.<listcomp>)COLUMNSLINES)	r   fcntlr   termiosr   ImportErrorr)   r,   ru   )r   r   r   r   rowsr   r   r   r   r   M  s    
r   c                     s4   t dtdd t   sdS t  fdd} | S )zd
    Return a function which returns console width.
    Supported: linux, osx, windows, cygwin.
    zQUse `_screen_shape_wrapper()(file)[0]` instead of `_environ_cols_wrapper()(file)`r   )
stacklevelNc                    s    | d S r<   r   r   shaper   r   r|   k  s    z$_environ_cols_wrapper.<locals>.inner)r   DeprecationWarningr   r   )r|   r   r   r   _environ_cols_wrapper`  s     r   c                   C   s   t jdkrtd krdS dS )Nntr;   z[A)r6   rV   coloramar   r   r   r   _term_move_upr  s    r   c                 C   s   t dd t| D S )Nc                 s   s"   | ]}t |d krdndV  qdS )FWr   rA   Nr   )r   chr   r   r   r   w  s     z_text_width.<locals>.<genexpr>)sumrv   )rh   r   r   r   _text_widthv  s    r   c                 C   s   t td| S )zp
    Returns the real on-screen length of a string which may contain
    ANSI control codes and wide chars.
    r;   )r   RE_ANSIsub)r   r   r   r   disp_lenz  s    r   c                 C   sp   t | t| kr| d| S tt| }t| |krD| dd } q*|rltt| rl| drd| S | d S | S )zB
    Trim a string which may contain ANSI control characters.
    Nz[0m)r5   r   boolr   searchendswith)r   lengthZansi_presentr   r   r   	disp_trim  s    r   )NF)6rG   r6   rer   	functoolsr   r   r   inspectr   unicodedatar   warningsr   weakrefr
   rangechrrv   _rangeZ_unichZ_unicodeZ_basestringplatformr   anyr   r   compiler   r   r   init	TypeErrorr9   r\   r:   rH   rS   ra   rl   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   <module>   sT   



D+	