o
    tf/                      @  s"  U d Z ddlm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mZmZ ddlmZ ddlmZ ddlmZ i Zd	ed
< e ZejejedZedejZd,ddZ d-ddZ!d.ddZ"eddd/ddZ#d0d1dd Z$d2d&d'Z%G d(d) d)Z&G d*d+ d+e	jZ'dS )3aG  
    babel.localedata
    ~~~~~~~~~~~~~~~~

    Low-level locale data access.

    :note: The `Locale` class, which uses this module under the hood, provides a
           more convenient interface for accessing the locale data.

    :copyright: (c) 2013-2024 by the Babel Team.
    :license: BSD, see LICENSE for more details.
    )annotationsN)abc)IteratorMappingMutableMapping)	lru_cache)chain)Anydict[str, Any]_cachezlocale-dataz%^(con|prn|aux|nul|com[0-9]|lpt[0-9])$namestrreturn
str | Nonec                 C  sL   | rt | ts	dS |   } ttt gD ]}| | kr#|  S qdS )zNormalize a locale ID by stripping spaces and apply proper casing.

    Returns the normalized locale ID string or `None` if the ID is not
    recognized.
    N)
isinstancer   striplowerr   from_iterabler   locale_identifiers)r   Z	locale_id r   Y/var/www/html/software/conda/envs/catlas/lib/python3.10/site-packages/babel/localedata.pynormalize_locale!   s   r   os.PathLike[str] | strc                 C  sP   t j| } tjdkrtt j| d rtd|  dt j	t
|  dS )z?
    Resolve a locale identifier to a `.dat` path on disk.
    win32r   zName z is invalid on Windows.dat)ospathbasenamesysplatform_windows_reserved_name_rematchsplitext
ValueErrorjoin_dirname)r   r   r   r   resolve_locale_filename/   s    r&   boolc                 C  sB   | rt | ts	dS | tv rdS tjt| }|rdS tt| S )zCheck whether locale data is available for the given locale.

    Returns `True` if it exists, `False` otherwise.

    :param name: the locale identifier string
    FT)	r   r   r   r   r   existsr&   r'   r   )r   Z
file_foundr   r   r   r(   ?   s   r(   )maxsize	list[str]c                   C  s   dd dd t tD D S )a&  Return a list of all locale identifiers for which locale data is
    available.

    This data is cached after the first invocation.
    You can clear the cache by calling `locale_identifiers.cache_clear()`.

    .. versionadded:: 0.8.1

    :return: a list of locale identifiers (strings)
    c                 S  s$   g | ]\}}|d kr|dkr|qS )r   rootr   ).0stem	extensionr   r   r   
<listcomp>Z   s
    z&locale_identifiers.<locals>.<listcomp>c                 s  s    | ]	}t j|V  qd S N)r   r   r"   )r,   filenamer   r   r   	<genexpr>]   s    z%locale_identifiers.<locals>.<genexpr>)r   listdirr%   r   r   r   r   r   N   s   r   Tmerge_inheritedc                 C  s  t j| } t  zst| }|sw| dks|si }n+ddlm} |d| }|s@| 	d}t
|dkr7dnd|dd }t| }t| }t|d	}| dkr_|r_t|t| nt|}W d   n1 snw   Y  |t| < |W t  S t  w )
af  Load the locale data for the given locale.

    The locale data is a dictionary that contains much of the data defined by
    the Common Locale Data Repository (CLDR). This data is stored as a
    collection of pickle files inside the ``babel`` package.

    >>> d = load('en_US')
    >>> d['languages']['sv']
    u'Swedish'

    Note that the results are cached, and subsequent requests for the same
    locale return the same dictionary:

    >>> d1 = load('en_US')
    >>> d2 = load('en_US')
    >>> d1 is d2
    True

    :param name: the locale identifier string (or "root")
    :param merge_inherited: whether the inherited data should be merged into
                            the data of the requested locale
    :raise `IOError`: if no locale data file is found for the given locale
                      identifier, or one of the locales it inherits from
    r+   r   )
get_globalZparent_exceptions_   Nrb)r   r   r   _cache_lockacquirer   getZ
babel.corer5   splitlenr$   loadcopyr&   openmergepicklerelease)r   r4   datar5   parentpartsr1   fileobjr   r   r   r?   b   s.   

