
    qjt                     J   U d Z ddlZddl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"j-        e"j.        e"j/        e"j0        e"j1        e"j2        e"j3        e"j4        e"j5        e"j6        h
Z7ee#d<   dZ8ee#d<   dej9        e8<   ddhZ:ee#d<   ej;        ej<        ej=        ej>        ej?        ej@        hZAee#d<   ejB        ejC        ejD        ejE        ejF        ejG        ejH        ejI        ejJ        ejK        ejL        ejM        ejN        ejO        hZPee#d<   ejI        ejO        hZQee#d<   eQejJ        hz  ZRee#d<   e"jS        e"jT        e"jU        e"jV        e"jW        hZXee#d<   e"jY        e"jZ        e"j[        e"j\        e"j]        e"j^        e"j_        hZ`ee#d<   e"ja        e"jb        e"jc        e"jd        e"je        e"jf        e"jg        e"jh        e"ji        e"jj        e"jk        e"jl        e"jU        e"jm        e"jn        e"jo        hZpee#d<   e"jq        e"jr        hZsee#d<   h dZtee#d<   e"ju        e"j]        e"jv        hZwee#d <   ejx        ejy        ejz        ej{        ej|        ej}        iZ~ee#d!<    ee~                                          Zee#d"<    ee~                                          Zee#d#<   eez  Zee#d$<   eej        e8e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%         d7ee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jx        ejy        ffdGedHedIee         dJee&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LiteralOptional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)selfrD   namevisitfs       [/lsinfo/ai/hellotax_ai/data_center/backend/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   childrenrR   )rN   rD   childs      rQ   rM   zVisitor.visit_default   sd      dD!! 	- - -::e,,,,,,,,,,	- 	-- -rS   N)	__name__
__module____qualname____doc__LNr   r   rR   rM    rS   rQ   rC   rC      sf        LL0" 0! 0 0 0 00-" -! - - - - - -rS   rC   leafcomplex_subscriptmoderE   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        }	|	sDt          |          }
|
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    rqt3          |
          t          j        k    rTt3          |
j                  t          j	        k    s0t6          j        |v r$t3          |
j                  t          j        k    r|S |
j         t<          v r!t?          |
t@          tB          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         tF          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         tN          vr|S nh|	j         t          j        k    r|	j        S |	j         t          j        k    r|S n3|j         tN          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t<          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          j0        k    r|	r|t          j+        k    r|S n|j         t          j1        k    r|	r|	j         t          j2        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          j3        t          j4        t          j5        hv r|S n|j         t          j6        k    r\|t          j+        k    r|	r|	j         t          j+        k    r|S np|t          j3        k    r!|dk    r|S |	r|	j         t          j+        k    r|S n>|j         t          j
        k    r|S |j         t          j7        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)8rI   parentvaluer?   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   $pep646_typed_star_arg_type_var_tuple
