o
    1)hZt                     @   sL  U d Z ddlZddlZddlmZ ddlmZ ddlm	Z	 ddl
mZ ddlmZ dd	lmZ ejr<ddlZdd
lmZ edZejejdf ed< edZedZedejZedejej B Z!edejej B Z"e	dZ#e	dZ$e	dZ%e	dZ&e	dZ'e	dZ(e	dZ)e	dZ*e	dZ+e	dZ,e	dZ-e	dZ.e	dZ/e	d Z0e	d!Z1e	d"Z2e	d#Z3e	d$Z4e	d%Z5e	d&Z6e	d'Z7e	d(Z8e	d)Z9e	d*Z:e	d+Z;e	d,Z<e	d-Z=e	d.Z>e	d/Z?e	d0Z@e	d1ZAe	d2ZBe	d3ZCe	d4ZDe	d5ZEe	d6ZFe	d7ZGe	d8ZHe	d9ZIe	d:ZJe	d;ZKe	d<ZLe	d=ZMe	d>ZNe	d?ZOe	d@ZPe	dAZQe	dBZRe	dCZSi dDe#dEe;dFe'dGe*dHe3dIe2dJe6dKe<dLe.dMe8dNe/dOe9dPe-dQe7dRe)dSe4dTe+e,e0e1e$e(e%e5e&e:dU	ZTdVdW eTU D ZVeWeTeWeVksJ dXedNdYXdZd[ eYeTd\d] d^D  dOZZe[eIeKeJe=eNeOePgZ\e[e=eQeKePgZ]d_e^d`e^fdadbZ_dcddd`e^fdedfZ`dge^d`e^fdhdiZadje^d`ebfdkdlZcdmdnd`ejdeje^e^f  fdodpZeG dqdr drZfG dsdd ddejgZhG dtdu duZiG dvdw dwZjddxdyZkG dzd{ d{elZmG d|d} d}ejgZnG d~d dZodS )zImplements a Jinja / Python combination lexer. The ``Lexer`` class
is used to do some preprocessing. It filters out invalid operators like
the bitshift operators we don't allow in templates. It separates
template code and python code in expressions.
    N)literal_eval)deque)intern   )pattern)TemplateSyntaxError)LRUCache)Environment2   Lexer_lexer_cachez\s+z(\r\n|\r|\n)z7('([^'\\]*(?:\\.[^'\\]*)*)'|"([^"\\]*(?:\\.[^"\\]*)*)")z
    (
        0b(_?[0-1])+ # binary
    |
        0o(_?[0-7])+ # octal
    |
        0x(_?[\da-f])+ # hex
    |
        [1-9](_?\d)* # decimal
    |
        0(_?0)* # decimal zero
    )
    z
    (?<!\.)  # doesn't start with a .
    (\d+_)*\d+  # digits, possibly _ separated
    (
        (\.(\d+_)*\d+)?  # optional fractional part
        e[+\-]?(\d+_)*\d+  # exponent part
    |
        \.(\d+_)*\d+  # required fractional part
    )
    addZassigncoloncommadivdoteqfloordivgtZgteqZlbraceZlbracketZlparenltZlteqmodmulnepipepowrbraceZrbracketZrparen	semicolonsubtilde
whitespacefloatintegernamestringoperatorZblock_beginZ	block_endZvariable_beginZvariable_endZ	raw_beginZraw_endZcomment_beginZcomment_endcommentZlinestatement_beginZlinestatement_endZlinecomment_beginZlinecomment_endZlinecommentdatainitialeof+-/z//*%z**~[](){}z==z!=>)	z>=<z<==.:|,;c                 C   s   i | ]\}}||qS  r=   ).0kvr=   r=   KC:\Users\User\Downloads\Proyecto_IoT\venv\Lib\site-packages\jinja2/lexer.py
<dictcomp>   s    rB   zoperators droppedr:   c                 c   s    | ]}t |V  qd S N)reescaper>   xr=   r=   rA   	<genexpr>       rH   c                 C   s
   t |  S rC   )lenrG   r=   r=   rA   <lambda>   s   
 rL   )key
