
    yIf.t                     V   U d Z ddlZddlmZmZmZmZmZmZm	Z	m
Z
mZmZ ej        dk    rddlmZ nddlmZ ddlmZ ddlmZ ddlmZmZ dd	lmZmZ dd
lmZ ddlmZ ddlmZm Z m!Z!m"Z"  ej#        e           ej$        Z%ee&d<    ed          Z'ee e!f         Z(e)Z*e)Z+ej,        ej-        ej.        hZ/ee&d<   e%j0        e%j1        e%j2        e%j3        e%j4        e%j5        e%j6        e%j7        e%j8        e%j9        h
Z:ee&d<   dZ;ee&d<   dej<        e;<   ddhZ=ee&d<   ej>        ej?        ej@        ejA        ejB        ejC        hZDee&d<   ejE        ejF        ejG        ejH        ejI        ejJ        ejK        ejL        ejM        ejN        ejO        ejP        ejQ        ejR        hZSee&d<   ejL        ejR        hZTee&d<   eTejM        hz  ZUee&d<   e%jV        e%jW        e%jX        e%jY        e%jZ        hZ[ee&d<   e%j\        e%j]        e%j^        e%j_        e%j`        e%ja        e%jb        hZcee&d<   e%jd        e%je        e%jf        e%jg        e%jh        e%ji        e%jj        e%jk        e%jl        e%jm        e%jn        e%jo        e%jX        e%jp        e%jq        e%jr        hZsee&d<   e%jt        e%ju        hZvee&d<   h dZwee&d<   e%jx        e%j`        e%jy        hZzee&d <   ej{        ej|        ej}        ej~        ej        ej        iZee&d!<    ee                                          Zee&d"<    ee                                          Zee&d#<   eez  Zee&d$<   eej        e;ej        ej        ej        hz  Zee&d%<   d&Z ed'(           G d) d*ee'                               Zd+e d,ed-ed.efd/Zdxd1e)d2ed3ed.efd4Zd5ee(         d.ee          fd6Zd5ee(         d7eee+                  d.efd8Zd5ee(         d.ee+         fd9Zd:e!d;e(d.ee(         fd<Zd=e(d>e(d.dfd?Zd+e d.e(fd@Zd5e(d.ee          fdAZd5e(d.efdBZd5ed-ed.efdCZd5e(d.efdDZd5e(d.efdEZd5e(d.efdFZej{        ej|        ffdGe dHe dIee          dJe
e)e)f         d.ef
dKZd5e(d.efdLZdyd5e(dNed.efdOZd5e(d.efdPZd5e(d.efdQZd+e dRe	e+         d.efdSZd5e!d.efdTZd5e!d.e fdUZd5e(d.efdVZd5e!d.efdWZd5e!d.efdXZd5e!d.efdYZd5e(d.efdZZd5e(d.efd[Zd+e d.efd\Zd+e d.efd]Zd+e d.efd^Zd+e d.efd_Zd+e d.efd`Zd+e d.efdaZd+e d.efdbZd+e d.efdcZdded.efdeZd'dfdge!dhe(died.dfdjZd5e(d.ee(         fdkZd+e d.dfdlZdmed.ee          fdnZdmed.ee          fdoZdmed.ee          fdpZdmed.ee          fdqZd+e d.edr         fdsZd+e d.efdtZd5e(d.ee          fduZd5e(d.ee          fdvZd+e d.e(fdwZdS )zz>
blib2to3 Node/Leaf transformation-related utility functions.
    N)
FinalGenericIteratorListLiteralOptionalSetTupleTypeVarUnion)   
   )	TypeGuard)
mypyc_attr)	CACHE_DIR)ModePreview)get_string_prefixhas_triple_quotes)pygram)token)NLLeafNode	type_reprsymsT
WHITESPACE	STATEMENT   STANDALONE_COMMENTandorLOGIC_OPERATORSCOMPARATORSMATH_OPERATORSSTARSVARARGS_SPECIALSVARARGS_PARENTSUNPACKING_PARENTSTEST_DESCENDANTSTYPED_NAMES>   %=&=*=+=-=/=@=^=|=**=//=<<=>>=:=ASSIGNMENTSIMPLICIT_TUPLEBRACKETOPENING_BRACKETSCLOSING_BRACKETSBRACKETSALWAYS_NO_SPACE7   T)allow_interpreted_subclassesc                   J    e Zd ZdZdedee         fdZdedee         fdZdS )VisitorzBBasic lib2to3 visitor that yields things of type `T` on `visit()`.nodereturnc              #     K   |j         dk     rt          j        |j                  }n!t          t	          |j                             }t          | d| d          }|r ||          E d{V  dS |                     |          E d{V  dS )az  Main method to visit `node` and its children.

        It tries to find a `visit_*()` method for the given `node.type`, like
        `visit_simple_stmt` for Node objects or `visit_INDENT` for Leaf objects.
        If no dedicated `visit_*()` method is found, chooses `visit_default()`
        instead.

        Then yields objects of type `T` from the selected visitor.
           visit_N)typer   tok_namestrr   getattrvisit_default)selfrG   namevisitfs       ?/var/www/piapp/venv/lib/python3.11/site-packages/black/nodes.pyvisitzVisitor.visit   s       9s??>$),DDy++,,D
 55 	0vd||#########))$///////////    c              #      K   t          |t                    r%|j        D ]}|                     |          E d{V  dS dS )zCDefault `visit_*()` implementation. Recurses to children of `node`.N)
isinstancer   childrenrU   )rQ   rG   childs      rT   rP   zVisitor.visit_default   sd      dD!! 	- - -::e,,,,,,,,,,	- 	-- -rV   N)	__name__
__module____qualname____doc__LNr   r   rU   rP    rV   rT   rF   rF      sf        LL0" 0! 0 0 0 00-" -! - - - - - -rV   rF   leafcomplex_subscriptmoderH   c                   d}d}d}| j         }| j        }| j        }|t          v r|S |t          j        k    r|S |J d|             |t          j        k    r,|j         t          j        t          j	        t          j
        hvr|S |t          j        k    r|j         t          j        k    r|S | j        }	|	st          |          }
|
r|
j         t          v r|S |t          j        k    r2|
j         t          j        k    r|S |
j         t          j        k    r|s|S |S |
j         t          j        k    rf|
j        r]|
j        j         t          j        t          j        t          j        t          j        hv r|S |
j        j         t          j        k    r|
j        S n]|
j         t          j        k    rAt3          |
          t          j        k    r$t3          |
j                  t          j	        k    r|S |
j         t6          v r!t9          |
t:          t<          z            r|S n|
j         t          j        k    r2|
j        r*|
j        j         t          j        t          j
        hv r|r|n|S n|
j        r*|
j        j         t          j        k    r|
j         t@          v r|S |
j         t          j!        k    r#|j        r|j        j         t          j"        k    r|S n'|	j         t          v r|S |	j         t          j#        k    r|S |j         t          j        t          j        hv r|	r|	j         t          j        k    r|S n|j         t          j        k    r|	r|	j         t          j        k    r|S n|j         t          j        k    r[|	s|S |t          j        k    r|	j         tH          vr|S nh|	j         t          j        k    r|	j        S |	j         t          j        k    r|S n3|j         tH          v r,|	s(t          |          }
|
r|
j         t          j        k    r|S n|j         t          j%        k    ra|t          j&        k    s|t          j'        k    r|S |	s$|t          j(        k    s|t          j)        k    r|S n|	j         t          j        k    r|S n|j         t          j        k    r^|t          j        k    r|S |	s*t          |          }
|
r|
j         t          j&        k    r|S n0|	j         t          j        ht6          z  v r|S n|j         t          j"        k    r|S |j         t          j*        k    rC|	r|S t          |          }
|
r*|
j         t          j!        k    s|
j         t          j(        k    r|S n|j         t          j+        k    r-|t          j&        k    r|S |	r|	j         t          j&        k    r|S n_|j         t          j        t          j
        hv r^|	s/|j        
J d            |j        j         t          j	        k    r|S |S |t          j,        k    s|	j         t          j,        k    r|S |s|S n|j         t          j-        k    r|	r|t          j(        k    r|S n|j         t          j.        k    r|	r|	j         t          j/        k    r|S n|j         t          j        t          j        hv r|	st          |          }
|
r|
j         t          v r|S |
j        }|J |
j         t          j        k    r!|j         t          j        t          j
        hv r|S |
j         t          j        k    r|j         t          j        k    r|S n|t          j0        t          j1        t          j2        hv r|S n|j         t          j3        k    r\|t          j(        k    r|	r|	j         t          j(        k    r|S np|t          j0        k    r!|dk    r|S |	r|	j         t          j(        k    r|S n>|j         t          j
        k    r|S |j         t          j4        k    r|t          j        k    r|S |S )	zReturn whitespace prefix if needed for the given `leaf`.

    `complex_subscript` signals whether the given leaf is part of a subscription
    which has non-trivial arguments, like arithmetic expressions or function calls.
      z  Nz/INTERNAL ERROR: hand-made leaf without parent: )withinzsubscripts are always parentedimport)5rL   parentvaluerB   r   COMMENTCOLONr   	subscriptsubscriptlistsliceopLBRACEfstring_replacement_fieldprev_siblingpreceding_leafr?   COMMAEQUALarglistargument
parametersvarargslisttypedargslistprefixSTARparent_type	star_exprr(   	is_varargr)   r*   factorr&   AT	decoratorBANGr,   trailerLPARRPARDOTLSQBdotted_nameclassdef
COLONEQUALatomdictsetmaker
DOUBLESTARNAMENUMBERSTRINGimport_fromexcept_clause)ra   rb   rc   NOSPACEDOUBLESPACEtpvprevprevpprevp_parents               rT   
whitespacer      s    BE"K	AA
AO	EM==TDTT===EKAF+  
 	ELQVt'EEE	D =q!! 	
&666IzU[((	u{**3D*	L:$$| (<$LMO$	)   I\&$*<<< !<' J%*$$E""dn44EL))T-??? IZ+++9J'JKKK 	 Z5;&&| : 1dndl5S S S 19uur9 L		!T[00
n,,IZ58###QX]dn5T5TI	&	&	&		ej	 	 	v$/4<000 	tyEK//I 0 
4#	#	# 	DI,,I	
4%	%	% 	Iy++	 , Y%+%% ;Y%+%%I & 
;		 	"1%%E EJ%+55		
4<		
??a5:ooI 	EI~~ej	 "1 Y%+%%I & 
4=	 	 I 	"1%%E EJ%*44	 5 Y5;-*::::I ; 
4>	!	!		
4#	#	# 	Iq!! 	
eh..%*	2I2II 3J 
4=	 	 
??I 	DI++I	
DNDL1	1	1 	8'')I'''x} 222I%"""di53C&C&CL" 	I	 
49		 	ANNI	
4$	$	$ 	DI!111I	
DK0	0	0 	"1%%E EJ*:::	 <L+++zU[((\->C . . 	u{**|/@DM/Q/Q	 5:u|U\:::I ; 
4#	#	#	>> 	UY..	%*__H}} 	UY..		
4<				
4%	%	%
??ILrV   
nl_count	form_feed
empty_linec                 ,    |r|| dz
  z  dz   |z   S || z  S )z$Generate a normalized prefix string.   r`   )r   r   r   s      rT   make_simple_prefixr     s/     Ahl+t3j@@  rV   rG   c                     | rb| j         }|rPt          |t                    r|S 	 t          |                                          d         S # t
          $ r Y dS w xY w| j        } | bdS )z3Return the first leaf that precedes `node`, if any.N)rr   rX   r   listleaves
IndexErrorri   )rG   ress     rT   rs   rs     s    
  	#t$$ 
CJJLL))"--   tt {   4s   &A 
AAtokensc                     |sdS |d         | du S | sdS | j         |d         k    rdS t          | j        |dd                   S )a;  Return if the `node` and its previous siblings match types against the provided
    list of tokens; the provided `node`has its type matched against the last element in
    the list.  `None` can be used as the first element to declare that the start of the
    list is anchored at the start of its parent's children.Tr   NF)rL   prev_siblings_arerr   )rG   r   s     rT   r   r     sc    
  tbzt| uyF2JuT.ss<<<rV   c                 0    | | j         dS | j         j        S )z|
    Returns:
        @node.parent.type, if @node is not None and has a parent.
            OR
        None, otherwise.
    N)ri   rL   rG   s    rT   r}   r}     s      |t{*t;rV   ancestor
descendantc                 L    |}|r|j         | k    r|j         }|r|j         | k    |S )z:Return the child of `ancestor` that contains `descendant`.)ri   )r   r   rG   s      rT   child_towardsr     s=    #D
 4;(**{  4;(**KrV   	old_child	new_childc                 x    | j         }|sdS |                                 }||                    ||           dS dS )z
    Side Effects:
        * If @old_child.parent is set, replace @old_child with @new_child in
        @old_child's underlying Node structure.
            OR
        * Otherwise, this function does nothing.
    N)ri   removeinsert_child)r   r   ri   	child_idxs       rT   replace_childr     sT     F   ""IIy11111 rV   c                     | j         }| }|rV|j        }|nL|j        d         j         |k    rn5|j        t          j        k    rn|j        |j        j        t          v rn|}|V|S )zReturn `leaf` or one of its ancestors that is the topmost container of it.

    By "container" we mean a node where `leaf` is the very first child.
    Nr   )r{   ri   rY   rL   r   
file_inputrr   rA   )ra   same_prefix	containerri   s       rT   container_ofr     s    
 +KI
 !>?1$33;$/))*v/B/G8/S/S	   rV   c                 v    t          | t                    r| S | j        rt          | j        d                   S dS )z(Returns the first leaf of the node tree.r   N)rX   r   rY   first_leaf_ofr   s    rT   r   r     s=    $ } T]1-...trV   c                 l    | j         t          j        t          j        t          j        t          j        hv S )z?Whether node is an arithmetic or a binary arithmetic expression)rL   r   