tname_starr%   	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)r^   r_   r`   NOSPACEDOUBLESPACEtpvprevprevpprevp_parents               rQ   
whitespacer      s    BE"K	AA
AO	EM==TDTT===EKAF+  
 	ELQVt'EEE	D Cq!! 	
&666IzU[((	u{**3D*	L:$$| (<$LMO$	)   I\&$*<<< !<' J%*$$E""dn44EL))T-???@DHH#EL11T_DD
 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LrS   
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      rQ   make_simple_prefixr     s/     Ahl+t3j@@  rS   rD   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)ro   rU   r   listleaves
IndexErrorrf   )rD   ress     rQ   rp   rp     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)rI   prev_siblings_arero   )rD   r   s     rQ   r   r     sc    
  tbzt| uyF2JuT.ss<<<rS   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)rf   rI   rD   s    rQ   rz   rz     s      |t{*t;rS   ancestor
descendantc                 L    |}|r|j         | k    r|j         }|r|j         | k    |S )z:Return the child of `ancestor` that contains `descendant`.)rf   )r   r   rD   s      rQ   child_towardsr     s=    #D
 4;(**{  4;(**KrS   	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)rf   removeinsert_child)r   r   rf   	child_idxs       rQ   replace_childr     sT     F   ""IIy11111 rS   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   )rx   rf   rV   rI   r   
file_inputro   r>   )r^   same_prefix	containerrf   s       rQ   container_ofr     s    
 +KI
 !>?1$33;$/))*v/B/G8/S/S	   rS   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)rU   r   rV   first_leaf_ofr   s    rQ   r   r     s=    $ } T]1-...trS   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)rI   r   
arith_expr
shift_exprxor_exprand_exprr   s    rQ   is_arith_liker     s*    9	  rS   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)rU   r   rI   r   r   r   rg   setintersectionr   unify_docstring_detectionrf   r   simple_stmtro   r   r   NEWLINEINDENTru   ri   )rD   r`   rx   s      rQ   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5rS   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   )rI   r   r   lenrV   r   r   r   r   s    rQ   is_empty_tupler   J  s`     		TY 	0!#	0M!!UZ/	0 M!!UZ/	rS   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   )
rI   r   r   unwrap_singleton_parenthesistestlist_gexpr   rV   r   rq   r:   rD   gexps     rQ   is_one_tupler   T  s    yDI+D11<49(:::54=!!Q&O4=+;+@EK+OO 		^# 	1!#	1M!!U[0rS   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)rI   r   namedexpr_test).0rW   s     rQ   	<genexpr>z-is_tuple_containing_walrus.<locals>.<genexpr>l  s,      LLUuzT00LLLLLLrS   )rI   r   r   r   r   anyrV   r   s     rQ   is_tuple_containing_walrusr   d  s[    yDIu'--D|tyD$666uLLdmLLLLLLrS   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   )
rI   bracket_depth	enumerateLookupErrorr   rq   rf   r   rs   rw   )	r   r   r   r   depth_opening_indexr^   commasr   s	            rQ   is_one_sequence_betweenr   o  s    	gl#x//u!A%E )& 1 1 A A7??E  ?@@@FaN~'  7??E*E!!di5;&>&>aKF{ t{/"4     !A:rS   c                 R    t          |           }|duo|j        t          j        k    S )z7Return True iff `node` is of the shape ( test := test )N)r   rI   r   r   )rD   inners     rQ   is_walrus_assignmentr     s)    (..EBt/B!BBrS   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
   )
rI   r   r   r   rV   r   r   r   r   r   )rD   r   s     rQ   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'rS   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)
rI   r   r   r   powerrV   allmapr   r   r   s    rQ   is_simple_decorator_expressionr     s     yEJtyDJ= 	a %3 7qt9LMMNN &&* Q24=3D4PPP 5rS   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
   )rI   r   
yield_expris_name_tokenrg   r   r   rV   r   r   r   is_yield)rD   lparexprrpars       rQ   r   r     s    yDO##tT tzW44tyDIu
4=Qu}D$yEJ49
#:#:~~5rS   rd   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)rI   r%   rf   r   r{   )r^   rd   r   s      rQ   r~   r~     sY     y((((uAv x 	5H6VrS   c                 ,    | j         t          j        k    S )z&Return True if the node is an f-string)rI   r   fstringr   s    rQ   
is_fstringr    s    9$$rS   c                     t          |           t          | j                  d         }t          t          j        || j                  }|                                 pd|_        |S )z/Converts an fstring node back to a string node.N)rx   r   )rK   r   rx   r   r   r   
get_linenolineno)rD   string_without_prefixstring_leafs      rQ   fstring_to_stringr
    sY    IIc$+&6&6&8&89u|%:4;OOOK**/aKrS   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   )rU   r   r  r
  r   r   rg   )rD   r^   s     rQ   is_multiline_stringr    sl    $ *T"2"2  &&	D$		 uTZ((?TTZ-??rS   c                     | j         t          j        t          j        hv sJ | j        J | j        j         t          j        t          j        hv S r   )rI   r   suiter   rf   funcdefr   r   s    rQ   is_parent_function_or_classr    sF    9T%566666;""";dm<<<rS   c                 V    | j         t          j        t          j        t          j        hv S r   )rI   r   r  r   async_funcdefr   s    rQ   is_function_or_classr    s    9t}d6HIIIrS   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   )rf   r  rx   stripr   rV   rI   r   r   r   DEDENTis_stub_bodyr   s    rQ   is_stub_suiter    s    {'B4'H'Hu { u 	DMa= EM11= EL00= EL00u}Q$$&& ua()))rS   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   r^   s     rQ   r   zis_stub_body.<locals>.<genexpr>@  s3      HHUY,,,HHHHHHrS   )rU   r   rI   r   r   r   rV   rx   r  r   r   )rD   rW   s     rQ   r  r  3  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	rS   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   rb   )
rU   r   rI   r   r   rV   r   r   rg   r   )rD   firstr   s      rQ   is_atom_with_invisible_parensr  D  s     $ di!7!7u-"DM"$54E5$ 	J%*$	K2	 tT""	 I#		
 J"rS   c                 >    t          |           pt          |           S r   )is_empty_lparis_empty_rparr^   s    rQ   is_empty_parr$  V  s    5-"5"55rS   c                 B    | j         t          j        k    o
| j        dk    S Nrb   )rI   r   r   rg   r#  s    rQ   r!  r!  Z      9
"7tzR'77rS   c                 B    | j         t          j        k    o
| j        dk    S r&  )rI   r   r   rg   r#  s    rQ   r"  r"  ^  r'  rS   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.re   from)	rf   rI   rg   boolr   r   r   import_namer   )r^   r   r   r   s       rQ   	is_importr-  b  ss    A	A
A	UZ 	
(]?q?QVt/?%? BV@@af0@&@	  rS   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+  rI   r   r   rg   rf   r   	with_stmtASYNCnext_siblingr#  s    rQ   is_with_or_async_with_stmtr3  p  s    	UZ 	/J& 	/K	/ K.	  	
 
	U[  	5	5"dn4
 
	rS   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+  rI   r   r1  rf   r   
async_stmtr  r#  s    rQ   is_async_stmt_or_funcdefr6  ~  sJ     	U[  	FK	FK$2D EE  rS   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:)rI   rg   r   rh   r   
startswithr^   r   r   s      rQ   is_type_commentr:    s6    
 		A
A 233OY8O8OOrS   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.)rI   rg   r   rh   r   is_type_ignore_comment_stringr9  s      rQ   is_type_ignore_commentr=    s2    	A
A 233X8UVW8X8XXrS   rg   c                 ,    |                      d          S )zSReturn True if the given string match with type comment with
    ignore annotation.z# type: ignore)r8  )rg   s    rQ   r<  r<    s     ,---rS   )visiblerf   rW   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).
    (rb   )r   N)
r   r   r   r   rx   r   r   r   r   r   )rf   rW   r?  r   r   rx   indexr   s           rQ   wrap_in_parenthesesrD    s     
72CC33D
72CC33D\FELLLNNaETYud 344II
y)))))rS   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   rV   rI   r   r   r   )rD   r   wrappedr   s       rQ   r   r     sS     4=Qt-D'4I##	UZ(?(?tNrS   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`).
    rA  rB  N)rI   r   r   rg   r   r#  s    rQ   ensure_visiblerH    s@     yEJ


	ej	 	 


 