token_typereturnc                 C   sL   | t v rt |  S tdtdtdtdtdtdtdtdt	dt
d	td
tdi| | S )Nzbegin of commentzend of commentr%   zbegin of statement blockzend of statement blockzbegin of print statementzend of print statementzbegin of line statementzend of line statementztemplate data / textzend of template)reverse_operatorsTOKEN_COMMENT_BEGINTOKEN_COMMENT_ENDTOKEN_COMMENTTOKEN_LINECOMMENTTOKEN_BLOCK_BEGINTOKEN_BLOCK_ENDTOKEN_VARIABLE_BEGINTOKEN_VARIABLE_ENDTOKEN_LINESTATEMENT_BEGINTOKEN_LINESTATEMENT_END
TOKEN_DATA	TOKEN_EOFget)rN   r=   r=   rA   _describe_token_type   s"   r^   tokenTokenc                 C   s   | j tkr| jS t| j S )z#Returns a description of the token.)type
TOKEN_NAMEvaluer^   )r_   r=   r=   rA   describe_token   s   

rd   exprc                 C   s8   d| v r|  dd\}}|tkr|S t|S | }t|S )z0Like `describe_token` but for token expressions.r9   r   )splitrb   r^   )re   ra   rc   r=   r=   rA   describe_token_expr   s   rg   rc   c                 C   s   t t| S )zsCount the number of newline characters in the string.  This is
    useful for extensions that filter a stream.
    )rJ   
newline_refindall)rc   r=   r=   rA   count_newlines      rj   environmentr	   c                 C   s   t j}t| jt|| jft| jt|| jft| jt|| jfg}| j	dur8|
t| j	td|| j	 f | jdurM|
t| jtd|| j f dd t|ddD S )zACompiles all the rules from the environment into a list of rules.Nz	^[ \t\v]*z(?:^|(?<=\S))[^\S\r\n]*c                 S   s   g | ]}|d d qS )r   Nr=   rF   r=   r=   rA   
<listcomp>   s    z!compile_rules.<locals>.<listcomp>T)reverse)rD   rE   rJ   comment_start_stringrQ   block_start_stringrU   variable_start_stringrW   line_statement_prefixappendrY   line_comment_prefixTOKEN_LINECOMMENT_BEGINsorted)rl   erulesr=   r=   rA   compile_rules   s:   

ry   c                   @   sL   e Zd ZdZefdedeje ddfddZde	d	ej
e dd
fddZdS )FailurezjClass that raises a `TemplateSyntaxError` if called.
    Used by the `Lexer` to specify known errors.
    messageclsrO   Nc                 C   s   || _ || _d S rC   )r{   error_class)selfr{   r|   r=   r=   rA   __init__  s   
zFailure.__init__linenofilenamezte.NoReturnc                 C   s   |  | j||rC   )r}   r{   )r~   r   r   r=   r=   rA   __call__	  s   zFailure.__call__)__name__
__module____qualname____doc__r   strtTyper   intOptionalr   r=   r=   r=   rA   rz      s    
 rz   c                   @   sX   e Zd ZU eed< eed< eed< defddZdedefdd	Zd
edefddZ	dS )r`   r   ra   rc   rO   c                 C      t | S rC   )rd   r~   r=   r=   rA   __str__     zToken.__str__re   c                 C   s2   | j |krdS d|v r|dd| j | jgkS dS )zTest a token against a token expression.  This can either be a
        token type or ``'token_type:token_value'``.  This can only test
        against string values and types.
        Tr9   r   F)ra   rf   rc   r~   re   r=   r=   rA   test  s
   
z
Token.testiterablec                    s   t  fdd|D S )z(Test against multiple token expressions.c                 3   s    | ]}  |V  qd S rC   )r   )r>   re   r   r=   rA   rH   &  rI   z!Token.test_any.<locals>.<genexpr>)any)r~   r   r=   r   rA   test_any$  s   zToken.test_anyN)
r   r   r   r   __annotations__r   r   boolr   r   r=   r=   r=   rA   r`     s   
 c                   @   s2   e Zd ZdZdddZddd	Zdefd
dZdS )TokenStreamIteratorz`The iterator for tokenstreams.  Iterate over the stream
    until the eof token is reached.
    streamTokenStreamrO   Nc                 C   s
   || _ d S rC   )r   )r~   r   r=   r=   rA   r   .  s   
zTokenStreamIterator.__init__c                 C   s   | S rC   r=   r   r=   r=   rA   __iter__1  s   zTokenStreamIterator.__iter__c                 C   s.   | j j}|jtu r| j   tt| j  |S rC   )r   currentra   r\   closeStopIterationnextr~   r_   r=   r=   rA   __next__4  s   


zTokenStreamIterator.__next__)r   r   rO   N)rO   r   )r   r   r   r   r   r   r`   r   r=   r=   r=   rA   r   )  s
    