"
r?   dict1MutableMapping[Any, Any]dict2Mapping[Any, Any]Nonec                 C  s   |  D ]I\}}|durM| |}t|trG|du ri }t|tr&||f}n#t|tr=|\}}| }t|| ||f}n| }t|| n|}|| |< qdS )an  Merge the data from `dict2` into the `dict1` dictionary, making copies
    of nested dictionaries.

    >>> d = {1: 'foo', 3: 'baz'}
    >>> merge(d, {1: 'Foo', 2: 'Bar'})
    >>> sorted(d.items())
    [(1, 'Foo'), (2, 'Bar'), (3, 'baz')]

    :param dict1: the dictionary to merge into
    :param dict2: the dictionary containing the data that should be merged
    N)itemsr<   r   dictAliastupler@   rB   )rI   rK   keyZval2Zval1aliasothersr   r   r   rB      s&   






rB   c                   @  s.   e Zd ZdZdddZdd	d
ZdddZdS )rP   zRepresentation of an alias in the locale data.

    An alias is a value that refers to some other part of the locale data,
    as specified by the `keys`.
    keystuple[str, ...]r   rM   c                 C  s   t || _d S r0   )rQ   rU   )selfrU   r   r   r   __init__      zAlias.__init__r   c                 C  s   dt | j d| jdS )N< >)type__name__rU   rW   r   r   r   __repr__   s   zAlias.__repr__rE   Mapping[str | int | None, Any]c                 C  sP   |}| j D ]}|| }qt|tr||}|S t|tr&|\}}||}|S )zResolve the alias based on the given data.

        This is done recursively, so if one alias resolves to a second alias,
        that second alias will also be resolved.

        :param data: the locale data
        :type data: `dict`
        )rU   r   rP   resolverQ   )rW   rE   baserR   rS   rT   r   r   r   rb      s   	





zAlias.resolveN)rU   rV   r   rM   )r   r   )rE   ra   r   ra   )r^   
__module____qualname____doc__rX   r`   rb   r   r   r   r   rP      s
    

rP   c                   @  sX   e Zd ZdZddddZdddZd ddZd!ddZd"ddZd#ddZ	d$ddZ
dS )%LocaleDataDictzUDictionary wrapper that automatically resolves aliases to the actual
    values.
    NrE   %MutableMapping[str | int | None, Any]rc   %Mapping[str | int | None, Any] | Nonec                 C  s   || _ |d u r	|}|| _d S r0   )_datarc   )rW   rE   rc   r   r   r   rX      s   
zLocaleDataDict.__init__r   intc                 C  
   t | jS r0   )r>   rj   r_   r   r   r   __len__      
zLocaleDataDict.__len__Iterator[str | int | None]c                 C  rl   r0   )iterrj   r_   r   r   r   __iter__   rn   zLocaleDataDict.__iter__rR   str | int | Noner	   c                 C  s~   | j |  }}t|tr|| j}t|tr(|\}}|| j }t|| t|tr4t	|| jd}||ur=|| j |< |S N)rc   )
rj   r   rP   rb   rc   rQ   r@   rB   rO   rg   )rW   rR   origvalrS   rT   r   r   r   __getitem__   s   




zLocaleDataDict.__getitem__valuerM   c                 C  s   || j |< d S r0   rj   )rW   rR   rw   r   r   r   __setitem__   rY   zLocaleDataDict.__setitem__c                 C  s   | j |= d S r0   rx   )rW   rR   r   r   r   __delitem__   s   zLocaleDataDict.__delitem__c                 C  s   t | j | jdS rs   )rg   rj   r@   rc   r_   r   r   r   r@      s   zLocaleDataDict.copyr0   )rE   rh   rc   ri   )r   rk   )r   ro   )rR   rr   r   r	   )rR   rr   rw   r	   r   rM   )rR   rr   r   rM   )r   rg   )r^   rd   re   rf   rX   rm   rq   rv   ry   rz   r@   r   r   r   r   rg      s    




rg   )r   r   r   r   )r   r   r   r   )r   r   r   r'   )r   r*   )T)r   r   r4   r'   r   r
   )rI   rJ   rK   rL   r   rM   )(rf   
__future__r   r   rC   rer   	threadingcollectionsr   collections.abcr   r   r   	functoolsr   	itertoolsr   typingr	   r   __annotations__RLockr:   r   r$   dirname__file__r%   compileIr    r   r&   r(   r   r?   rB   rP   rg   r   r   r   r   <module>   s2    



4!!