
    ɭde                        d dl Z d dlZd dlmZmZ d dlmZmZmZm	Z	m
Z
mZmZmZmZmZ d dlmZmZmZ d dlmZmZ d dlmZmZmZmZmZmZmZmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z( d dl)m*Z* d dl+m,Z, d d	l-m.Z.m/Z/  ed
          Z0e1Z2e1Z3ee.e/f         Z4e G d d                      Z5e G d d                      Z6e G d d                      Z7e G d d                      Z8dee0         deee2e0f                  fdZ9	 d+de5de5de	e.         de:ddf
dZ;ddde5ded e<de:fd!Z=de5de:fd"Z>d#e6d$e1de:fd%Z?de5d&e.d$e1de:fd'Z@de5d(e.d$e1de:fd)ZAde5de<fd*ZBdS ),    N)	dataclassfield)
CallableDictIteratorListOptionalSequenceTupleTypeVarUnioncast)COMMA_PRIORITYDOT_PRIORITYBracketTracker)ModePreview)BRACKETSCLOSING_BRACKETSOPENING_BRACKETSSTANDALONE_COMMENTTEST_DESCENDANTSchild_towardsis_docstring
is_funcdef	is_importis_multiline_stringis_one_sequence_betweenis_type_commentis_type_ignore_commentis_with_or_async_with_stmtreplace_childsyms
whitespace)	str_width)token)LeafNodeTc            	          e Zd ZU dZ ed          Zeed<   dZe	ed<    ee
          Zee         ed<    ee          Zeeee         f         ed	<    ee          Zeed
<   dZeed<   dZeed<   dZee         ed<   	 d5dedededdfdZd6dededdfdZedefd            Zedefd            Zedefd            Zedefd            Zedefd            Z edefd            Z!edefd            Z"edefd            Z#edefd            Z$edefd            Z%edefd            Z&dd d!ee'egef                  defd"Z(defd#Z)defd$Z*defd%Z+defd&Z,defd'Z-	 d6d(ed)edefd*Z.d+edefd,Z/dedee         fd-Z0d7d.Z1dedefd/Z2	 d6d0ede3e4e5ee	f                  fd1Z6d8d2Z7de8fd3Z9defd4Z:dS )9Linez;Holds leaves and comments. Can be printed with `str(line)`.F)reprmoder   depthdefault_factoryleavescommentsbracket_trackerinside_bracketsshould_split_rhsNmagic_trailing_commaleafpreformattedtrack_bracketreturnc                    |j         t          v p%t          |j                                                  }|sdS t
          j        |j         k    r| j        r
| j        dd= | j        r:|s8|xj	        t          ||                     |          | j                  z  c_	        | j        s|r|rn| j                            |           | j        j        r|                     |          r|| _        n+|                     |d          r|                                  |                     |          s| j                            |           dS dS )ag  Add a new `leaf` to the end of the line.

        Unless `preformatted` is True, the `leaf` will receive a new consistent
        whitespace prefix and metadata applied by :class:`BracketTracker`.
        Trailing commas are maybe removed, unpacked for loop variables are
        demoted from being delimiters.

        Inline comments are put aside.
        N)complex_subscriptr-   T)ensure_removable)typer   boolvaluestripr&   COLONis_class_paren_emptyr1   prefixr$   is_complex_subscriptr-   r4   r3   markr6   has_magic_trailing_commaremove_trailing_commaappend_commentappend)selfr7   r8   r9   	has_values        +lib/python3.11/site-packages/black/lines.pyrK   zLine.append?   sq    I)ET$*2B2B2D2D-E-E	 	F;$)##(A#BCC ; 	| 	 KK:"&";";D"A"AY   KK
  	-| 	-} 	- %%d+++y- -0066 504D-..td.KK -**,,,""4(( 	%Kt$$$$$	% 	%    c                     | j         j        dk    s| j                                         r<| j        rt	          d          | j        r|j        t          k    rt	          d          |                     ||           dS )zLike :func:`append()` but disallow invalid standalone comment structure.

        Raises ValueError when any `leaf` is appended after a standalone comment
        or when a standalone comment is not the first leaf on the line.
        r   z$cannot append to standalone commentsz5cannot append standalone comments to a populated liner8   N)	r3   r.   any_open_for_or_lambda
