name : jslexer.cpython-39.pyc
a

�`��@s�dZddlmZddlZddlmZegd�edd�Zdd	d
ddd
�Z	e�
dej�Ze�
dej�Z
e�
d�Ze�
dej�Ze�
d�Ze�
dej�Ze�
d�Zedd�Zde�
dej�fde�
d�fde�
d�fde�
dejejB�fde
fdefde�
d ej�fd!e�
d"ej�fd#e�
d$d%�eeje���fd&e�
d'ej�fd(e�
d)ejejB�fgZd*d+�Zd,d-�Zd.d/�Zd2d0d1�ZdS)3z�
    babel.messages.jslexer
    ~~~~~~~~~~~~~~~~~~~~~~

    A simple JavaScript 1.5 lexer which is used for the JavaScript
    extractor.

    :copyright: (c) 2013-2021 by the Babel Team.
    :license: BSD, see LICENSE for more details.
�)�
namedtupleN)�unichr)+�+�-�*�%z!=z==�<�>z<=z>=�=z+=z-=z*=z%=z<<z>>z>>>z<<=z>>=z>>>=�&z&=�|z|=z&&z||�^z^=�(�)�[�]�{�}�!�--�++�~�,�;�.�:T)�key�reverse���
�
�	)�b�f�n�r�tz[\w$_][\w\d$_]*z[\w$_][\w\d$_.]*[\w\d$_.]z/=?z%/(?:[^/\\]*(?:\\.[^/\\]*)*)/[a-zA-Z]*z(\r\n|\n|\r)z\\z[a-fA-F0-9]{1,4}�Tokenztype value linenoz\s+z<!--.*Zlinecommentz//.*Zmultilinecommentz	/\*.*?\*/�dotted_name�name�numberzb(
        (?:0|[1-9]\d*)
        (\.\d+)?
        ([eE][-+]?\d+)? |
        (0x[a-fA-F0-9]+)
    )Zjsx_tagz(?:</?[^>\s]+|/>)�operatorz(%s)r�template_stringz`(?:[^`\\]*(?:\\.[^`\\]*)*)`�stringzT(
        '(?:[^'\\]*(?:\\.[^'\\]*)*)'  |
        "(?:[^"\\]*(?:\\.[^"\\]*)*)"
    )cCsVg}tD]H\}}|s"|r"d|vr"q|s0|dkr0q|dkrB|s>qd}|�||f�q|S)ze
    Get a tokenization rule list given the passed syntax options.

    Internal to this module.
    �jsxr-r)r*)�_rules�append)r/�dottedr-�rules�
token_type�rule�r6�:/usr/lib/python3.9/site-packages/babel/messages/jslexer.py�	get_rules:sr8cCs|jdkr|jdvS|jdvS)zzA helper function that helps the tokenizer to decide if the current
    token may be followed by a division operator.
    r,)rrrrr)r*r+r.�regexp)�type�value)�tokenr6r6r7�indicates_divisionNs

r=cCs^|r |d|dkr |ddvs(Jd��t�d|dd��}g}|j}d}|�d|�}|dkrb�q6||||��||d}|tvr�|t|�n�|dv�r$t�||d	�}|d
u�r|��}t|�dk�rz|t	t
|d���Wnty�Yn0|d
}qJ|||�|��}qJn||�n||�|d	}qJ|t|�k�rT|||d
��d�
|�S)z�Unquote a string with JavaScript rules.  The string has to start with
    string delimiters (``'``, ``"`` or the back-tick/grave accent (for template strings).)
    r���z"'`z)string provided is not properly delimitedz\1��\ZuU�N����)�line_join_re�subr1�find�escapes�
uni_escape_re�match�group�lenr�int�
ValueError�end�join)r.�result�add�posZ
escape_posZ	next_charZescapedZ
escaped_valuer6r6r7�unquote_stringWsD"�



rUccs�d}d}d}t|�}t|||d�}||kr�|D] \}	}
|
�||�}|dur.q�q.|rft�||�}d}	nt�||�}d}	|dur�|d7}q"|��}|	dur�t|	||�}
t|
�}|
V|tt�	|��7}|�
�}q"dS)z�
    Tokenize JavaScript/JSX source.  Returns a generator of tokens.

    :param jsx: Enable (limited) JSX parsing.
    :param dotted: Read dotted names as single name token.
    :param template_string: Support ES6 template strings
    Frr?)r/r2r-Nr,r9)rMr8rK�division_re�regex_rerLr(r=�line_re�findallrP)�sourcer/r2r-Z
may_dividerT�linenorPr3r4r5rKZtoken_valuer<r6r6r7�tokenize�s2r\)TTT) �__doc__�collectionsr�reZ
babel._compatr�sortedrMZ	operatorsrI�compile�UNICODEZname_reZdotted_name_rerV�DOTALLrWrX�patternrFrJr(�VERBOSE�IrQ�map�escaper0r8r=rUr\r6r6r6r7�<module>sF
�



�
��	8

© 2025 Cubjrnet7