r   c                   @   s   e Zd ZdZdeje deje deje fddZ	de
fdd	Zdefd
dZedefddZdeddfddZdefddZd#deddfddZdedeje fddZdedefddZdefddZd$dd Zdedefd!d"ZdS )%r   zA token stream is an iterable that yields :class:`Token`\s.  The
    parser however does not iterate over it but calls :meth:`next` to go
    one token ahead.  The current active token is stored as :attr:`current`.
    	generatorr"   r   c                 C   s>   t || _t | _|| _|| _d| _tdtd| _	t
|  d S )NFr    )iter_iterr   _pushedr"   r   closedr`   TOKEN_INITIALr   r   )r~   r   r"   r   r=   r=   rA   r   E  s   
zTokenStream.__init__rO   c                 C   r   rC   )r   r   r=   r=   rA   r   S  r   zTokenStream.__iter__c                 C   s   t | jp
| jjtuS rC   )r   r   r   ra   r\   r   r=   r=   rA   __bool__V  s   zTokenStream.__bool__c                 C   s   |  S )z Are we at the end of the stream?r=   r   r=   r=   rA   eosY  s   zTokenStream.eosr_   Nc                 C   s   | j | dS )z Push a token back to the stream.N)r   rs   r   r=   r=   rA   push^  s   zTokenStream.pushc                 C   s"   t | }| j}| | || _|S )zLook at the next token.)r   r   r   )r~   Z	old_tokenresultr=   r=   rA   lookb  s
   
zTokenStream.lookr   nc                 C   s   t |D ]}t|  qdS )zGot n tokens ahead.N)ranger   )r~   r   _r=   r=   rA   skipj  s   
zTokenStream.skipre   c                 C   s   | j |r
t| S dS )zqPerform the token test and return the token if it matched.
        Otherwise the return value is `None`.
        N)r   r   r   r   r=   r=   rA   next_ifo  s   zTokenStream.next_ifc                 C   s   |  |duS )z8Like :meth:`next_if` but only returns `True` or `False`.N)r   r   r=   r=   rA   skip_ifx  s   zTokenStream.skip_ifc                 C   s\   | j }| jr| j | _ |S | j jtur,z	t| j| _ W |S  ty+   |   Y |S w |S )z|Go one token ahead and return the old one.

        Use the built-in :func:`next` instead of calling this directly.
        )	r   r   popleftra   r\   r   r   r   r   )r~   rvr=   r=   rA   r   |  s   
zTokenStream.__next__c                 C   s&   t | jjtd| _td| _d| _dS )zClose the stream.r   r=   TN)r`   r   r   r\   r   r   r   r   r=   r=   rA   r     s   

zTokenStream.closec                 C   sn   | j |s3t|}| j jtu rtd|d| j j| j| jtd|dt	| j | j j| j| jt
| S )z}Expect a given token type and return it.  This accepts the same
        argument as :meth:`jinja2.lexer.Token.test`.
        z%unexpected end of template, expected r8   zexpected token z, got )r   r   rg   ra   r\   r   r   r"   r   rd   r   r   r=   r=   rA   expect  s    
zTokenStream.expect)r   )rO   N)r   r   r   r   r   Iterabler`   r   r   r   r   r   r   r   propertyr   r   r   r   r   r   r   r   r   r   r=   r=   r=   rA   r   ?  s*    
	
r   c                 C   sZ   | j | j| j| j| j| j| j| j| j| j	| j
| jf}t|}|du r+t|  t|< }|S )z(Return a lexer which is probably cached.N)rp   block_end_stringrq   variable_end_stringro   comment_end_stringrr   rt   trim_blockslstrip_blocksnewline_sequencekeep_trailing_newliner   r]   r   )rl   rM   lexerr=   r=   rA   	get_lexer  s"   
r   c                       s$   e Zd ZdZdZ fddZ  ZS )OptionalLStripzWA special tuple for marking a point in the state that can have
    lstrip applied.
    r=   c                    s   t  | |S rC   )super__new__)r|   memberskwargs	__class__r=   rA   r     s   zOptionalLStrip.__new__)r   r   r   r   	__slots__r   __classcell__r=   r=   r   rA   r     s    r   c                   @   sN   e Zd ZU eje ed< ejeejedf eje	 f ed< ej