is_comment
ValueErrorr1   r?   r   rK   )rL   r7   r8   s      rN   append_safezLine.append_safec   s      &!++#::<< ,  I !GHHH{ ty,>>> K   	D|44444rO   c                 h    t          | j                  dk    o| j        d         j        t          k    S )z"Is this line a standalone comment?   r   )lenr1   r?   r   rL   s    rN   rS   zLine.is_commentw   s-     4;1$RQ)<@R)RRrO   c                 `    t          |           o| j        d         j        t          j        k    S )zIs this line a decorator?r   )r@   r1   r?   r&   ATrY   s    rN   is_decoratorzLine.is_decorator|   s%     Dzz=dk!n1UX==rO   c                 T    t          |           ot          | j        d                   S )zIs this an import line?r   )r@   r   r1   rY   s    rN   r   zLine.is_import   s#     Dzz7iA777rO   c                 T    t          |           ot          | j        d                   S )zIs this a with_stmt line?r   )r@   r!   r1   rY   s    rN   r!   zLine.is_with_or_async_with_stmt   s$     DzzH8QHHHrO   c                     t          |           o5| j        d         j        t          j        k    o| j        d         j        dk    S )z Is this line a class definition?r   class)r@   r1   r?   r&   NAMErA   rY   s    rN   is_classzLine.is_class   s@     JJ 0A#uz10A$/	
rO   c                 d    | j         o)| j        dd         d t          d          D             k    S )zEIs this line a class definition with a body consisting only of "..."?Nc                 B    g | ]}t          t          j        d           S .r'   r&   DOT.0_s     rN   
<listcomp>z&Line.is_stub_class.<locals>.<listcomp>   s1     6
 6
 6
%&DC  6
 6
 6
rO      )rb   r1   rangerY   s    rN   is_stub_classzLine.is_stub_class   sG     } 
RSS!1 6
 6
*/((6
 6
 6
 "
 	
rO   c                 6   	 | j         d         }n# t          $ r Y dS w xY w	 | j         d         }n# t          $ r d}Y nw xY w|j        t          j        k    r|j        dk    p8|j        t          j        k    o#|duo|j        t          j        k    o
|j        dk    S )zBIs this a function definition? (Also returns True for async defs.)r   FrW   Ndef)r1   
IndexErrorr?   r&   ra   rA   ASYNC)rL   
first_leafsecond_leafs      rN   is_defzLine.is_def   s    	QJJ 	 	 	55		*.+a.KK 	 	 	KKK	5:-K*2Be2K 
Ou{* +4'+ EJ.+ !U*		
s    
0 ??c                     | j         oE| j        dd         t          t          j        d          gd t          d          D             z   k    S )zHIs this line a function definition with a body consisting only of "..."?N:c                 B    g | ]}t          t          j        d           S rf   rh   rj   s     rN   rm   z$Line.is_stub_def.<locals>.<listcomp>   s7     O
 O
 O
%&DC  O
 O
 O