arith_expr
shift_exprxor_exprand_exprr   s    rT   is_arith_liker   $  s*    9	  rV   c                    t          | t                    rO| j        t          j        k    rdS t          | j                  }t          |                              d          rdS t          j
        |v rZ| j        rS| j        j        t          j        k    r9| j        j        s-| j        j        r!| j        j        j        t          j        k    rdS t!          | j        d t          j        t          j        t          j        g          rdS t!          | j        t          j        t          j        t          j        g          rdS dS )NFbBfFT)rX   r   rL   r   r   r   rj   setintersectionr   unify_docstring_detectionri   r   simple_stmtrr   r   r   NEWLINEINDENTrx   rl   )rG   rc   r{   s      rT   is_docstringr   .  s   $ 9$$5"4:..v;;##F++ 	5 	)T11K 	2K 000( 1K 1 K#t66tdEM5<9IJ   t tTEU&VWW  t5rV   c                     | j         t          j        k    oWt          | j                  dk    o?| j        d         j         t
          j        k    o| j        d         j         t
          j        k    S )z+Return True if `node` holds an empty tuple.   r   r   )rL   r   r   lenrY   r   r   r   r   s    rT   is_empty_tupler   O  s`     		TY 	0!#	0M!!UZ/	0 M!!UZ/	rV   c                 x   | j         t          j        k    r`t          |           }||j         t          j        k    rdS t          |j                  dk    o|j        d         j         t          j        k    S | j         t          v o7t          | j                  dk    o| j        d         j         t          j        k    S )zMReturn True if `node` holds a tuple with one element, with or without parens.NFr   r   )