e ed< dS )_Ruler   .tokenscommandN)r   r   r   r   Patternr   r   UnionTuplerz   r   r=   r=   r=   rA   r     s   
 $r   c                   @   s   e Zd ZdZdddZdedefd	d
Z			ddedeje deje deje de	f
ddZ
		ddejejeeef  deje deje deje fddZ		ddedeje deje deje dejejeeef  f
ddZdS )r   a  Class that implements a lexer for a given environment. Automatically
    created by the environment class, usually you don't have to do that.

    Note that the lexer is not automatically bound to an environment.
    Multiple environments can share the same lexer.
    rl   r	   rO   Nc                 C   s&  t j}dtdtjt fdd}tttd ttt	d tt
td tttd tttd tttd g}t|}||j}||j}||j}||j}	|jrLdnd}
|j| _|j| _|j| _d| d| d	| d
}d|gdd |D  }dt|d| dttddt|dtd gtt|d| d| d	| |
 d
tt fdt|dt!dfd gt"t|d| d| d	| |
 dt#dg| t$t|d|	 d	|	 t%dg| t&t|d| d| d| d	| |
 d

ttt'dt|dt!dfd gt(t|dt)dg| t*t|dt+t,fdgi| _-d S )NrG   rO   c                 S   s   t | t jt jB S rC   )rD   compileMSrK   r=   r=   rA   c  s   zLexer.__init__.<locals>.cz\n?r   z(?P<raw_begin>z(\-|\+|)\s*raw\s*(?:\-z\s*|z))r:   c                 S   s"   g | ]\}}d | d| dqS )z(?P<r5   z	(\-|\+|))r=   )r>   r   rr=   r=   rA   rm   
  s   " z"Lexer.__init__.<locals>.<listcomp>rootz(.*?)(?:r2   #bygroupz.+z(.*?)((?:\+z|\-#popz(.)zMissing end of comment tagz(?:\+z\-z	(.*?)((?:z(\-|\+|))\s*endraw\s*(?:\+zMissing end of raw directivez	\s*(\n|$)z(.*?)()(?=\n|$)).rD   rE   r   r   r   r   whitespace_reTOKEN_WHITESPACEfloat_reTOKEN_FLOAT
integer_reTOKEN_INTEGERname_rerb   	string_reTOKEN_STRINGoperator_reTOKEN_OPERATORry   rp   r   r   r   r   r   r   r   joinr   r[   rQ   rS   rR   rz   rU   rV   rW   rX   TOKEN_RAW_BEGINTOKEN_RAW_ENDrY   rZ   ru   rT   TOKEN_LINECOMMENT_ENDrx   )r~   rl   rw   r   Z	tag_rulesZroot_tag_rulesZblock_start_reZblock_end_reZcomment_end_reZvariable_end_reZblock_suffix_reZroot_raw_reZroot_parts_rer=   r=   rA   r     s   










		
zLexer.__init__rc   c                 C   s   t | j|S )z`Replace all newlines with the configured sequence in strings
        and template data.
        )rh   r   r   )r~   rc   r=   r=   rA   _normalize_newlinesV  rk   zLexer._normalize_newlinessourcer"   r   statec                 C   s&   |  ||||}t| |||||S )z:Calls tokeniter + tokenize and wraps it in a token stream.)	tokeniterr   wrap)r~   r   r"   r   r   r   r=   r=   rA   tokenize\  s   zLexer.tokenizer   c           
      c   sT   |D ]\}}}|t v rq|}|tkrt}n|tkrt}n|ttfv r$q|tkr.| |}nr|dkr5|}nk|t	krG|}|
 sFtd|||nY|tkr}z| |dd ddd}W nB ty| } zt|dd  }	t|	||||d	}~ww |tkrt|d
dd}n|tkrt|d
d}n|tkrt| }t|||V  qd	S )zThis is called with the stream as returned by `tokenize` and wraps
        every token in a :class:`Token` and converts the value.
        keywordzInvalid character in identifierr   asciibackslashreplacezunicode-escaper9   Nr   r   r   )ignored_tokensrY   rU   rZ   rV   r   r   r[   r   rb   isidentifierr   r   encodedecode	Exceptionr   rf   stripr   r   replacer   r   r   	operatorsr`   )