rO   rn   )rw   r1   r'   r&   rC   ro   rY   s    rN   is_stub_defzLine.is_stub_def   sb     { 
t{233/Dc4J4J3K O
 O
*/((O
 O
 O
 4
  
 	
rO   c                 6   t          |           ot          | j                  dk    or| j        ok| j        d         j        t
          j        k    oK| j        d         j        dk    o5| j        d         j        t
          j        k    o| j        d         j        dk    S )zzIs this a class with no base classes but using parentheses?

        Those are unnecessary and should be removed.
              (rn   ))	r@   rX   r1   rb   r?   r&   LPARrA   RPARrY   s    rN   rD   zLine.is_class_paren_empty   s     JJ ,DK  A%,, A#uz1, A$+	,
 A#uz1, A$+	
rO   c                     | r | j         d         j        t          j        k    rdS | j         d         j        }|                    d          rdS t          j        | j        v r|                    d          rdS dS )z#Is the line a triple quoted string?r   F)z"""z'''T)zr'''zr"""zR'''zR""")	r1   r?   r&   STRINGrA   
startswithr   accept_raw_docstringsr-   )rL   rA   s     rN   is_triple_quoted_stringzLine.is_triple_quoted_string   s      	t{1~*el::5A$N++ 	4(DI55%:J:J,;
 ;
5 4urO   c                 v    t          | j                  dk    rdS | j        d         j        t          j        k    S )z/Does this line open a new level of indentation.r   F)rX   r1   r?   r&   rC   rY   s    rN   opens_blockzLine.opens_block   s4     t{q  5{2#u{22rO   first_leaf_matchesr   c                    t          | j                  dk    rdS | j        d         }|j        t          k    s|j        dS |du p ||j                  S )zIs this line converted from fmt off/skip code?

        If first_leaf_matches is not None, it only returns True if the first
        leaf of converted code matches.
        rW   Fr   N)rX   r1   r?   r   fmt_pass_converted_first_leaf)rL   r   r7   s      rN   is_fmt_pass_convertedzLine.is_fmt_pass_converted   sm     t{q  5{1~I+++195!T) 
-?-?..
 .
 	
rO   c                 @    | j         D ]}|j        t          k    r dS dS )z)If so, needs to be split before emitting.TF)r1   r?   r   rL   r7   s     rN   contains_standalone_commentsz!Line.contains_standalone_comments   s4    K 	 	Dy...tt / urO   c                     t          j        | j        d           D ]W\  }}|t          j        k    rt          |          }t          |          dk    r9|D ]}|                     |          r  dS XdS )zFChck if we have an implicit multiline string with comments on the linec                     | j         S N)r?   )r7   s    rN   <lambda>zGLine.contains_implicit_multiline_string_with_comments.<locals>.<lambda>   s    di rO   rW   TF)	itertoolsgroupbyr1   r&   r   listrX   comments_after)rL   	leaf_typeleaf_group_iterator	leaf_listr7   s        rN   0contains_implicit_multiline_string_with_commentsz5Line.contains_implicit_multiline_string_with_comments   s    .7.?K///
 /
 
	  
	 *I* EL((011I9~~""!    &&t,,  444   urO   c                    t                      }	 | j        d         }|                    t          |                     |j        t
          j        k    s|j        t
          j        k    r6|j        s/| j        d         }|                    t          |                     n# t          $ r Y dS w xY wd}| j
                                        D ]4\  }}|D ],}t          |          r|st          |          s||vr  dS d}-5dS )Nr   r<   FT)setr1   addidr?   r&   COMMAr   rA   rs   r2   itemsr   r    )rL   ignored_ids	last_leafcomment_seenleaf_idr2   comments          rN   $contains_uncollapsable_type_commentsz)Line.contains_uncollapsable_type_comments  s'   ee	BIOOByMM***~,,%*,,Y_, !KO	9... 	 	 	55	 !%!4!4!6!6 		$ 		$GX# $ $"7++ $# $27;;$#;66#ttt#$ us   BB   
B.-B.c                 Z   | j         sdS t          d | j         D             d          }t          d t          | j                   D             d          }||k    rP| j         dd          D ]@}| j                            t          |          g           D ]}t          |          r  dS AdS )NFc              3   :   K   | ]}|j         d k    |j         V  dS r   Nlinenork   r7   s     rN   	<genexpr>z9Line.contains_unsplittable_type_ignore.<locals>.<genexpr>:  s1      SS4$+QRBRBR4;BRBRBRBRSSrO   r   c              3   :   K   | ]}|j         d k    |j         V  dS r   r   r   s     rN   r   z9Line.contains_unsplittable_type_ignore.<locals>.<genexpr><  s0      OOTdkQ>N>NT[>N>N>N>NOOrO   r<   T)r1   nextreversedr2   getr   r    )rL   
first_line	last_linenoder   s        rN   !contains_unsplittable_type_ignorez&Line.contains_unsplittable_type_ignore)  s    { 	5 SS4;SSSUVWW
OOXdk%:%:OOOQR
 
	 "" BCC( $ $#}00D2>> $ $G-g66 $#ttt$$ urO   c                 >    t          d | j        D                       S )Nc              3   4   K   | ]}t          |          V  d S r   )r   r   s     rN   r   z2Line.contains_multiline_strings.<locals>.<genexpr>K  s+      EE&t,,EEEEEErO   )anyr1   rY   s    rN   contains_multiline_stringszLine.contains_multiline_stringsJ  s!    EEEEEEEErO   closingr>   c                    |j         t          v r'| j        r | j        d         j         t          j        k    sdS |j         t          j        k    rdS |j         t          j        k    r_|j        V|j        j         t          j	        k    r<|j
        5t          |j
        || j        t          j        t          j        f          rdS dS | j        rdS |j
        t          |j
        || j                  sdS dS )aT  Return True if we have a magic trailing comma, that is when:
        - there's a trailing comma here
        - it's not a one-tuple
        - it's not a single-element subscript
        Additionally, if ensure_removable:
        - it's not from square bracket indexing
        (specifically, single-element square bracket indexing)
        r   FTN)brackets)r?   r   r1   r&   r   RBRACERSQBparentr#   traileropening_bracketr   LSQBr   )rL   r   r>   s      rN   rH   zLine.has_magic_trailing_commaM  s     L,,, -B$335<5<''4<5:%%*N'4<77+7++K#j%*5	   8 u4> 	4".7N#Wdk8
 8
