o
    8fp                     @   sr  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#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%j0e%j1e%j2e%j3e%j4e%j5e%j6e%j7e%j8e%j9h
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jAejBejChZDee&d< ejEejFejGejHejIejJejKejLejMejNejOejPejQejRhZSee&d< ejLejRhZTee&d< eTejMhB ZUee&d< e%jVe%jWe%jXe%jYe%jZhZ[ee&d< e%j\e%j]e%j^e%j_e%j`e%jae%jbhZcee&d< e%jde%jee%jfe%jge%jhe%jie%jje%jke%jle%jme%jne%joe%jXe%jpe%jqe%jrhZsee&d< e%jte%juhZvee&d< h dZwee&d< e%jxe%j`e%jyhZzee&d < ej{ej|ej}ej~ejejiZee&d!< ee Zee&d"< ee Zee&d#< eeB Zee&d$< eeje;hB Zee&d%< d&Zed'd(G d)d* d*ee' Zd+e d,ed-ed.efd/d0Zdd2e)d3ed4ed.efd5d6Zd7ee( d.ee  fd8d9Zd7ee( d:eee+  d.efd;d<Zd7ee( d.ee+ fd=d>Zd?e!d@e(d.ee( fdAdBZdCe(dDe(d.dfdEdFZd+e d.e(fdGdHZd7e(d.ee  fdIdJZd7e(d.efdKdLZd+e d-ed.efdMdNZd7e(d.efdOdPZd7e(d.efdQdRZd7e(d.efdSdTZej{ej|ffdUe dVe dWee  dXe
e)e)f d.ef
dYdZZd7e(d.efd[d\Zdd7e(d^ed.efd_d`Zd7e(d.efdadbZd7e(d.efdcddZd+e dee	e+ d.efdfdgZd+e d.efdhdiZd7e!d.efdjdkZd7e!d.efdldmZd7e!d.efdndoZd7e(d.efdpdqZd7e(d.efdrdsZd+e d.efdtduZd+e d.efdvdwZd+e d.efdxdyZd+e d.efdzd{Zd+e d.efd|d}Zd+e d.efd~dZd+e d.efddZd+e d.efddZded.efddZd'dde!de(ded.dfddZd7e(d.ee( fddZd+e d.dfddZded.ee  fddZded.ee  fddZded.ee  fddZded.ee  fddZded.ee  fddZd+e d.ed fddZd+e d.efddZd7e(d.ee  fddZd7e(d.ee  fddZd+e d.e(fddZdS )z>
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                   @   s<   e Zd ZdZdedee fddZdedee fddZdS )	VisitorzBBasic lib2to3 visitor that yields things of type `T` on `visit()`.nodereturnc                 c   sd    |j dk rtj|j  }ntt|j }t| d| d}|r(||E dH  dS | |E dH  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)selfrE   namevisitf rQ   D/home/ertert/spirit/venv/lib/python3.10/site-packages/black/nodes.pyvisit   s   

zVisitor.visitc                 c   s0    t |tr|jD ]}| |E dH  q	dS dS )zCDefault `visit_*()` implementation. Recurses to children of `node`.N)
isinstancer   childrenrS   )rN   rE   childrQ   rQ   rR   rM      s   

zVisitor.visit_defaultN)	__name__
__module____qualname____doc__LNr   r   rS   rM   rQ   rQ   rQ   rR   rD      s    rD   leafcomplex_subscriptmoderF   c                C   sR  d}d}d}| j }| j}| j}|tv r|S |tjkr|S |dus'J d| |tjkr9|j tjtj	tj
hvr9|S | j}	|	st|}
|
rI|
j tv rK|S |tjkrd|
j tjkrX|S |
j tjkrb|sb|S |S |
j tjkr|
jr|
jj tjtjtjtjhv r}|S |
jj tjkr|
jS nl|
j tjkrt|
tjkrt|
jtj	kr|S |
j tv rt|
ttB dr|S nE|
j tjkr|
jr|
jj tjtj
hv r|r|S |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tjhv r|	r|	j tjkr
|S |S |j tjkr!|	r|	j tjkr|S |S |j tjkrR|	s-|S |tjkr=|	j t!vr;|S |S |	j tjkrG|	jS |	j tjkrP|S |S |j t!v rm|	skt|}
|
ri|
j tjkrk|S |S |j tj"kr|tj#ks|tj$kr|S |	s|tj%ks|tj&kr|S |S |	j tjkr|S |S |j tjkr|tjkr|S |	st|}
|
r|
j tj#kr|S |S |	j tjhtB v r|S |S |j tj kr|S |j tj'kr |	r|S t|}
|
r|
j tjks|
j tj%kr|S |S |j tj(kr|tj#kr|S |	r|	j tj#kr|S |S |j tjtj
hv rV|	s@|jdus4J d|jj tj	kr>|S |S |tj)ksM|	j tj)krO|S |sT|S |S |j tj*krj|	rh|tj%krh|S |S |j tj+kr|	r}|	j tj,kr}|S |S |j tjtjhv r|	st|}
|
r|
j tv r|S |
j}|dusJ |
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 |S |tj-tj.tj/hv r|S |S |j tj0kr|tj%kr|	r|	j tj%kr|S |S |tj-kr|dkr|S |	r|	j tj%kr|S |S |j tj
kr|S |j tj1k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)2rI   parentvaluerA   r   COMMENTCOLONr   	subscriptsubscriptlistsliceopprev_siblingpreceding_leafr>   COMMAEQUALarglistargument
parametersvarargslisttypedargslistprefixSTARparent_type	star_exprr'   	is_varargr(   r)   factorr%   AT	decoratorr+   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_parentrQ   rQ   rR   
whitespace   sl  



 
    ~vofcYV"JC4/*
	r   
nl_count	form_feed
empty_linec                 C   s    |r|| d  d | S ||  S )z$Generate a normalized prefix string.   rQ   )r   r   r   rQ   rQ   rR   make_simple_prefix  s   r   rE   c                 C   sR   | r'| j }|r"t|tr|S z	t| d W S  ty!   Y dS w | j} | sdS )z3Return the first leaf that precedes `node`, if any.N)rj   rT   r   listleaves
IndexErrorrc   )rE   resrQ   rQ   rR   rk     s   
rk   tokensc                 C   sJ   |sdS |d du r| 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_arerj   )rE   r   rQ   rQ   rR   r     s   r   c                 C   s   | du s	| j du rdS | j jS )z|
    Returns:
        @node.parent.type, if @node is not None and has a parent.
            OR
        None, otherwise.
    N)rc   rI   rE   rQ   rQ   rR   ru     s   ru   ancestor
descendantc                 C   s*   |}|r|j | kr|j }|r|j | ks	|S )z:Return the child of `ancestor` that contains `descendant`.)rc   )r   r   rE   rQ   rQ   rR   child_towards  s
   r   	old_child	new_childc                 C   s2   | j }|sdS |  }|dur||| 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)rc   removeinsert_child)r   r   rc   	child_idxrQ   rQ   rR   replace_child  s   r   c                 C   sr   | j }| }|r7|j}|du r	 |S |jd j |kr	 |S |jtjkr%	 |S |jdur3|jjtv r3	 |S |}|s|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   )rs   rc   rU   rI   r   
file_inputrj   r@   )r\   same_prefix	containerrc   rQ   rQ   rR   container_of  s&   	r   c                 C   s&   t | tr| S | jrt| jd S dS )z(Returns the first leaf of the node tree.r   N)rT   r   rU   first_leaf_ofr   rQ   rQ   rR   r     s
   
r   c                 C   s   | 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   rQ   rQ   rR   is_arith_like  s   r   c                 C   s   | j tjkrdS t| j}t|drdS tj|v r7| j	r7| j	j t
jkr7| j	js7| j	j	r7| j	j	j t
jkr7dS t| j	d tjtjt
jgrFdS t| j	t
jtjt
jgrTdS dS )NFbBfFT)rI   r   r   r   rd   setintersectionr   unify_docstring_detectionrc   r   simple_stmtrj   r   r   NEWLINEINDENTrp   rf   )r\   r^   rs   rQ   rQ   rR   is_docstring!  s,   

r   c                 C   s>   | j tjkot| 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   lenrU   r   r|   r}   r   rQ   rQ   rR   is_empty_tupleA  s   r   c                 C   sv   | j tjkr&t| }|du s|j tjkrdS t|jdko%|jd j tjkS | j t	v o:t| 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   rU   r   rl   r<   rE   gexprQ   rQ   rR   is_one_tupleK  s    
r   c                 C   sD   | j tjkrdS t| }|du s|j tjkrdS tdd |jD S )zDReturn True if `node` holds a tuple that contains a walrus operator.FNc                 s   s    | ]	}|j tjkV  qd S N)rI   r   namedexpr_test).0rV   rQ   rQ   rR   	<genexpr>c  s    z-is_tuple_containing_walrus.<locals>.<genexpr>)rI   r   r   r   r   anyrU   r   rQ   rQ   rR   is_tuple_containing_walrus[  s   r   openingclosingr   bracketsc           	      C   s   | j |j f|kr
dS |jd }t|D ]
\}}|| u r nqtdd}|d7 }||d D ]2}||u r9 |dk S |j}||kr`|j tjkr`|d7 }|jr`|jj tjtj	hv r`|d7 } |dk S q.|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   rl   rc   r   rn   rr   )	r   r   r   r   depth_opening_indexr\   commasr   rQ   rQ   rR   is_one_sequence_betweenf  s4   
 r   c                 C   s   t | }|duo|jtjkS )z7Return True iff `node` is of the shape ( test := test )N)r   rI   r   r   )rE   innerrQ   rQ   rR   is_walrus_assignment  s   r   Flastc                 C   s   | j tjkoTt| jdko| jd j tjko| jd j tjkpT|o9t| jdko9| jd j tjko9| jd j tj	kpT|oTt| jdkoT| jd j tjkoT| 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   rU   r   r~   r   r|   r}   )rE   r   rQ   rQ   rR   is_simple_decorator_trailer  s(   r   c                 C   sp   | j tjkrdS | j tjkr6| jr6| jd j tjko5ttt| jdd o5t	| jdk p5t| jd 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   powerrU   allmapr   r   r   rQ   rQ   rR   is_simple_decorator_expression  s   	r   c                 C   sx   | 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_tokenrd   r   r   rU   r   r|   r}   is_yield)rE   lparexprrparrQ   rQ   rR   r     s   r   ra   c                 C   s@   | 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'   rc   r   rv   )r\   ra   r   rQ   rQ   rR   rw     s   
rw   c                 C   s   t | jo	d| jv S )zKReturn True if `leaf` is a multiline string that actually spans many lines.r   )r   rd   r\   rQ   rQ   rR   is_multiline_string  s   r   c                 C   s8   | j tjtjhv sJ | jd usJ | jj tjtjhv S r   )rI   r   suiter   rc   funcdefr   r   rQ   rQ   rR   is_parent_function_or_class  s   r   c                 C   s   | j tjtjtjhv S r   )rI   r   r   r   async_funcdefr   rQ   rQ   rR   is_function_or_class     r   c                 C   s   | j durt| sdS | j rdS t| jdks4| jd jtjks4| jd jtj	ks4| jd jtj
kr6d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   )rc   r   rs   stripr   rU   rI   r   r   r   DEDENTis_stub_bodyr   rQ   rQ   rR   is_stub_suite  s   
r   c                 C   sp   t | tr| jtjkrdS t| jdkrdS | jd }|j  o7|jtj	ko7t|jdko7t
dd |jD S )zCReturn True if `node` is a simple statement containing an ellipsis.Fr   r   r   c                 s   s     | ]}|t tjd kV  qdS ).N)r   r   r~   )r   r\   rQ   rQ   rR   r   #  s    zis_stub_body.<locals>.<genexpr>)rT   r   rI   r   r   r   rU   rs   r   r   r   )rE   rV   rQ   rQ   rR   r     s   

r   c                 C   sp   t | ts| jtjkrdS | jd | jd }}t |to7|jtjko7|jdko7t |to7|jtj	ko7|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   r_   )
rT   r   rI   r   r   rU   r   r|   rd   r}   )rE   firstr   rQ   rQ   rR   is_atom_with_invisible_parens'  s   


r   c                 C   s   t | pt| S r   )is_empty_lparis_empty_rparr   rQ   rQ   rR   is_empty_par9  s   r   c                 C      | j tjko
| jdkS Nr_   )rI   r   r|   rd   r   rQ   rQ   rR   r   =  r   r   c                 C   r   r   )rI   r   r}   rd   r   rQ   rQ   rR   r   A  r   r   c                 C   sP   | j }| j}| j}t|tjko&|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.rb   from)	rc   rI   rd   boolr   r   r   import_namer   )r\   r   r   r   rQ   rQ   rR   	is_importE  s   
r   c                 C   sR   t | jtjko| jdko| jo| jjtjkp(t | 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   rd   rc   r   	with_stmtASYNCnext_siblingr   rQ   rQ   rR   is_with_or_async_with_stmtS  s   r  c                 C   s*   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   r  rc   r   
async_stmtr   r   rQ   rQ   rR   is_async_stmt_or_funcdefa  s   r  c                 C   s$   | 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   rd   r   re   r    
startswithr\   r   r   rQ   rQ   rR   is_type_commentn  s   r  c                 C   s"   | j }| j}|tjthv ot|S )zGReturn True if the given leaf is a type comment with ignore annotation.)rI   rd   r   re   r    is_type_ignore_comment_stringr  rQ   rQ   rR   is_type_ignore_commentx  s   r
  rd   c                 C   s
   |  dS )zSReturn True if the given string match with type comment with
    ignore annotation.z# type: ignore)r  )rd   rQ   rQ   rR   r	    s   
r	  )visiblerc   rV   r  c                C   sh   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).
    (r_   )r   N)
r   r   r|   r}   rs   r   r   r   r   r   )rc   rV   r  r   r   rs   indexr   rQ   rQ   rR   wrap_in_parentheses  s   r  c                 C   s>   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   rU   rI   r   r|   r}   )rE   r   wrappedr   rQ   rQ   rR   r     s   r   c                 C   s0   | 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`).
    r  r  N)rI   r   r|   rd   r}   r   rQ   rQ   rR   ensure_visible  s
   

