B
    Ad$                 @  s   U d Z ddlmZ ddlmZ ddlmZmZmZm	Z	 dddhdd	hd
dddhgZ
ddddddZddddddZddddddZddddZe Zded< dS ) z
    babel.messages.checkers
    ~~~~~~~~~~~~~~~~~~~~~~~

    Various routines that help with validation of translations.

    :since: version 0.9

    :copyright: (c) 2013-2023 by the Babel Team.
    :license: BSD, see LICENSE for more details.
    )annotations)Callable)PYTHON_FORMATCatalogMessageTranslationErroriduxXfFgGzCatalog | Noner   None)catalogmessagereturnc             C  sd   |j st|jtstddS | dkr*dS |j}t|ttfsD|f}t|| jkr`td| j dS )z0Verify the number of plurals in the translation.z/Found plural forms for non-pluralizable messageNz*Wrong number of plural forms (expected %d))	Zpluralizable
isinstancestringstrr   listtuplelennum_plurals)r   r   msgstrs r   I/var/www/html/venv/lib/python3.7/site-packages/babel/messages/checkers.pyr      s    r   c             C  sl   d|j krdS |j}t|ttfs(|f}|j}t|ttfsB|f}x$t||D ]\}}|rNt|| qNW dS )z9Verify the format string placeholders in the translation.zpython-formatN)flagsidr   r   r   r   zip_validate_format)r   r   Zmsgidsr   msgidZmsgstrr   r   r   python_format.   s    
r$   r   )formatalternativer   c             C  s>  ddddd}dddddd	}ddd
dd}t || |f\}}t |||f\}}|rl|sl|sltdn||kr|td|rt|t|krtdxtt||D ]4\}	\\}
}\}
}|||std|	d ||f qW nXt|}xN|D ]F\}}||krtd|q|||| std|||| f qW dS )a  Test format string `alternative` against `format`.  `format` can be the
    msgid of a message and `alternative` one of the `msgstr`\s.  The two
    arguments are not interchangeable as `alternative` may contain less
    placeholders if `format` uses named placeholders.

    The behavior of this function is undefined if the string does not use
    string formatting.

    If the string formatting of `alternative` is compatible to `format` the
    function returns `None`, otherwise a `TranslationError` is raised.

    Examples for compatible format strings:

    >>> _validate_format('Hello %s!', 'Hallo %s!')
    >>> _validate_format('Hello %i!', 'Hallo %d!')

    Example for an incompatible format strings:

    >>> _validate_format('Hello %(name)s!', 'Hallo %s!')
    Traceback (most recent call last):
      ...
    TranslationError: the format strings are of different kinds

    This function is used by the `python_format` checker.

    :param format: The original format string
    :param alternative: The alternative format string that should be checked
                        against format
    :raises TranslationError: on formatting errors
    r   zlist[tuple[str, str]])r   r   c             S  sN   g }xDt | D ]6}| \}}}|dkr4|d kr4q||t|f qW |S )N%)r   finditergroupsappendr   )r   resultmatchnamer%   typecharr   r   r   _parse^   s    z _validate_format.<locals>._parsebool)abr   c             S  s2   | |krdS x t D ]}| |kr||krdS qW dS )NTF)_string_format_compatibilities)r1   r2   setr   r   r   _compatibleg   s    
z%_validate_format.<locals>._compatible)resultsr   c             S  sD   d }x6| D ].\}}|d kr$|d k}q
|d k|kr
t dq
W t|S )Nz5format string mixes positional and named placeholders)r   r0   )r6   
positionalr-   _charr   r   r   _check_positionalo   s    
z+_validate_format.<locals>._check_positionalzplaceholders are incompatiblez)the format strings are of different kindsz-positional format placeholders are unbalancedzDincompatible format for placeholder %d: %r and %r are not compatible   zunknown named placeholder zDincompatible format for placeholder %r: %r and %r are not compatibleN)mapr   r   	enumerater!   dict)r%   r&   r/   r5   r9   r1   r2   Za_positionalZb_positionalidx_firstsecondZtype_mapr-   r.   r   r   r   r"   >   s.     	
$

r"   z1list[Callable[[Catalog | None, Message], object]])r   c              C  sd   g } yddl m} W n tk
r(   Y n$X x |dD ]}| |  q6W t| dkr`ttgS | S )Nr   )working_setzbabel.checkers)	pkg_resourcesrB   ImportErroriter_entry_pointsr*   loadr   r   r$   )checkersrB   entry_pointr   r   r   _find_checkers   s    rI   rG   N)__doc__
__future__r   collections.abcr   Zbabel.messages.catalogr   r   r   r   r3   r   r$   r"   rI   rG   __annotations__r   r   r   r   <module>   s   _