. 4urO   r   c                    |j         t          k    r"| j                                        r	d|_        dS |j         t
          j        k    rdS | j        st          |_         d|_        dS | j        d         }|j         t
          j        k    r|j	        s|j
        rt          t          |j
                                                            dk    rIt          |          s:t          | j                  dk     rt          |_         d|_        dS | j        d         }| j                            t!          |          g                               |           dS )z0Add an inline or standalone comment to the line. Fr   rn   r   r<   T)r?   r   r3   any_open_bracketsrE   r&   COMMENTr1   r   rA   r   rX   r   r   r2   
setdefaultr   rK   )rL   r   r   s      rN   rJ   zLine.append_comment|  s9    L...$6688 /  GN5<5=((5{ 	-GLGN5KO	Nej((O )  ) D)0022334499#G,, : 4;!##1!#uBI  I33::7CCCtrO   c                 R    | j                             t          |          g           S )z;Generate comments that should appear directly after `leaf`.)r2   r   r   r   s     rN   r   zLine.comments_after  s     }  D2...rO   c                    | j                                         }| j                            t          |          g           }| j                            t          | j         d                   g                               |           dS )z@Remove the trailing comma and moves the comments attached to it.r   N)r1   popr2   r   r   extend)rL   trailing_commatrailing_comma_commentss      rN   rI   zLine.remove_trailing_comma  sx    **"&-"3"3B~4F4F"K"K  DKO!4!4b99@@#	
 	
 	
 	
 	
rO   c                 J   | j                                         }|dS |j        }t          |t                    r<|j        t          j        k    rdS |j        t          j        k    rt          ||          }|duo*t          d |                                D                       S )zAReturn True iff `leaf` is part of a slice with non-trivial exprs.NFc              3   2   K   | ]}|j         t          v V  d S r   )r?   r   )rk   ns     rN   r   z,Line.is_complex_subscript.<locals>.<genexpr>  s;       3
 3
+,AF&&3
 3
 3
 3
 3
 3
rO   )r3   get_open_lsqbnext_sibling
isinstancer(   r?   r#   	listmakersubscriptlistr   r   	pre_order)rL   r7   	open_lsqbsubscript_starts       rN   rF   zLine.is_complex_subscript  s    (6688	5#0ot,, 	G#t~55u#t'999"/"F"Fd* 
s 3
 3
0?0I0I0K0K3
 3
 3
 0
 0
 	
rO   r   c              #     K   t          t          t          t                   gt          t
          t          t          f                  f         |rt          nt                    } || j	                  D ]p\  }}t          |j                  t          |j                  z   }d|j        v r dS |                     |          D ]}|t          |j                  z  }|||fV  qdS )zReturn an enumeration of leaves with their length.

        Stops prematurely on multiline strings and standalone comments.
        
N)r   r   r
   r'   r   r   Indexenumerate_reversed	enumerater1   rX   rE   rA   r   )rL   r   opindexr7   lengthr   s          rN   enumerate_with_lengthzLine.enumerate_with_length  s       htn%xeTk0B'CCD"*9	
 
 2dk?? 	& 	&KE4%%DJ7Ftz!!..t44 - -#gm,,,v%%%%%	& 	&rO   c                 \    t          | j        | j        | j        | j        | j                  S )N)r-   r.   r4   r5   r6   )r+   r-   r.   r4   r5   r6   rY   s    rN   clonez
Line.clone  s5    * 0!2!%!:
 
 
 	
rO   c                 V   | sdS d| j         z  }t          | j                  }t          |          }|j         | |j         }|D ]}|t          |          z  }t          j        	                    | j
                                                  D ]}|t          |          z  }|dz   S )zRender the line.r   z    )r.   iterr1   r   rE   rA   strr   chainfrom_iterabler2   values)rL   indentr1   firstresr7   r   s          rN   __str__zLine.__str__  s     	4$*$dk""V4v4u{44 	 	D3t99CC 44T]5I5I5K5KLL 	  	 G3w<<CCTzrO   c                 8    t          | j        p| j                  S )z/Return True if the line has leaves or comments.)r@   r1   r2   rY   s    rN   __bool__zLine.__bool__  s    DK04=111rO   )FFF)r:   N)r:   r+   );__name__
