
    ITh)                        % S r SSKrSSKrSSKrSSKrSSKJrJr  SSKJ	r	  SSK
JrJrJrJrJr  SSKJr  SSKJr  0 r\\\4   \S	'   SS
\\   SS4S jjrSS
\\   SS4S jjrSS
\\   S\4S jjrS\S\\   4S jr " S S\5      r\S\\	\4   S\\R<                     4S j5       rSSSSSSS.S\S\S\\   S\S\S\S
\\   S\\   S\\   4S jjr g) u	  Utility helpers to handle progress bars in `huggingface_hub`.

Example:
    1. Use `huggingface_hub.utils.tqdm` as you would use `tqdm.tqdm` or `tqdm.auto.tqdm`.
    2. To disable progress bars, either use `disable_progress_bars()` helper or set the
       environment variable `HF_HUB_DISABLE_PROGRESS_BARS` to 1.
    3. To re-enable progress bars, use `enable_progress_bars()`.
    4. To check whether progress bars are disabled, use `are_progress_bars_disabled()`.

NOTE: Environment variable `HF_HUB_DISABLE_PROGRESS_BARS` has the priority.

Example:
    ```py
    >>> from huggingface_hub.utils import are_progress_bars_disabled, disable_progress_bars, enable_progress_bars, tqdm

    # Disable progress bars globally
    >>> disable_progress_bars()

    # Use as normal `tqdm`
    >>> for _ in tqdm(range(5)):
    ...    pass

    # Still not showing progress bars, as `disable=False` is overwritten to `True`.
    >>> for _ in tqdm(range(5), disable=False):
    ...    pass

    >>> are_progress_bars_disabled()
    True

    # Re-enable progress bars globally
    >>> enable_progress_bars()

    # Progress bar will be shown !
    >>> for _ in tqdm(range(5)):
    ...   pass
    100%|███████████████████████████████████████| 5/5 [00:00<00:00, 117817.53it/s]
    ```