rL   r   r   unwrap_singleton_parenthesistestlist_gexpr   rY   r   rt   r=   rG   gexps     rT   is_one_tupler   Y  s    yDI+D11<49(:::54=!!Q&O4=+;+@EK+OO 		^# 	1!#	1M!!U[0rV   c                     | j         t          j        k    rdS t          |           }||j         t          j        k    rdS t          d |j        D                       S )zDReturn True if `node` holds a tuple that contains a walrus operator.FNc              3   @   K   | ]}|j         t          j        k    V  d S N)rL   r   namedexpr_test).0rZ   s     rT   	<genexpr>z-is_tuple_containing_walrus.<locals>.<genexpr>q  s,      LLUuzT00LLLLLLrV   )rL   r   r   r   r   anyrY   r   s     rT   is_tuple_containing_walrusr   i  s[    yDIu'--D|tyD$666uLLdmLLLLLLrV   openingclosingr   bracketsc                    | j         |j         f|k    rdS |j        dz   }t          |          D ]\  }}|| u r nt          d          d}|dz  }||d         D ]a}||u r nZ|j        }||k    rL|j         t          j        k    r7|dz  }|j        r+|j        j         t          j        t          j	        hv r|dz  } nb|dk     S )zIReturn True if content between `opening` and `closing` is a one-sequence.Fr   z#Opening paren not found in `leaves`r   Nr   )
rL   bracket_depth	enumerateLookupErrorr   rt   ri   r   rv   rz   )	r   r   r   r   depth_opening_indexra   commasr   s	            rT   is_one_sequence_betweenr   t  s    	gl#x//u!A%E )& 1 1 A A7??E  ?@@@FaN~'  7??E*E!!di5;&>&>aKF{ t{/"4     !A:rV   c                 R    t          |           }|duo|j        t          j        k    S )z7Return True iff `node` is of the shape ( test := test )N)r   rL   r   r   )rG   inners     rT   is_walrus_assignmentr     s)    (..EBt/B!BBrV   Flastc                 F   | j         t          j        k    ot          | j                  dk    o?| j        d         j         t
          j        k    o| j        d         j         t
          j        k    p|oWt          | j                  dk    o?| j        d         j         t
          j        k    o| j        d         j         t
          j	        k    pY|oWt          | j                  dk    o?| j        d         j         t
          j        k    o| j        d         j         t
          j	        k    S )z?Return True iff `node` is a trailer valid in a simple decoratorr   r   r   r   )