r~   r   r"   r   r   r_   Z	value_strrc   rw   msgr=   r=   rA   r   g  sR   	z
Lexer.wrapc                 c   s"   t |ddd }| js|d dkr|d= d|}d}d}dg}|dur:|dkr:|d	v s3J d
||d  | j|d  }	t|}
g }d}d}	 |	D ]\}}}|||}|du r_qN|ri|tt	t
fv riqNt|tr2| }t|tr|d }tdd |ddd D }|dkr| }|t|d d}|g|dd }n.|dkr| jr| ts|dd }|dks|rt||r|d| g|dd }t|D ]W\}}t|tr||||dkr|  D ]\}}|dur
|||fV  ||d7 } nqt|dq|| }|s|tvr%|||fV  ||d| 7 }d}qni| }|tkr|dkrF|d n@|dkrQ|d n5|dkr\|d n*|dv r|sot d| d||||! }||krt d| d| d||||s|tvr|||fV  ||d7 }| dd dk}|" }|dur|dkr|!  n*|dkr|  D ]\}}|dur||  n	qt|dn|| | j|d  }	n||krt|d|} n||
krdS t d || d!| |||qL)"a  This method tokenizes the text and returns the tokens in a
        generator. Use this method if you just want to tokenize a template.

        .. versionchanged:: 3.0
            Only ``\n``, ``\r\n`` and ``\r`` are treated as line
            breaks.
        N   r   r   
r   r   r   )variableblockzinvalid stateZ_beginTc                 s   s    | ]	}|d ur|V  qd S rC   r=   )r>   gr=   r=   rA   rH     s    z"Lexer.tokeniter.<locals>.<genexpr>r*   r)   r   z= wanted to resolve the token dynamically but no group matchedr3   r4   r1   r2   r/   r0   )r4   r2   r0   zunexpected ''z', expected 'r   zA wanted to resolve the new state dynamically but no group matchedz* yielded empty string without stack changezunexpected char z at )#rh   rf   r   r   rs   rx   rJ   matchrX   rV   rZ   
isinstancetuplegroupsr   r   rstripcountr   	groupdictr]   rW   rfindr   	fullmatch	enumeraterz   itemsRuntimeErrorignore_if_emptygroupr   r   popend)r~   r   r"   r   r   linesposr   stackstatetokensZsource_lengthZbalancing_stackZnewlines_strippedZline_startingregexr   	new_statemr  textZ
strip_signstrippedZl_posidxr_   rM   rc   r&   Zexpected_oppos2r=   r=   rA   r     s   




















 zLexer.tokeniter)rl   r	   rO   N)NNN)NN)r   r   r   r   r   r   r   r   r   r   r   r   r   r   Iteratorr`   r   r   r=   r=   r=   rA   r     sT    
w	

:)rl   r	   rO   r   )pr   rD   typingr   astr   collectionsr   sysr   Z_identifierr   r   
exceptionsr   utilsr   TYPE_CHECKINGZtyping_extensionsterl   r	   r   MutableMappingr   r   r   r   rh   r   r   
IGNORECASEVERBOSEr   r   Z	TOKEN_ADDZTOKEN_ASSIGNZTOKEN_COLONZTOKEN_COMMAZ	TOKEN_DIVZ	TOKEN_DOTZTOKEN_EQZTOKEN_FLOORDIVZTOKEN_GTZ
TOKEN_GTEQZTOKEN_LBRACEZTOKEN_LBRACKETZTOKEN_LPARENZTOKEN_LTZ
TOKEN_LTEQZ	TOKEN_MODZ	TOKEN_MULZTOKEN_NEZ
TOKEN_PIPEZ	TOKEN_POWZTOKEN_RBRACEZTOKEN_RBRACKETZTOKEN_RPARENZTOKEN_SEMICOLONZ	TOKEN_SUBZTOKEN_TILDEr   r   r   rb   r   r   rU   rV   rW   rX   r   r   rQ   rR   rS   rY   rZ   ru   r   rT   r[   r   r\   r   r
  rP   rJ   r   rv   r   	frozensetr   r  r   r^   rd   rg   r   rj   Listry   rz   
NamedTupler`   r   r   r   r  r   r   r   r=   r=   r=   rA   <module>   s.   




	
&
")
m