!	 rS   nlc                 ,    | j         t          j        k    S r   )rI   r   r   rI  s    rQ   r   r         7ej  rS   c                 ,    | j         t          j        k    S r   )rI   r   r   rK  s    rQ   is_lpar_tokenrN    rL  rS   c                 ,    | j         t          j        k    S r   )rI   r   r   rK  s    rQ   is_rpar_tokenrP    rL  rS   c                 ,    | j         t          j        k    S r   )rI   r   r   rK  s    rQ   is_number_tokenrR    s    7el""rS   )rE   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.NrE   rS  )rf   ro   rI   r   RARROWr   tname)r^   r   s     rQ   get_annotation_typerW    sg    {H

  	X%:%?5<%O%O8? 	x3tzAA7? 
 4rS   c                 6    | j         J t          |           duS )z7Returns whether this leaf is part of a type annotation.N)rf   rW  r#  s    rQ   is_part_of_annotationrY    s#    ;"""t$$D00rS   c                 v    t          | t                    r| S | j        sdS t          | j        d                   S )z,Returns the first leaf of the ancestor node.Nr   )rU   r   rV   
first_leafr   s    rQ   r[  r[    s=    $ ,] ,t$-*+++rS   c                 v    t          | t                    r| S | j        sdS t          | j        d                   S )z+Returns the last leaf of the ancestor node.Nr   )rU   r   rV   	last_leafr   s    rQ   r]  r]    s=    $ ,] ,tr*+++rS   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   )rf   rV   )r^   rD   s     rQ    furthest_ancestor_with_last_leafr_    sk    D
+ $+. 44;;OPR;S3S3S{ + $+. 44;;OPR;S3S3SKrS   )r   )F)r[   systypingr   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   r0  r  r   
match_stmt
case_blockr   r   rJ   r!   LESSGREATEREQEQUALNOTEQUAL	LESSEQUALGREATEREQUALr"   VBAR
CIRCUMFLEXAMPER	LEFTSHIFT
RIGHTSHIFTPLUSMINUSry   SLASHDOUBLESLASHPERCENTr   TILDEr   r#   r$   r%   rs   rt   r   rw   rv   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(   rV  r}   r)   r9   testlistexprlistr:   r   r   r   RSQBrm   RBRACEr;   r   keysr<   valuesr=   r>   rq   FSTRING_MIDDLEFSTRING_ENDr   r?   rU  rC   r+  rK   r   r   rp   r   r   rz   r   r   r   r   r   r   r   r   r   tupler   r   r   r   r   r~   r  r
  r  r  r  r  r  r  r$  r!  r"  r-  r3  r6  r:  r=  r<  rD  r   rH  r   rN  rP  rR  rW  rY  r[  r]  r_  r]   rS   rQ   <module>r     s     


 N N N N N N N N N N N N N N N N N N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sT s sT sc s s s sl! ! ! !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      rS   