rL   r   r   r   rY   r   r   r   r   r   )rG   r   s     rT   is_simple_decorator_trailerr     s   9$ !# 4a %24a %3	
  4DM""a'4a %34 a %3	
  4DM""a'4a %34 a %3'rV   c                 r   | j         t          j        k    rdS | j         t          j        k    r| j        r| j        d         j         t          j        k    obt          t          t          | j        dd                             o3t          | j                  dk     pt          | j        d         d          S dS )a\  Return True iff `node` could be a 'dotted name' decorator

    This function takes the node of the 'namedexpr_test' of the new decorator
    grammar and test if it would be valid under the old decorator grammar.

    The old grammar was: decorator: @ dotted_name [arguments] NEWLINE
    The new grammar is : decorator: @ namedexpr_test NEWLINE
    Tr   r   r   r   )r   F)
rL   r   r   r   powerrY   allmapr   r   r   s    rT   is_simple_decorator_expressionr     s     yEJtyDJ= 	a %3 7qt9LMMNN &&* Q24=3D4PPP 5rV   c                 V   | j         t          j        k    rdS t          |           r| j        dk    rdS | j         t          j        k    rdS t          | j                  dk    rdS | j        \  }}}|j         t          j	        k    r$|j         t          j
        k    rt          |          S dS )zAReturn True if `node` holds a `yield` or `yield from` expression.TyieldFr   )rL   r   
