U
    cc^                     @   s  d dl mZ d dlmZ d dlmZ d dlmZ d dlm	Z	 d dl
mZ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mZmZ dd	lmZmZ dd
lmZ erddl m!Z!m"Z"m#Z# edZ$G dd deZ%eee% ee%ee&e'f f ee%e&e&f f Z(e G dd deZ)G dd dZ*G dd dZ+e,dkrd dl-m!Z! d dl.m/Z/ d dl0m1Z1 dZ2e13dZ4e! Z e 5d e 6d e 6d e 6e/e2ddd  e 6  e 6d! e7e 8e4Z9e 6e9 e 6  e 6d" e 6e4 e 6d# d$S )%    )IntEnum)	lru_cache)filterfalse)	getLogger)
attrgetter)
TYPE_CHECKINGDictIterableList
NamedTupleOptionalSequenceTupleTypeUnion   )_is_single_cell_widthscached_cell_lencell_lenget_character_cell_sizeset_cell_size)Result	rich_repr)Style)ConsoleConsoleOptionsRenderResultrichc                   @   sP   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdZdS )ControlTypezDNon-printable control codes which typically translate to ANSI codes.r                        	   
                     N)__name__
__module____qualname____doc__ZBELLZCARRIAGE_RETURNHOMEZCLEARZSHOW_CURSORZHIDE_CURSORZENABLE_ALT_SCREENZDISABLE_ALT_SCREENZ	CURSOR_UPZCURSOR_DOWNZCURSOR_FORWARDZCURSOR_BACKWARDZCURSOR_MOVE_TO_COLUMNZCURSOR_MOVE_TOZERASE_IN_LINEZSET_WINDOW_TITLE r3   r3   R/var/www/html/project/venv/lib/python3.8/site-packages/pip/_vendor/rich/segment.pyr   #   s"   r   c                   @   s*  e Zd ZU dZeed< dZee ed< dZ	ee
e  ed< eedddZedd	d
ZedddZeedddZeedd eed dddZeed dddZed dddZedEed  ee ee ed  dddZedFed  eed  dddZeed  eed   d d!d"ZedGed  eee eeeed   d$d%d&ZedHed  eee eed  d'd(d)Z eed  ed*d+d,Z!eeed   eeef d-d.d/Z"edIeed   eee ee eeed   d0d1d2Z#edJe$d  eed   eeeeeed   d3d4d5Z%edKe$d  eed   eeeeeed   d3d6d7Z&edLe$d  eed   eeeeeed   d3d8d9Z'eed  ed  d d:d;Z(eed  ed  d d<d=Z)eed  ed  d d>d?Z*eed  ed  d d@dAZ+eed  ee eed   dBdCdDZ,dS )MSegmenta  A piece of text with associated style. Segments are produced by the Console render process and
    are ultimately converted in to strings to be written to the terminal.

    Args:
        text (str): A piece of text.
        style (:class:`~rich.style.Style`, optional): An optional style to apply to the text.
        control (Tuple[ControlCode], optional): Optional sequence of control codes.

    Attributes:
        cell_length (int): The cell length of this Segment.
    textNstylecontrol)returnc                 C   s   | \}}}|rdS t |S )zzThe number of terminal cells required to display self.text.

        Returns:
            int: A number of cells.
        r   )r   )selfr6   _styler8   r3   r3   r4   cell_lengthQ   s    
zSegment.cell_lengthc                 c   s:   | j V  | jd kr&| jd k	r6| jV  n| jV  | jV  d S N)r6   r8   r7   r:   r3   r3   r4   __rich_repr__[   s    


zSegment.__rich_repr__c                 C   s
   t | jS )z#Check if the segment contains text.)boolr6   r>   r3   r3   r4   __bool__d   s    zSegment.__bool__c                 C   s
   | j dk	S )z,Check if the segment contains control codes.N)r8   r>   r3   r3   r4   