Group-based control:
    ```python
    # Disable progress bars for a specific group
    >>> disable_progress_bars("peft.foo")

    # Check state of different groups
    >>> assert not are_progress_bars_disabled("peft"))
    >>> assert not are_progress_bars_disabled("peft.something")
    >>> assert are_progress_bars_disabled("peft.foo"))
    >>> assert are_progress_bars_disabled("peft.foo.bar"))

    # Enable progress bars for a subgroup
    >>> enable_progress_bars("peft.foo.bar")

    # Check if enabling a subgroup affects the parent group
    >>> assert are_progress_bars_disabled("peft.foo"))
    >>> assert not are_progress_bars_disabled("peft.foo.bar"))

    # No progress bar for `name="peft.foo"`
    >>> for _ in tqdm(range(5), name="peft.foo"):
    ...     pass

    # Progress bar will be shown for `name="peft.foo.bar"`
    >>> for _ in tqdm(range(5), name="peft.foo.bar"):
    ...     pass
    100%|███████████████████████████████████████| 5/5 [00:00<00:00, 117817.53it/s]

    ```
    N)contextmanagernullcontext)Path)ContextManagerDictIteratorOptionalUnion)tqdm   )HF_HUB_DISABLE_PROGRESS_BARSprogress_bar_statesnamereturnc                 "   [         SL a  [        R                  " S5        gU c  [        R	                  5         S[        S'   g[         Vs/ s H  oR                  U  S35      (       d  M  UPM!     nnU H
  n[        U	 M     S[        U '   gs  snf )a  
Disable progress bars either globally or for a specified group.

This function updates the state of progress bars based on a group name.
If no group name is provided, all progress bars are disabled. The operation
respects the `HF_HUB_DISABLE_PROGRESS_BARS` environment variable's setting.

Args:
    name (`str`, *optional*):
        The name of the group for which to disable the progress bars. If None,
        progress bars are disabled globally.

Raises:
    Warning: If the environment variable precludes changes.
FzlCannot disable progress bars: environment variable `HF_HUB_DISABLE_PROGRESS_BARS=0` is set and has priority.N_global.r   warningswarnr   clear
startswithr   keykeys_to_removes      R/var/www/auris/envauris/lib/python3.13/site-packages/huggingface_hub/utils/tqdm.pydisable_progress_barsr   l   s      $u,z	
 	|!!#).I&)<[)<#RVQWWXz@Z#)<[!C#C( "$)D! \   
B*Bc                 "   [         SL a  [        R                  " S5        gU c  [        R	                  5         S[        S'   g[         Vs/ s H  oR                  U  S35      (       d  M  UPM!     nnU H
  n[        U	 M     S[        U '   gs  snf )a  
Enable progress bars either globally or for a specified group.

This function sets the progress bars to enabled for the specified group or globally
if no group is specified. The operation is subject to the `HF_HUB_DISABLE_PROGRESS_BARS`
environment setting.

Args:
    name (`str`, *optional*):
        The name of the group for which to enable the progress bars. If None,
        progress bars are enabled globally.

Raises:
    Warning: If the environment variable precludes changes.
TzkCannot enable progress bars: environment variable `HF_HUB_DISABLE_PROGRESS_BARS=1` is set and has priority.Nr   r   r   r   s      r   enable_progress_barsr       s      $t+y	
 	|!!#)-I&)<[)<#RVQWWXz@Z#)<[!C#C( "$(D! \r   c                    [         SL a  gU c  [        R                  SS5      (       + $ U (       aD  U [        ;   a  [        U    (       + $ SR                  U R	                  S5      SS 5      n U (       a  MD  [        R                  SS5      (       + $ )a  
Check if progress bars are disabled globally or for a specific group.

This function returns whether progress bars are disabled for a given group or globally.
It checks the `HF_HUB_DISABLE_PROGRESS_BARS` environment variable first, then the programmatic
settings.

Args:
    name (`str`, *optional*):
        The group name to check; if None, checks the global setting.

Returns:
    `bool`: True if progress bars are disabled, False otherwise.
TNr   r   )r   r   getjoinsplit)r   s    r   are_progress_bars_disabledr&      s     $t+|&**9d;;;
&&*4000xx

3,- $
 #&&y$777    	log_levelc                 d    U [         R                  :X  a  g[        R                  " S5      S:X  a  gg)z
Determine if tqdm progress bars should be disabled based on logging level and environment settings.

see https://github.com/huggingface/huggingface_hub/pull/2000 and https://github.com/huggingface/huggingface_hub/pull/2698.
TTQDM_POSITIONz-1FN)loggingNOTSETosgetenvr(   s    r   is_tqdm_disabledr0      s*     GNN"	yy!T)r'   c                   D   ^  \ rS rSrSrU 4S jrS\SS4U 4S jjrSrU =r	$ )	r      z
Class to override `disable` argument in case progress bars are globally disabled.

Taken from https://github.com/tqdm/tqdm/issues/619#issuecomment-619639324.
c                 t   > UR                  SS 5      n[        U5      (       a  SUS'   [        TU ]  " U0 UD6  g )Nr   Tdisable)popr&   super__init__)selfargskwargsr   	__class__s       r   r7   tqdm.__init__   s:    zz&$'%d++ $F9$)&)r'   attrr   Nc                 T   >  [         TU ]  U5        g! [         a
    US:w  a  e  gf = f)zBFix for https://github.com/huggingface/huggingface_hub/issues/1603_lockN)r6   __delattr__AttributeError)r8   r=   r;   s     r   r@   tqdm.__delattr__   s3    	G% 	w 	s    '' )
__name__
__module____qualname____firstlineno____doc__r7   strr@   __static_attributes____classcell__)r;   s   @r   r   r      s%    *   r'   r   pathc           	   #     ^^#    [        U [        5      (       a  [        U 5      n U R                  S5       nU R	                  5       R
                  n[        SSUSU R                  S9mUR                  mS
S[        [           S[        4UU4S jjjnX1l        Uv   TR                  5         S	S	S	5        g	! , (       d  f       g	= f7f)u   
Open a file as binary and wrap the `read` method to display a progress bar when it's streamed.

First implemented in `transformers` in 2019 but removed when switched to git-lfs. Used in `huggingface_hub` to show
progress bar when uploading an LFS file to the Hub. See github.com/huggingface/transformers/pull/2078#discussion_r354739608
for implementation details.

Note: currently implementation handles only files stored on disk as it is the most common use case. Could be
      extended to stream any `BinaryIO` object but we might have to debug some corner cases.

Example:
```py
>>> with tqdm_stream_file("config.json") as f:
>>>     requests.put(url, data=f)
config.json: 100%|█████████████████████████| 8.19k/8.19k [00:02<00:00, 3.72kB/s]
```
rbBTr   )unit
unit_scaletotalinitialdescsizer   c                 L   > T" U 5      nTR                  [        U5      5        U$ N)updatelen)rU   dataf_readpbars     r   _inner_read%tqdm_stream_file.<locals>._inner_read  s!    $<DKKD	"Kr'   N)r"   )
isinstancerI   r   openstatst_sizer   r   readr	   intbytesclose)rL   f
total_sizer]   r[   r\   s       @@r   tqdm_stream_fileri      s     & $Dz	4AYY[((

 	hsm 	U 	 	
 

+ 
s   2CA6B5,	C5
C?CrO   T)rR   rS   rP   rQ   r   	_tqdm_barrT   rR   rS   rP   rQ   rj   c                 J    Ub  [        U5      $ [        UUUUU [        US9US9$ )Nr/   )rP   rQ   rR   rS   rT   r4   r   )r   r   r0   )rT   r(   rR   rS   rP   rQ   r   rj   s           r   _get_progress_bar_contextrl     s>     9%%
  95 r'   rW   )!rH   ior+   r-   r   
contextlibr   r   pathlibr   typingr   r   r   r	   r
   	tqdm.autor   old_tqdm	constantsr   r   rI   bool__annotations__r   r    r&   rd   r0   BufferedReaderri   rl   rC   r'   r   <module>rw      sd  BH 
  	  2  B B & 4 (* T#t)_ )* * *@)x} ) )@8Xc] 8d 8:
 
 
8 , *5s+ *9J9J0K * *b   $
  C=	
    3- ~ Dr'   