yield_expris_name_tokenrj   r   r   rY   r   r   r   is_yield)rG   lparexprrpars       rT   r   r     s    yDO##tT tzW44tyDIu
4=Qu}D$yEJ49
#:#:~~5rV   rg   c                     | j         t          vs| j        sdS | j        }|j         t          j        k    r|j        sdS |j        }|j         |v S )aF  Return True if `leaf` is a star or double star in a vararg or kwarg.

    If `within` includes VARARGS_PARENTS, this applies to function signatures.
    If `within` includes UNPACKING_PARENTS, it applies to right hand-side
    extended iterable unpacking (PEP 3132) and additional unpacking
    generalizations (PEP 448).
    F)rL   r(   ri   r   r~   )ra   rg   r   s      rT   r   r     sY     y((((uAv x 	5H6VrV   c                 ,    | j         t          j        k    S )z&Return True if the node is an f-string)rL   r   fstringr   s    rT   
is_fstringr    s    9$$rV   c                     t          |           t          | j                  d         }t          t          j        || j                  }|                                 pd|_        |S )z/Converts an fstring node back to a string node.N)r{   r   )rN   r   r{   r   r   r   
get_linenolineno)rG   string_without_prefixstring_leafs      rT   fstring_to_stringr    sY    IIc$+&6&6&8&89u|%:4;OOOK**/aKrV   c                     t          | t                    rt          |           rt          |           }nt          | t                    r| }ndS t          |j                  od|j        v S )zKReturn True if `leaf` is a multiline string that actually spans many lines.Fr   )rX   r   r  r  r   r   rj   )rG   ra   s     rT   is_multiline_stringr  
  sl    $ *T"2"2  &&	D$		 uTZ((?TTZ-??rV   c                     | j         t          j        t          j        hv sJ | j        J | j        j         t          j        t          j        hv S r   )rL   r   suiter   ri   funcdefr   r   s    rT   is_parent_function_or_classr    sF    9T%566666;""";dm<<<rV   c                 V    | j         t          j        t          j        t          j        hv S r   )rL   r   r  r   async_funcdefr   s    rT   is_function_or_classr    s    9t}d6HIIIrV   c                    | j         t          |           sdS | j                                        rdS t	          | j                  dk    s`| j        d         j        t          j        k    s@| j        d         j        t          j	        k    s | j        d         j        t          j
        k    rdS | j        d         j                                        rdS t          | j        d                   S )z2Return True if `node` is a suite with a stub body.NF   r   r   r   r   )ri   r  r{   stripr   rY   rL   r   r   r   DEDENTis_stub_bodyr   s    rT   is_stub_suiter  !  s    {'B4'H'Hu { u 	DMa= EM11= EL00= EL00u}Q$$&& ua()))rV   c                 r   t          | t                    r| j        t          j        k    rdS t          | j                  dk    rdS | j        d         }|j                                         oJ|j        t          j	        k    o5t          |j                  dk    ot          d |j        D                       S )zCReturn True if `node` is a simple statement containing an ellipsis.Fr   r   r   c              3   R   K   | ]"}|t          t          j        d           k    V  #dS ).N)r   r   r   )r   ra   s     rT   r   zis_stub_body.<locals>.<genexpr>E  s3      HHUY,,,HHHHHHrV   )rX   r   rL   r   r   r   rY   r{   r  r   r   )rG   rZ   s     rT   r  r  8  s    dD!! TY$2B%B%Bu
4=QuM!EL    	IJ$)#	I1$	I HHHHHHH	rV   c                 b   t          | t                    s| j        t          j        k    rdS | j        d         | j        d         }}t          |t                    oT|j        t          j        k    o?|j        dk    o4t          |t                    o|j        t          j	        k    o
|j        dk    S )zGiven a `LN`, determines whether it's an atom `node` with invisible
    parens. Useful in dedupe-ing and normalizing parens.
    Fr   r   re   )
rX   r   rL   r   r   rY   r   r   rj   r   )rG   firstr   s      rT   is_atom_with_invisible_parensr   I  s     $ di!7!7u-"DM"$54E5$ 	J%*$	K2	 tT""	 I#		
 J"rV   c                 >    t          |           pt          |           S r   )is_empty_lparis_empty_rparra   s    rT   is_empty_parr%  [  s    5-"5"55rV   c                 B    | j         t          j        k    o
| j        dk    S Nre   )rL   r   r   rj   r$  s    rT   r"  r"  _      9
"7tzR'77rV   c                 B    | j         t          j        k    o
| j        dk    S r'  )rL   r   r   rj   r$  s    rT   r#  r#  c  r(  rV   c                     | j         }| j        }| j        }t          |t          j        k    o9|dk    r|r|j        t          j        k    p|dk    o|o|j        t          j        k              S )z9Return True if the given leaf starts an import statement.rh   from)	ri   rL   rj   boolr   r   r   import_namer   )ra   r   r   r   s       rT   	is_importr.  g  ss    A	A
A	UZ 	
(]?q?QVt/?%? BV@@af0@&@	  rV   c                 $   t          | j        t          j        k    o+| j        dk    o | j        o| j        j        t          j        k              pBt          | j        t          j        k    o | j	        o| j	        j        t          j        k              S )zDReturn True if the given leaf starts a with or async with statement.with)
r,  rL   r   r   rj   ri   r   	with_stmtASYNCnext_siblingr$  s    rT   is_with_or_async_with_stmtr4  u  s    	UZ 	/J& 	/K	/ K.	  	
 
	U[  	5	5"dn4
 
	rV   c                     t          | j        t          j        k    o*| j        o#| j        j        t
          j        t
          j        hv           S )zReturn True if the given leaf starts an async def/for/with statement.

    Note that `async def` can be either an `async_stmt` or `async_funcdef`,
    the latter is used when it has decorators.
    )r,  rL   r   r2  ri   r   
async_stmtr  r$  s    rT   is_async_stmt_or_funcdefr7    sJ     	U[  	FK	FK$2D EE  rV   c                 r    | j         }| j        }|t          j        t          hv o|                    d          S )aB  Return True if the given leaf is a type comment. This function should only
    be used for general type comments (excluding ignore annotations, which should
    use `is_type_ignore_comment`). Note that general type comments are no longer
    used in modern version of Python, this function may be deprecated in the future.z# type:)rL   rj   r   rk   r!   
startswithra   r   r   s      rT   is_type_commentr;    s6    
 		A
A 233OY8O8OOrV   c                 f    | j         }| j        }|t          j        t          hv ot          |          S )zGReturn True if the given leaf is a type comment with ignore annotation.)rL   rj   r   rk   r!   is_type_ignore_comment_stringr:  s      rT   is_type_ignore_commentr>    s2    	A
A 233X8UVW8X8XXrV   rj   c                 ,    |                      d          S )zSReturn True if the given string match with type comment with
    ignore annotation.z# type: ignore)r9  )rj   s    rT   r=  r=    s     ,---rV   )visibleri   rZ   r@  c                :   t          t          j        |rdnd          }t          t          j        |rdnd          }|j        }d|_        |                                pd}t          t          j        |||g          }||_        | 	                    ||           dS )zWrap `child` in parentheses.

    This replaces `child` with an atom holding the parentheses and the old
    child.  That requires moving the prefix.

    If `visible` is False, the leaves will be valueless (and thus invisible).
    (re   )r   N)
r   r   r   r   r{   r   r   r   r   r   )ri   rZ   r@  r   r  r{   indexr   s           rT   wrap_in_parenthesesrE    s     
72CC33D
72CC33D\FELLLNNaETYud 344II
y)))))rV   c                     t          | j                  dk    rdS | j        \  }}}|j        t          j        k    r|j        t          j        k    sdS |S )zqReturns `wrapped` if `node` is of the shape ( wrapped ).

    Parenthesis can be optional. Returns None otherwiser   N)r   rY   rL   r   r   r   )rG   r   wrappedr  s       rT   r   r     sS     4=Qt-D'4I##	UZ(?(?tNrV   c                 ~    | j         t          j        k    r	d| _        dS | j         t          j        k    r	d| _        dS dS )zMake sure parentheses are visible.

    They could be invisible as part of some statements (see
    :func:`normalize_invisible_parens` and :func:`visit_import_from`).
    rB  rC  N)rL   r   r   rj   r   r$  s    rT   ensure_visiblerI    s@     yEJ


	ej	 	 


 
!	 rV   nlc                 ,    | j         t          j        k    S r   )rL   r   r   rJ  s    rT   r   r         7ej  rV   c                 ,    | j         t          j        k    S r   )rL   r   r   rL  s    rT   is_lpar_tokenrO    rM  rV   c                 ,    | j         t          j        k    S r   )rL   r   r   rL  s    rT   is_rpar_tokenrQ    rM  rV   c                 ,    | j         t          j        k    S r   )rL   r   r   rL  s    rT   is_number_tokenrS    s    7el""rV   )rH   paramNc                     | j         }|O|j        r|j        j        t          j        k    rdS |j         r|j         j        t
          j        k    rdS |j         }|OdS )z<Returns the type of annotation this leaf is part of, if any.NrH   rT  )ri   rr   rL   r   RARROWr   tname)ra   r   s     rT   get_annotation_typerX    sg    {H

  	X%:%?5<%O%O8? 	x3tzAA7? 
 4rV   c                 $    t          |           duS )z7Returns whether this leaf is part of a type annotation.N)rX  r$  s    rT   is_part_of_annotationrZ    s    t$$D00rV   c                 v    t          | t                    r| S | j        sdS t          | j        d                   S )z,Returns the first leaf of the ancestor node.Nr   )rX   r   rY   
first_leafr   s    rT   r\  r\    s=    $ ,] ,t$-*+++rV   c                 v    t          | t                    r| S | j        sdS t          | j        d                   S )z+Returns the last leaf of the ancestor node.Nr   )rX   r   rY   	last_leafr   s    rT   r^  r^    s=    $ ,] ,tr*+++rV   c                     | }|j         rN|j         j        rB||j         j        d         u r.|j         }|j         r |j         j        r||j         j        d         u .|S )zGReturns the furthest ancestor that has this leaf node as the last leaf.r   )ri   rY   )ra   rG   s     rT    furthest_ancestor_with_last_leafr`    sk    D
+ $+. 44;;OPR;S3S3S{ + $+. 44;;OPR;S3S3SKrV   )r   )F)r^   systypingr   r   r   r   r   r   r	   r
   r   r   version_infor   typing_extensionsmypy_extensionsr   black.cacher   
black.moder   r   black.stringsr   r   blib2to3r   blib2to3.pgen2r   blib2to3.pytreer   r   r   r   
initializepython_symbolsr   __annotations__r   r_   intLeafIDNodeTyper  r   r   r   if_stmt
while_stmtfor_stmttry_stmtr   r1  r  r   
match_stmt
case_blockr   r!   rM   r$   LESSGREATEREQEQUALNOTEQUAL	LESSEQUALGREATEREQUALr%   VBAR
CIRCUMFLEXAMPER	LEFTSHIFT
RIGHTSHIFTPLUSMINUSr|   SLASHDOUBLESLASHPERCENTr   TILDEr   r&   r'   r(   rv   rw   r   rz   ry   r)   r   r   	listmakerr   testlist_star_exprsubject_exprpatternr*   testlambdefor_testand_testnot_test
comparisonr~   r   r   r   r   r   termr   r   r+   rW  
tname_starr,   r<   testlistexprlistr=   r   r   r   RSQBrp   RBRACEr>   r   keysr?   valuesr@   rA   rt   FSTRING_MIDDLEFSTRING_ENDr   rB   rV  rF   r,  rN   r   r   rs   r   r}   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r  r  r  r  r  r  r  r   r%  r"  r#  r.  r4  r7  r;  r>  r=  rE  r   rI  r   rO  rQ  rS  rX  rZ  r\  r^  r`  r`   rV   rT   <module>r     s7     


                        w       ++++++ & & & & & & ! ! ! ! ! ! $ $ $ $ $ $ $ $ > > > > > > > >                   5 5 5 5 5 5 5 5 5 5 5 5  )   #e # # # GCLL
4:	 \5<?
E ? ? ?LOMMNLMOO	5      E   %9! " & & &	J	M	M	N	O	U    
J		K	O		J	K	J	K		M	H	K	     
E,-u - - -5;-/ % / / /LML    	INL 5    	ILLMMONIMMOOLIJ! %   $ j$/2U 2 2 2  U   $ (?O O O O	J
	J
	L%,   
 #gllnn-- % - - -#gnn..// % / / /"%55% 5 5 5)	K			J-     
 ...- - - - -gaj - - /.-DmT m mT mc m m m m`! ! ! !3 !RU ! ! ! !" (4.    $=HRL =$x7I2J =t = = = = 
hrl 
x'9 
 
 
 
D b Xb\    2R 2B 24 2 2 2 2"t     2 x~     t    r  $    B     r d     MR MD M M M M "'UZ 8	" """ J" CHo	"
 
" " " "JCr Cd C C C C b      4     02 $    *D #h- D    .%T %d % % % %
D T    	@b 	@T 	@ 	@ 	@ 	@=d =t = = = =Jt J J J J J* * * * * *.r d    " t    $6t 6 6 6 6 68 8 8 8 8 88 8 8 8 8 8D T    T d    
4 
D 
 
 
 
P$ P4 P P P PY Y$ Y Y Y Y. . . . . . EI * * * *R *T *T * * * *$r hrl    	 	$ 	 	 	 	!b !Yt_ ! ! ! !!b !Yt_ ! ! ! !!b !Yt_ ! ! ! !# #y # # # #	d 	w/F'G 	 	 	 	1 1 1 1 1 1
,R ,HTN , , , ,,B ,8D> , , , ,4 B      rV   