o
    i/                      @  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-2023 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   	locale_id r   K/var/www/edux/Edux_v2/venv/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   
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_globalparent_exceptions_   Nrb)r   r   r   _cache_lockacquirer   get
babel.corer7   splitlenr%   loadcopyr'   openmergepicklerelease)r   r6   datar7   parentpartsr3   fileobjr   r   r   rC   b   s.   

"
rC   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tuplerD   rF   )rM   rO   keyval2val1aliasothersr   r   r   rF      s&   






rF   c                   @  s.   e Zd ZdZdddZdd	d
ZdddZdS )rT   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   rQ   c                 C  s   t || _d S r2   )rU   r[   )selfr[   r   r   r   __init__      zAlias.__init__r   c                 C  s   dt | j d| jdS )N< >)type__name__r[   r]   r   r   r   __repr__   s   zAlias.__repr__rI   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`
        )r[   r   rT   resolverU   )r]   rI   baserV   rY   rZ   r   r   r   rh      s   	





zAlias.resolveN)r[   r\   r   rQ   )r   r   )rI   rg   r   rg   )rd   
__module____qualname____doc__r^   rf   rh   r   r   r   r   rT      s
    

rT   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.
    NrI   %MutableMapping[str | int | None, Any]ri   %Mapping[str | int | None, Any] | Nonec                 C  s   || _ |d u r	|}|| _d S r2   )_datari   )r]   rI   ri   r   r   r   r^      s   
zLocaleDataDict.__init__r   intc                 C  
   t | jS r2   )rB   rp   re   r   r   r   __len__      
zLocaleDataDict.__len__Iterator[str | int | None]c                 C  rr   r2   )iterrp   re   r   r   r   __iter__   rt   zLocaleDataDict.__iter__rV   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)ri   )
rp   r   rT   rh   ri   rU   rD   rF   rS   rm   )r]   rV   origvalrY   rZ   r   r   r   __getitem__   s   




zLocaleDataDict.__getitem__valuerQ   c                 C  s   || j |< d S r2   rp   )r]   rV   r}   r   r   r   __setitem__   r_   zLocaleDataDict.__setitem__c                 C  s   | j |= d S r2   r~   )r]   rV   r   r   r   __delitem__   s   zLocaleDataDict.__delitem__c                 C  s   t | j | jdS ry   )rm   rp   rD   ri   re   r   r   r   rD      s   zLocaleDataDict.copyr2   )rI   rn   ri   ro   )r   rq   )r   ru   )rV   rx   r   r	   )rV   rx   r}   r	   r   rQ   )rV   rx   r   rQ   )r   rm   )rd   rj   rk   rl   r^   rs   rw   r|   r   r   rD   r   r   r   r   rm      s    




rm   )r   r   r   r   )r   r   r   r   )r   r   r   r(   )r   r,   )T)r   r   r6   r(   r   r
   )rM   rN   rO   rP   r   rQ   )(rl   
__future__r   r   rG   rer   	threadingcollectionsr   collections.abcr   r   r   	functoolsr   	itertoolsr   typingr	   r   __annotations__RLockr=   r   r%   dirname__file__r&   compileIr!   r   r'   r)   r   rC   rF   rT   rm   r   r   r   r   <module>   s2    



4!!