__module____qualname____doc__r   r-   r   __annotations__r.   intr   r1   r   r'   dictr2   r   LeafIDr   r3   r4   r@   r5   r6   r	   rK   rU   propertyrS   r\   r   r!   rb   rp   rw   r|   rD   r   r   r   r   r   r   r   r   r   rH   rJ   r   rI   rF   r   r   r   r   r   r   r   r    rO   rN   r+   r+   1   s        EEE"""D$"""E3NNNt444FDJ444).t)D)D)DHd64:%&DDD&+eN&K&K&KO^KKK!OT!!!"d"""+/(4./// MR"% "%"%(,"%EI"%	"% "% "% "%H5 5 5D 5T 5 5 5 5( SD S S S XS >d > > > X> 84 8 8 8 X8 ID I I I XI 
$ 
 
 
 X
 
t 
 
 
 X
 
 
 
 
 X
$ 
T 
 
 
 X
 
d 
 
 
 X
     X 3T 3 3 3 X3 IM
 
 
%-hvt|.D%E
	
 
 
 
(d    $    "d " " " "H4    BFD F F F F 7<- --/3-	- - - -^#d #t # # # #J/4 /DJ / / / /
 
 
 

 
$ 
 
 
 
&  %& &&	%tS()	*& & & &*
 
 
 
     2$ 2 2 2 2 2 2rO   r+   c                   F    e Zd ZU dZeed<   eed<   eed<   eed<   eed<   dS )	RHSResultz2Intermediate split result from a right hand split.headbodytailr   closing_bracketN)r   r   r   r   r+   r   r'   r   rO   rN   r  r    sK         <<
JJJ
JJJ
JJJrO   r  c                       e Zd ZU dZeed<   ed          ed<   eed<   dZe	ed<    e
e          Zee         ed<   dZe	ed	<   d
ee         fdZdS )
LinesBlockzClass that holds information about a block of formatted lines.

    This is introduced so that the EmptyLineTracker can look behind the standalone
    comments and adjust their empty lines for class or def lines.
    r-   previous_blockoriginal_liner   beforer/   content_linesafterr:   c                     t          t          | j                            }|| j        z  g| j        z   || j        z  gz   S )N)r-   )r   r+   r-   r
  r  r  )rL   
empty_lines     rN   	all_lineszLinesBlock.all_lines  sE    49---..
$+%&);;zDJ?V>WW	
rO   N)r   r   r   r   r   r   r	   r+   r
  r   r   r   r  r   r   r  r  r   rO   rN   r  r    s           JJJ\****FCOOO$uT:::M49:::E3NNN
49 
 
 
 
 
 
rO   r  c            
           e Zd ZU dZeed<   dZee         ed<   dZ	ee
         ed<    ee          Zee         ed<   dZee
         ed<   d	ed
e
fdZd	ed
eeef         fdZd	ededed
eeef         fdZdS )EmptyLineTrackera{  Provides a stateful method that returns the number of potential extra
    empty lines needed before and after the currently processed line.

    Note: this tracker works on lines that haven't been split yet.  It assumes
    the prefix of the first leaf consists of optional newlines.  Those newlines
    are consumed by `maybe_empty_lines()` and included in the computation.
    r-   Nprevious_liner  r/   previous_defssemantic_leading_commentcurrent_liner:   c                 8   |                      |          \  }}| j        r| j        j        nd}| j        dn||z
  }t          j        |j        v rV| j        rO| j        j        Ct          | j        j        j	                  dk    r!| j        j        j
        r|j        s	|j        sd}t          | j        | j        |||          }|j        r2| j        #| j        j        s| j        j        r|r| j        |r|| _        n|j        r|rd| _        || _        || _        |S )zReturn the number of extra empty lines before and after the `current_line`.

        This is for separating `def`, `async def` and `class` with extra empty
        lines (two on module-level).
        r   NrW   )r-   r  r	  r
  r  )_maybe_empty_linesr  r  r  r   module_docstring_newlinesr-   rX   r	  r1   r   rb   rw   r  rS   r\   r  )rL   r  r
  r  previous_afterblocks         rN   maybe_empty_linesz"EmptyLineTracker.maybe_empty_lines#  sy    //==6:6IP,22q
 !) A.( 	 -1BBB# C#2:D'5<==BB#1I C!* C.:.A C F.&
 
 
 " 
	1!)&3 * +6 * ;A * 2:f:05-* 	1f 	1,0D))#rO   c                    d}|j         dk    r| j        j        rdnd}|j        r?|j        d         }|j                            d          }t          ||          }d|_        nd}t          |          }|j         }d }| j        rL| j        d         j         |k    r6| j        	                                }| j        r| j        d         j         |k    6|| j
        J | j        j        rH|r|j        s| j
        j        r|rdnd}nst          j        | j        v r|j        r