is_controlh   s    zSegment.is_controli @  )r5   r5   )segmentcutr9   c                 C   s(  |\}}}t }|j}||kr,||d||fS t}t|| t| }	|d |	 }
t|
}||kr||
|||||	d  ||fS |	t|k r||	 }|	d7 }	|||7 }|d |	 }
||kr||
|||||	d  ||fS ||kr||
d |	d  d |||d||	d   ||fS qtdd S )N r    zWill never reach here)r5   r<   r   intlenr   AssertionError)clsrC   rD   r6   r7   r8   _Segmentr<   	cell_sizeposbeforeZcell_poscharr3   r3   r4   _split_cellsm   s6    


zSegment._split_cells)rD   r9   c                 C   sb   | \}}}t |rV|t|kr.| td||fS t|d| ||t||d ||fS | | |S )a0  Split segment in to two segments at the specified column.

        If the cut point falls in the middle of a 2-cell wide character then it is replaced
        by two spaces, to preserve the display width of the parent segment.

        Returns:
            Tuple[Segment, Segment]: Two segments.
        rE   N)r   rH   r5   rP   )r:   rD   r6   r7   r8   r3   r3   r4   split_cells   s    	
zSegment.split_cellsc                 C   s   | dS )zMake a new line segment.
r3   )rJ   r3   r3   r4   line   s    zSegment.line)segmentsr7   
post_styler9   c                    s>   |}|r"|j   fdd|D }r:fdd|D }|S )a  Apply style(s) to an iterable of segments.

        Returns an iterable of segments where the style is replaced by ``style + segment.style + post_style``.

        Args:
            segments (Iterable[Segment]): Segments to process.
            style (Style, optional): Base style. Defaults to None.
            post_style (Style, optional): Style to apply on top of segment style. Defaults to None.

        Returns:
            Iterable[Segments]: A new iterable of segments (possibly the same iterable).
        c                 3   s,   | ]$\}}}||rd n ||V  qd S r=   r3   .0r6   r;   r8   )applyrJ   r3   r4   	<genexpr>   s   z&Segment.apply_style.<locals>.<genexpr>c                 3   s4   | ],\}}} ||rd n|r$| n|V  qd S r=   r3   rV   )rJ   rU   r3   r4   rY      s   
)__add__)rJ   rT   r7   rU   Zresult_segmentsr3   )rX   rJ   rU   r4   apply_style   s    
zSegment.apply_styleF)rT   rB   r9   c                 C   s$   |rt td|S ttd|S dS )a2  Filter segments by ``is_control`` attribute.

        Args:
            segments (Iterable[Segment]): An iterable of Segment instances.
            is_control (bool, optional): is_control flag to match in search.

        Returns:
            Iterable[Segment]: And iterable of Segment instances.

        r8   N)filterr   r   )rJ   rT   rB   r3   r3   r4   filter_control   s    zSegment.filter_control)rT   r9   c           
      c   s   g }|j }|D ]d}d|jkrj|jsj|\}}}|rr|d\}}	}|rR|| || |	r,|V  g }|j }q,q|| q|r~|V  dS )a   Split a sequence of segments in to a list of lines.

        Args:
            segments (Iterable[Segment]): Segments potentially containing line feeds.

        Yields:
            Iterable[List[Segment]]: Iterable of segment lists, one per line.
        rR   N)appendr6   r8   	partition)
rJ   rT   rS   r^   rC   r6   r7   __textnew_liner3   r3   r4   split_lines   s     



zSegment.split_linesT)rT   lengthr7   padinclude_new_linesr9   c                 c   s   g }|j }| j}| d}	|D ]}
d|
jkr|
js|
\}}}|r|d\}}}|r`|| || |r:|||||d}|r| |	 |V  |dd= q:q||
 q|r|||||dV  dS )a  Split segments in to lines, and crop lines greater than a given length.

        Args:
            segments (Iterable[Segment]): An iterable of segments, probably
                generated from console.render.
            length (int): Desired line length.
            style (Style, optional): Style to use for any padding.
            pad (bool): Enable padding of lines that are less than `length`.

        Returns:
            Iterable[List[Segment]]: An iterable of lines of segments.
        rR   )r7   re   N)r^   adjust_line_lengthr6   r8   r_   )rJ   rT   rd   r7   re   rf   rS   r^   rg   Znew_line_segmentrC   r6   segment_styler`   ra   rb   Zcropped_liner3   r3   r4   split_and_crop_lines	  s2    
   