r  nlc                 C      | j tjkS r   )rI   r   r   r  rQ   rQ   rR   r        r   c                 C   r  r   )rI   r   r|   r  rQ   rQ   rR   is_lpar_token  r  r  c                 C   r  r   )rI   r   r}   r  rQ   rQ   rR   is_rpar_token  r  r  c                 C   r  r   )rI   r   r   r  rQ   rQ   rR   is_string_token  r  r  c                 C   r  r   )rI   r   r   r  rQ   rQ   rR   is_number_token  r  r  )rF   paramNc                 C   sP   | j }|dur&|jr|jjtjkrdS |j r|j jtjkrdS |j }|dusdS )z<Returns the type of annotation this leaf is part of, if any.NrF   r  )rc   rj   rI   r   RARROWr   tname)r\   r   rQ   rQ   rR   get_annotation_type  s   r  c                 C   s   t | duS )z7Returns whether this leaf is part of a type annotation.N)r  r   rQ   rQ   rR   is_part_of_annotation  s   r  c                 C   &   t | tr| S | jsdS t| jd S )z,Returns the first leaf of the ancestor node.Nr   )rT   r   rU   
first_leafr   rQ   rQ   rR   r     
   
r   c                 C   r  )z+Returns the last leaf of the ancestor node.Nr   )rT   r   rU   	last_leafr   rQ   rQ   rR   r"    r!  r"  c                 C   sJ   | }|j r#|j jr#||j jd u r#|j }|j r#|j jr#||j jd u s|S )zGReturns the furthest ancestor that has this leaf node as the last leaf.r   )rc   rU   )r\   rE   rQ   rQ   rR    furthest_ancestor_with_last_leaf  s
   r#  )r   )F)rZ   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   r   r   r   
match_stmt
case_blockr   r    rJ   r#   LESSGREATEREQEQUALNOTEQUAL	LESSEQUALGREATEREQUALr$   VBAR
CIRCUMFLEXAMPER	LEFTSHIFT
RIGHTSHIFTPLUSMINUSrt   SLASHDOUBLESLASHPERCENTry   TILDEr   r%   r&   r'   rn   ro   r{   rr   rq   r(   r   r   	listmakerr   testlist_star_exprsubject_exprpatternr)   testlambdefor_testand_testnot_test
comparisonrv   r   r   r   r   r   termr   r   r*   r  
tname_starr+   r;   testlistexprlistr<   r|   r}   r   RSQBLBRACERBRACEr=   r   keysr>   valuesr?   r@   rl   rA   r  rD   r   rK   r   r   rk   r   ru   r   r   r   r   r   r   r   r   r   r   r   r   r   r   rw   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#  rQ   rQ   rQ   rR   <module>   sF   0


	
" j"

 



%
 