|j        sd}nO|rd}nJd}nG|rd}nB|s>|j         r7|j        d         j        t"          j        k    r|j        d         j        dvrd}nd}|j        s|j        s|j        r|                     |||          S | j
        rD| j
        j        r8|j        s1|                    t,                    s|| j
        j         k    r|pddfS | j
        r,| j
        j        r |j        rt          j        |j        v rd	S |dfS t          j        |j        v o|j        d         j        t6          k    pu|j        pnt;          |j        d                   oT| j
        oM| j
        j        d         o;| j
        j        d         j        o$t?          | j
        j        d         j                   }| j
        r| j
        j        r|sd
S |dfS )NrW   r   r   r   r   r   )withtryforwhileifmatchr   r   rW   r   r   ) r.   r-   is_pyir1   rE   countminr@   r  r   r  rw   r   "blank_line_after_nested_stub_classrb   rp   r?   r&   rC   rA   r\   #_maybe_empty_lines_for_class_or_defr   r   r   $no_blank_line_before_class_docstring2allow_empty_first_line_before_new_block_or_commentr   r   r   r   r   )	rL   r  max_allowedru   r
  user_had_newliner.   previous_defis_empty_first_line_oks	            rN   r  z#EmptyLineTracker._maybe_empty_linesU  s   ""#y/6!!QK 	%,Q/J&,,T22F--F "JF<<"  	4T%7%;%AU%J%J-1133L   	4T%7%;%AU%J%J #%111y # !4 9K9R "29QQFF>$)KK$- L(6 L FF FFFF FF$* %+B/4CC$+A.4MN N FFF$ 	(; 	|?T 	;;f&6  
 	$",	$ !*	$ !66)6TT		$
 +111Ka!## 	"+	 4	
 ;|?PPPt19 F !  #A&+/AA 
+

 !!4Q!788 L*L*1!4L *1!4;L 't'9'@'C'JKKK 	( 	".	 +	
 4qyrO   r
  r-  c                 X   |j         s| j                            |           | j        dS | j        j         r| j        j        r	|j        rdS dS | j        j        |j        k     r| j        j        s| j        j	        rdS d }| j        j
        r]| j        j        |j        k    rH|dk    rB| j        }|7|j        0|j        j        j        s|j        j        j        s|j        dk    r|}ndS | j        j        r|j        s| j        j        rI| j        j        |j        k     rd}n| j        j        |j        k    rd}n|j        r| j        j        rd}nd}nt           j        |j        v r| j        j        |j        k    rd}n~|j	        s|j         r'| j        j	        s|j        rt%          d|          }nLd}nI| j        j        |j        k    rd}n1d}n.|j        rdnd}t           j        | j        v r| j        j        r|sd}|-|j        }|$t+          |j        |          |j        z
  |_        d}|dfS )Nr$  r#  r   rW   r   )r\   r  rK   r  r-   r%  rp   r.   rb   rw   rS   r  r  r	  r   r
  r   +blank_line_between_nested_and_def_stub_filer'  dummy_implementationsr|   maxr  )rL   r  r
  r-  comment_to_add_newlinesslcnewlinesr  s           rN   r)  z4EmptyLineTracker._maybe_empty_lines_for_class_or_def  s    ( 	4%%l333%4* 	y L$> t4#l&888' 9+/+=+D 9 48<)	"(L,>>>!/C&2*8A 3*8D 3 J!OO*-''t9 .	$ #(:(C #%+l.@@@ HH'-0BBB HH!/ !D4F4T ! HH HH C|GXXX&,|/AAA#'3'@(/  % !  #1f~~HH  !HH#)L,>>>(.5qqAH -::&2 ;( ; ".4CN)/6AANDXX (. {rO   )r   r   r   r   r   r   r  r	   r+   r  r  r   r   r  r   r  r  r   r   r  r@   r)  r   rO   rN   r  r    s%          JJJ$(M8D>(((+/NHZ(/// %d ; ; ;M4:;;;59hz29990d 0z 0 0 0 0dkt kc3h k k k kZ] ]*-]AE]	sCx] ] ] ] ] ]rO   r  sequencer:   c              #   h   K   t          |           dz
  }t          |           D ]}||fV  |dz  }dS )z;Like `reversed(enumerate(sequence))` if that were possible.rW   N)rX   r   )r7  r   elements      rN   r   r   "  sS      MMAEH%%  g
 rO   Fnew_lineold_liner1   r8   c                     |D ]r}t          |j        |j                  }t          ||           |                     ||           |                    |          D ]}|                     |d           sdS )a  
    Append leaves (taken from @old_line) to @new_line, making sure to fix the
    underlying Node structure where appropriate.

    All of the leaves in @leaves are duplicated. The duplicates are then
    appended to @new_line and used to replace their originals in the underlying
    Node structure. Any comments attached to the old leaves are reattached to
    the new leaves.

    Pre-conditions:
        set(@leaves) is a subset of set(@old_line.leaves).
    rQ   TN)r'   r?   rA   r"   rK   r   )r:  r;  r1   r8   old_leafnew_leafcomment_leafs          rN   append_leavesr@  *  s      = =x~66h)))|<<<$33H== 	= 	=LOOLtO<<<<	== =rO   r   )line_strliner-   rA  c                z   |st          |           }|j        rt          nt          }t          j        |vr- ||          |j        k    od|vo|                                  S |                                 rdS d|vr ||          |j        k    S |                    d          ^}}} ||          |j        k    s ||          |j        k    rdS g }d}g }	t          j
        }