zSegment.split_and_crop_lines)rS   rd   r7   re   r9   c                 C   s   t dd |D }||k rF|r8|| d||  |g }q|dd }n||krg }|j}d}|D ]X}|j}	||	 |k s||jr|| ||	7 }q`|\}
}}t|
|| }
|| |
|  qq`n|dd }|S )a  Adjust a line to a given width (cropping or padding as required).

        Args:
            segments (Iterable[Segment]): A list of segments in a single line.
            length (int): The desired width of the line.
            style (Style, optional): The style of padding if used (space on the end). Defaults to None.
            pad (bool, optional): Pad lines with spaces if they are shorter than `length`. Defaults to True.

        Returns:
            List[Segment]: A line of segments with the desired length.
        c                 s   s   | ]}|j V  qd S r=   )r<   rW   rC   r3   r3   r4   rY   K  s     z-Segment.adjust_line_length.<locals>.<genexpr>rF   Nr   )sumr^   r<   r8   r   )rJ   rS   rd   r7   re   Zline_lengthrb   r^   rC   Zsegment_lengthr6   rh   r`   r3   r3   r4   rg   8  s(    

zSegment.adjust_line_length)rS   r9   c                    s   t  t fdd|D S )zGet the length of list of segments.

        Args:
            line (List[Segment]): A line encoded as a list of Segments (assumes no '\\n' characters),

        Returns:
            int: The length of the line.
        c                 3   s   | ]} |j V  qd S r=   )r6   rj   	_cell_lenr3   r4   rY   p  s     z*Segment.get_line_length.<locals>.<genexpr>)r   rk   )rJ   rS   r3   rl   r4   get_line_lengthe  s    
zSegment.get_line_length)linesr9   c                    s0   | j  |r t fdd|D nd}|t|fS )zGet the shape (enclosing rectangle) of a list of lines.

        Args:
            lines (List[List[Segment]]): A list of lines (no '\\n' characters).

        Returns:
            Tuple[int, int]: Width and height in characters.
        c                 3   s   | ]} |V  qd S r=   r3   rW   rS   rn   r3   r4   rY   }  s     z$Segment.get_shape.<locals>.<genexpr>r   )rn   maxrH   )rJ   ro   	max_widthr3   rq   r4   	get_shaper  s    
zSegment.get_shape)ro   widthheightr7   	new_linesr9   c           	         s   |p
t |}|r$| d d gn| d g}| j |d| } fdd|D |dd< t ||k r||g|t |   |S )a  Set the shape of a list of lines (enclosing rectangle).

        Args:
            lines (List[List[Segment]]): A list of lines.
            width (int): Desired width.
            height (int, optional): Desired height or None for no change.
            style (Style, optional): Style of any padding added.
            new_lines (bool, optional): Padded lines should include "
". Defaults to False.

        Returns:
            List[List[Segment]]: New list of lines.
        rF   rR   Nc                    s   g | ]} |d qS ))r7   r3   rp   rg   r7   ru   r3   r4   
<listcomp>  s    z%Segment.set_shape.<locals>.<listcomp>)rH   rg   extend)	rJ   ro   ru   rv   r7   rw   _heightblankZshaped_linesr3   rx   r4   	set_shape  s    &zSegment.set_shape)rJ   ro   ru   rv   r7   rw   r9   c                 C   s`   |t | }|s|dd S |d| }|r>| d| d |n| d| |}||gg|  }|S )a  Aligns lines to top (adds extra lines to bottom as required).

        Args:
            lines (List[List[Segment]]): A list of lines.
            width (int): Desired width.
            height (int, optional): Desired height or None for no change.
            style (Style): Style of any padding added.
            new_lines (bool, optional): Padded lines should include "
". Defaults to False.

        Returns:
            List[List[Segment]]: New list of lines.
        NrF   rR   rH   rJ   ro   ru   rv   r7   rw   extra_linesr|   r3   r3   r4   	align_top  s    $zSegment.align_topc                 C   s`   |t | }|s|dd S |d| }|r>| d| d |n| d| |}|gg| | }|S )a  Aligns render to bottom (adds extra lines above as required).

        Args:
            lines (List[List[Segment]]): A list of lines.
            width (int): Desired width.
            height (int, optional): Desired height or None for no change.
            style (Style): Style of any padding added. Defaults to None.
            new_lines (bool, optional): Padded lines should include "
". Defaults to False.

        Returns:
            List[List[Segment]]: New list of lines.
        NrF   rR   r~   r   r3   r3   r4   align_bottom  s    $zSegment.align_bottomc           
      C   s|   |t | }|s|dd S |d| }|r>| d| d |n| d| |}|d }|| }	|gg| | |gg|	  }|S )a  Aligns lines to middle (adds extra lines to above and below as required).

        Args:
            lines (List[List[Segment]]): A list of lines.
            width (int): Desired width.
            height (int, optional): Desired height or None for no change.
            style (Style): Style of any padding added.
            new_lines (bool, optional): Padded lines should include "
". Defaults to False.

        Returns:
            List[List[Segment]]: New list of lines.
        NrF   rR   r   r~   )
rJ   ro   ru   rv   r7   rw   r   r|   Z	top_linesZbottom_linesr3   r3   r4   align_middle  s    $zSegment.align_middlec                 c   sv   t |}zt|}W n tk
r*   Y dS X t}|D ]6}|j|jkr`|js`||j|j |j}q4|V  |}q4|V  dS )a)  Simplify an iterable of segments by combining contiguous segments with the same style.

        Args:
            segments (Iterable[Segment]): An iterable of segments.

        Returns:
            Iterable[Segment]: A possibly smaller iterable of segments that will render the same way.
        N)iternextStopIterationr5   r7   r8   r6   )rJ   rT   iter_segmentsZlast_segmentrK   rC   r3   r3   r4   simplify  s    

 zSegment.simplifyc                 c   sJ   |D ]@}|j s|jdkr |V  q|\}}}| ||r<|dndV  qdS )zRemove all links from an iterable of styles.

        Args:
            segments (Iterable[Segment]): An iterable segments.

        Yields:
            Segment: Segments with link removed.
        N)r8   r7   update_link)rJ   rT   rC   r6   r7   _controlr3   r3   r4   strip_links  s
    

zSegment.strip_linksc                 c   s"   |D ]\}}}| |d|V  qdS )zRemove all styles from an iterable of segments.

        Args:
            segments (Iterable[Segment]): An iterable segments.

        Yields:
            Segment: Segments with styles replace with None
        Nr3   )rJ   rT   r6   r;   r8   r3   r3   r4   strip_styles)  s    
zSegment.strip_stylesc                 c   sZ   i }|D ]L\}}}|rF| |}|dkr6|j}|||< | |||V  q| |d|V  qdS )zRemove all color from an iterable of segments.

        Args:
            segments (Iterable[Segment]): An iterable segments.

        Yields:
            Segment: Segments with colorless style.
        N)getwithout_color)rJ   rT   cacher6   r7   r8   Zcolorless_styler3   r3   r4   remove_color6  s    
zSegment.remove_color)rT   cutsr9   c                 c   sD  g }|j }t|}t|d}|dkr(g S |dkr2q:g V  qd}|j}|j}	t}
|D ]}|\}}}|rR|rl|n
||
| }||k r|| |}qR||kr|| |	 V  |  |}t|d}|dkr|r|	 V   dS qRn6||| \}}|\}}}|| |	 V  |  |}t|d}|dkr`|r.|	 V   dS q`qR|	 V  dS )zDivides an iterable of segments in to portions.

        Args:
            cuts (Iterable[int]): Cell positions where to divide.

        Yields:
            [Iterable[List[Segment]]]: An iterable of Segments in List.
        r   N)r^   r   r   clearcopyr   rQ   )rJ   rT   r   Zsplit_segmentsZadd_segmentZ	iter_cutsrD   rM   Zsegments_clearZsegments_copyrm   rC   r6   r;   r8   Zend_posrN   r3   r3   r4   divideL  sX    





zSegment.divide)NN)F)NTT)NT)NNF)F)F)F)-r.   r/   r0   r1   str__annotations__r7   r   r   r8   r   ControlCodepropertyrG   r<   r   r?   r@   rA   rB   classmethodr   r   rP   rQ   rS   r	   r[   r]   r
   rc   ri   rg   rn   rt   r}   r   r   r   r   r   r   r   r   r   r3   r3   r3   r4   r5   ?   s   
		&  (     
.  ,"   

# 

 

 

 
r5   c                   @   s:   e Zd ZdZdee eddddZddd	d
ddZdS )Segmentsa=  A simple renderable to render an iterable of segments. This class may be useful if
    you want to print segments outside of a __rich_console__ method.

    Args:
        segments (Iterable[Segment]): An iterable of segments.
        new_lines (bool, optional): Add new lines between segments. Defaults to False.
    FN)rT   rw   r9   c                 C   s   t || _|| _d S r=   )listrT   rw   )r:   rT   rw   r3   r3   r4   __init__  s    
zSegments.__init__r   r   r   consoleoptionsr9   c                 c   s8   | j r(t }| jD ]}|V  |V  qn| jE d H  d S r=   )rw   r5   rS   rT   )r:   r   r   rS   rC   r3   r3   r4   __rich_console__  s    

zSegments.__rich_console__)F)	r.   r/   r0   r1   r	   r5   r@   r   r   r3   r3   r3   r4   r     s    r   c                   @   s:   e Zd Zdeee  eddddZdddd	d
dZdS )SegmentLinesFN)ro   rw   r9   c                 C   s   t || _|| _dS )a=  A simple renderable containing a number of lines of segments. May be used as an intermediate
        in rendering process.

        Args:
            lines (Iterable[List[Segment]]): Lists of segments forming lines.
            new_lines (bool, optional): Insert new lines after each line. Defaults to False.
        N)r   ro   rw   )r:   ro   rw   r3   r3   r4   r     s    
zSegmentLines.__init__r   r   r   r   c                 c   sF   | j r,t }| jD ]}|E d H  |V  qn| jD ]}|E d H  q2d S r=   )rw   r5   rS   ro   )r:   r   r   rb   rS   r3   r3   r4   r     s    



zSegmentLines.__rich_console__)F)	r.   r/   r0   r	   r
   r5   r@   r   r   r3   r3   r3   r4   r     s
    r   __main__)r   )Syntax)Textzfrom rich.console import Console
console = Console()
text = Text.from_markup("Hello, [bold magenta]World[/]!")
console.print(text)zHello, [bold magenta]World[/]!zrich.Segmentz]A Segment is the last step in the Rich render process before generating text with ANSI codes.z
Consider the following code:
pythonT)Zline_numberszVWhen you call [b]print()[/b], Rich [i]renders[/i] the object in to the the following:
zAThe Segments are then processed to produce the following output:
zS
You will only need to know this if you are implementing your own Rich renderables.N):enumr   	functoolsr   	itertoolsr   loggingr   operatorr   typingr   r   r	   r
   r   r   r   r   r   r   cellsr   r   r   r   r   reprr   r   r7   r   r   r   r   r   logr   rG   r   r   r5   r   r   r.   pip._vendor.rich.consoleZpip._vendor.rich.syntaxr   pip._vendor.rich.textr   codefrom_markupr6   ruleprintr   render	fragmentsr3   r3   r3   r4   <module>   sf   0    V