t          | j                  D ]\  }}|
t          j
        k    rd}|j        dz   t          |          k    r|                    d           n/|j        dz   t          |          k     r|                                }|%|#|j        |j        dz   k    r|j        }
|dk    r dS |j        |
k    rV|j        t"          j        k    rAdg}||	z  }|j        |v r|t          | j                  dz
  k    s||j        xx         dz  cc<   |
t          j
        k    rt)          |
|j                  }
t+          |          r`t          |	          dk    r dS |}|}t-          |          |v r5|	                    |           |j        n|j        }t-          |          |v 5t          |	          dk    rdS t1          d |D                       S )a  For non-multiline strings, return True if `line` is no longer than `line_length`.
    For multiline strings, looks at the context around `line` to determine
    if it should be inlined or split up.
    Uses the provided `line_str` rendering, if any, otherwise computes a new one.
    r   FNrW   r   Tc              3   "   K   | ]
}|d k    V  dS r   r   )rk   vals     rN   r   z'is_line_short_enough.<locals>.<genexpr>  s&      **Csax******rO   )line_to_stringpreviewr%   rX   r   multiline_string_handlingline_lengthr   splitmathinfr   r1   bracket_depthrK   r   r?   r&   r   prev_siblingr'  r   r   r   all)rB  r-   rA  widthr   rl   lastcommasmultiline_stringmultiline_string_contextsmax_level_to_updateir7   	had_commaignore_ctxsctxs                   rN   is_line_short_enoughrZ  B  s#     (!$''.II3E(44E(OOt// 8H$855777	
 ((** u8uX$"222nnT**OEAtuU||d&&&%%++8H*H*Hu F'+*,-1XT[)) '! '!4$(**'+I!A%F33a    #a'#f++55"JJLL	%$0$2d6H16LLL '+&8#q== 55!444ek9Q9Q 04fK44K%44c$+>N>NQR>R9R9Rt)***a/***$(**"%&94;M"N"Nt$$ 	!,--11uu#Cc((h&&)00555:%j	 c((h&& $%%**t**6******rO   c                    | j         }t          |          dk     rdS |d         j        t          j        k    r|d         j        t          j        k    rd}d}|d         }|ddd         D ]}|j        t          v r|j        t          vr dS |dz  }nh|j        t          j        k    r|dz  }nM|j        t          j        k    r'|j        t          j        k    s|j        t          v s dS n|j        t          vr dS |dk    r	|dk    r dS dS )	zReturn False if the line cannot be split *for sure*.

    This is not an exhaustive search but a cheap heuristic that we can use to
    avoid some unfortunate formattings (mostly around wrapping unsplittable code
    in unnecessary parentheses).
    r   Fr   rW   r   r<   NT)	r1   rX   r?   r&   r   ri   r   r   ra   )rB  r1   
call_count	dot_countr   r7   s         rN   can_be_splitr^    s    [F
6{{Quay~%%&).EI*E*E
	bz26r6N 	 	Dy,,,9$444 55a

ei''Q		ej((	UY..$)?O2O2O 55"222uu1}}auu4rO   rhsrI  c                    | j         }d}t          |j                  D ]K}|r||j        u rd}|j        t
          k    r|s dS |s%|j        t          v r|j        |j        v r	|j        r|}L|j        }|j	        sdS |
                                }|                    |          }|dk    rdS |dk    r,t          j        |j        v r|t          k    r| j        j        rdS |t$          k    rdS t'          |j                  dk    s
J d            |j        d         }|j        d         }	|j        t(          v r"|	j        t          vrt+          |||          rdS |j        d	         }
|j        d
         }|j        t,          j        k    sK|j        t,          j        k    s6|j        t,          j        k    rV|j        rO|j        j        t6          j        k    r5|
j        t(          v rdS t;          |          rdS t=          |||          rdS dS )a  Does `rhs.body` have a shape safe to reformat without optional parens around it?

    Returns True for only a subset of potentially nice looking formattings but
    the point is to not return false positives that end up producing lines that
    are too long.
    NFTrW   r   zStranded delimiterr   )r   rI  r<   r   )rQ  rI  )r  r   r1   r   r?   r   r   rA   r3   
delimitersmax_delimiter_prioritydelimiter_count_with_priorityr   (wrap_multiple_context_managers_in_parensr-   r   r  r!   r   rX   r   _can_omit_opening_parenr&   r   r   r   r   r#   r   r   _can_omit_closing_paren)r_  rI  rB  r  r7   btmax_prioritydelimiter_countr   secondpenultimaterQ  s               rN   can_omit_invisible_parensrl    sT    8D '+O%% # # 	#t'FFF"O9***?*55	#	---$33
 4 #O		B= t,,..L66|DDOu!<	II..3 / 5
 |##tt{q   "6    KNE[^Fz%%%&+=M*M*M"4u+NNN 	4 +b/K;r?D 		UZ9$$ I## $ DL00 ///5u%% 	 4"4dLLL 	45rO   r   c                   d}d| j         z  }d}|                                 D ]>\  }}}|j        t          v r|j        |u rd}|r||z  }||k    r n.|j        t
          v rd}?t          | j                  |dz   k    rdS dS ) See `can_omit_invisible_parens`.Fr~   r   TrW   )r.   r   r?   r   r   r   rX   r1   )rB  r   rI  	remainderr   _indexr7   leaf_lengths           rN   re  re  &  s    I^FF%)%?%?%A%A  !k9(((T-AU-J-JI 	"k!F##y,,,!	 t{vz))45rO   rQ  c                    d| j         z  }d}|                                 D ]0\  }}}||z  }||j        u r|s||k    r dS  |j        t          v rd}1dS )rn  r~   FT)r.   r   r   r?   r   )rB  rQ  rI  r   seen_other_bracketsrp  r7   rq  s           rN   rf  rf  ?  s    ^F%)%?%?%A%A ' '!k+4'''" f&;&;tt '< Y***"&5rO   c                 F    t          |                               d          S )zmReturns the string representation of @line.

    WARNING: This is known to be computationally expensive.
    r   )r   rB   )rB  s    rN   rF  rF  P  s    
 t99??4   rO   r   )Cr   rK  dataclassesr   r   typingr   r   r   r   r	   r
   r   r   r   r   black.bracketsr   r   r   
black.moder   r   black.nodesr   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   black.stringsr%   blib2to3.pgen2r&   blib2to3.pytreer'   r(   r)   r   r   r   LNr+   r  r  r  r   r@   r@  r   rZ  r^  rl  re  rf  rF  r   rO   rN   <module>r~     s        ( ( ( ( ( ( ( (                        H G G G G G G G G G $ $ $ $ $ $ $ $                                     & $ # # # # #             & & & & & & & & GCLL	
4: }2 }2 }2 }2 }2 }2 }2 }2@         
 
 
 
 
 
 
 
* K K K K K K K K\! %q/1J     NS= =="=,0J=FJ=	= = = =2 02X+ X+ X+
X+X+),X+	X+ X+ X+ X+v!t ! ! ! ! !Hb	bb 
b b b bJ$ $ S T    2$  C D    "! !# ! ! ! ! ! !rO   