hyb
2026-01-07 c7f60dc7e9a36596f0e0d1787bd0cca4e9b57bcb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
Ë
ñúh§`ãóˆ—ddlmZddlmZddlmZddlmZddlm    Z    ddl
m Z m Z m Z mZmZmZmZmZmZmZddlmZmZmZmZmZdd    lmZmZdd
lmZe r
dd l m!Z!m"Z"m#Z#ed «Z$Gd „de«Z%eee%ee%ee&e'ffee%e&e&ffZ(e«Gd„de««Z)Gd„d«Z*Gd„d«Z+e,dk(rddl-m!Z!ddl.m/Z/ddl0m1Z1dZ2e1jfd«Z4e!«Z e jkd«e jmd«e jmd«e jme/e2dd¬ ««e jm«e jmd!«e7e jqe4««Z9e jme9«e jm«e jmd"«e jme4«e jmd#«y$y$)%é)Ú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óP—eZdZdZdZdZdZdZdZdZ    dZ
d    Z d
Z d Z d Zd ZdZdZdZdZy)Ú ControlTypezDNon-printable control codes which typically translate to ANSI codes.réééééééé    é
é é é éééN)Ú__name__Ú
__module__Ú __qualname__Ú__doc__ÚBELLÚCARRIAGE_RETURNÚHOMEÚCLEARÚ SHOW_CURSORÚ HIDE_CURSORÚENABLE_ALT_SCREENÚDISABLE_ALT_SCREENÚ    CURSOR_UPÚ CURSOR_DOWNÚCURSOR_FORWARDÚCURSOR_BACKWARDÚCURSOR_MOVE_TO_COLUMNÚCURSOR_MOVE_TOÚ ERASE_IN_LINEÚSET_WINDOW_TITLE©óúKH:\Change_password\venv_build\Lib\site-packages\pip/_vendor/rich/segment.pyr r #sY„ÙNà €DØ€OØ €DØ €EØ€KØ€KØÐØÐØ€IØ€KØ€NØ€OØÐØ€NØ€MØÑrEr cóv—eZdZUdZeed<dZeeed<dZ    ee
e ed<e de fd„«Zdefd„Zdefd    „Ze defd
„«Zeed «d dd e dedfd„««Zd e dedfd„Zed/d„«Ze        d0deddeedeededfd„«Ze    d1deddededfd„«Zededdeedfd„«Ze            d2dedde deedededeedf d„«Ze        d3dedde deedededf
d„«Z ededde fd„«Z!edeeddee e ffd „«Z"e            d4deedd!e d"ee deed#edeedf d$„«Z#e    d1d%e$ddeedd!e d"e ded#edeedfd&„«Z%e    d1d%e$ddeedd!e d"e ded#edeedfd'„«Z&e    d1d%e$ddeedd!e d"e ded#edeedfd(„«Z'ededdedfd)„«Z(ededdedfd*„«Z)ededdedfd+„«Z*ededdedfd,„«Z+ededd-ee deedfd.„«Z,y)5Ú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ó,—|\}}}|rdSt|«S)zzThe number of terminal cells required to display self.text.
 
        Returns:
            int: A number of cells.
        r)r)ÚselfrIÚ_stylerKs    rFÚ cell_lengthzSegment.cell_lengthQs!€ð!%шˆfgÙˆqÐ/¤¨$£Ð/rEc#ó°K—|j–—|j€|j|j–—yy|j–—|j–—y­w©N)rIrKrJ©rNs rFÚ __rich_repr__zSegment.__rich_repr__[sHèø€Øi‰iŠØ <‰<Р؏z‰zÐ%Ø—j‘jÓ ð&ð—*‘*Ò Ø—,‘,Ó ùs‚AAcó,—t|j«S)z#Check if the segment contains text.)ÚboolrIrSs rFÚ__bool__zSegment.__bool__ds€äD—I‘I‹ÐrEcó—|jduS)z,Check if the segment contains control codes.N)rKrSs rFÚ
is_controlzSegment.is_controlhs€ð|‰| 4Ð'Ð'rEi@ÚsegmentÚcut)rHrHcóò—|\}}}t}|j}||k\r ||d||«fSt}t||z t    |«z«}        |d|    }
t |
«} | |z
} | s||
||«|||    d||«fS| dk(r1|||    «dk(r#||d|    dz||«|d||    dzdz||«fS| dk(r4|||    dz
«dk(r#||d|    dz
dz||«|d||    dz||«fS| |kr|    dz }    n|    dz}    Œ®)a\Split a segment in to two at a given cell position.
 
        Note that splitting a double-width character, may result in that character turning
        into two spaces.
 
        Args:
            segment (Segment): A segment to split.
            cut (int): A cell position to cut on.
 
        Returns:
            A tuple of two segments.
        ÚNéÿÿÿÿr!ú r)rHrPrÚintÚlenr) ÚclsrZr[rIrJrKÚ_SegmentrPÚ    cell_sizeÚposÚbeforeÚcell_posÚout_bys              rFÚ _split_cellszSegment._split_cellsmss€ð 'шˆeW܈Ø×)Ñ)ˆ Ø +Ò Ø™H R¨°Ó8Ð8Ð 8ä+ˆ    ä3˜Ñ$¬¨D«    Ñ1Ó2ˆàؘ$˜3ZˆFÜ Ó'ˆHØ ‘^ˆFÙá˜V U¨GÓ4Ù˜T # $˜Z¨°Ó8ððð˜Š|¡    ¨$¨s©)Ó 4¸Ò 9á˜T $ 3˜Z¨#Ñ-¨u°gÓ>Ù˜S 4¨¨a©¨     ?Ñ2°E¸7ÓCððð˜Š|¡    ¨$¨s°Q©w©-Ó 8¸AÒ =á˜T ) C¨!¡G˜_¨sÑ2°E¸7ÓCÙ˜S 4¨¨ :Ñ-¨u°gÓ>ððð˜#Š~ؐq‘‘àq‘ð-rEcóЗ|\}}}|dk\sJ‚t|«r=|t|«k\r|td||«fSt|d|||«t||d||«fS|j||«S)axSplit 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.
 
        Args:
            cut (int): Offset within the segment to cut.
 
        Returns:
            Tuple[Segment, Segment]: Two segments.
        rr]N)rrarHri)rNr[rIrJrKs     rFÚ split_cellszSegment.split_cellsžs†€ð $шˆeWؐaŠxˆˆxä ! $Ô 'à”c˜$“iÒØœW R¨°Ó8Ð8Ð8䘘T˜c˜
 E¨7Ó3ܘ˜S˜T˜
 E¨7Ó3ðð ð
× Ñ   sÓ+Ð+rEcó—|d«S)zMake a new line segment.ú
rD)rbs rFÚlinez Segment.line¸s€ñ4‹yÐrEÚsegmentsÚ
post_stylecó`‡‡‡—|}|r|jŠˆˆfd„|D«}‰r ˆˆfd„|D«}|S)aApply 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).
        c3óN•K—|]\}}}‰||rdn‰|«|«–—Œy­wrRrD)Ú.0rIrOrKÚapplyrbs    €€rFú    <genexpr>z&Segment.apply_style.<locals>.<genexpr>Ós0øèø€òá)D˜& 'ñD¡'™$©u°V«}¸g×Fñùsƒ"%c3óP•K—|]\}}}‰||rdn|r|‰zn‰|«–—Œy­wrRrD)rsrIrOrKrbrps    €€rFruz&Segment.apply_style.<locals>.<genexpr>ØsBøèø€ò ñ*D˜& 'ñØñ#ñá5;˜f zÒ1Àà÷ñ ùsƒ#&)Ú__add__)rbrorJrpÚresult_segmentsrts`  ` @rFÚ apply_stylezSegment.apply_style½sCú€ð&#ˆÙ Ø—M‘MˆEôà-<ôˆOñ ô ð.=ô ˆOðÐrErYcóZ—|rttd«|«Sttd«|«S)a2Filter 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.
 
        rK)Úfilterrr)rbrorYs   rFÚfilter_controlzSegment.filter_controlæs+€ñ Üœ* YÓ/°Ó:Ð :äœz¨)Ó4°hÓ?Ð ?rEc#óK—g}|j}|D]k}d|jvrS|jsG|\}}}|sŒ&|jd«\}}    }|r||||««|    r|–—g}|j}|rŒ=Œd||«Œm|r|–—yy­w)aSplit 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.
        rmN)ÚappendrIrKÚ    partition)
rbrornr~rZrIrJÚ_Ú_textÚnew_lines
          rFÚ split_lineszSegment.split_linesùsŸèø€ð!ˆØ—‘ˆàò      ˆGؐw—|‘|Ñ#¨G¯OªOØ!(‘e˜QÚØ,0¯N©N¸4Ó,@Ñ)E˜8 TÙÙ™s 5¨%Ó0Ô1ÙØ"š
Ø!˜Ø!%§¡˜óñw•ð      ñ Ø‹Jð ùs‚6B    ¹<B    Á6B    ÚlengthÚpadÚinclude_new_linesc#ó”K—g}|j}|j}|d«}    |D]Œ}
d|
jvrt|
jsh|
\} } } | sŒ&| j    d«\}}} |r|||| ««|r3|||||¬«}|r|j|    «|–—|j «| rŒ^Œ…||
«ŒŽ|r|||||¬«–—yy­w)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.
        rm)rJr…N)r~Úadjust_line_lengthrIrKrÚclear)rbror„rJr…r†rnr~rˆÚnew_line_segmentrZrIÚ segment_styler€rr‚Ú cropped_lines                 rFÚsplit_and_crop_lineszSegment.split_and_crop_linessåèø€ð*!ˆØ—‘ˆà ×3Ñ3ÐÙ˜t›9Ðàò     ˆGؐw—|‘|Ñ#¨G¯OªOØ)0Ñ&m QÚØ,0¯N©N¸4Ó,@Ñ)E˜8 TÙÙ™s 5¨-Ó8Ô9ÙÙ'9Ø  &°¸3ô(˜ ñ-Ø(×/Ñ/Ð0@ÔAØ*Ò*ØŸ
™
œ óñw•ð!     ñ" Ù$ T¨6¸ÀCÔHÓ Hð ùs‚A
CÁ ACÂ+Crncó^—td„|D««}||kr|r||d||z
z|«gz}|S|dd}|S||kDrmg}|j}d}|D]V}|j}    ||    z|ks |jr||«||    z }Œ1|\}
} } t    |
||z
«}
|||
| ««|S|S|dd}|S)aAdjust 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.
        c3ó4K—|]}|j–—Œy­wrR)rP)rsrZs  rFruz-Segment.adjust_line_length.<locals>.<genexpr>Xsèø€ÒB°'˜'×-Õ-ÑBùs‚r_Nr)Úsumr~rPrKr) rbrnr„rJr…Ú line_lengthr‚r~rZÚsegment_lengthrIr‹r€s              rFrˆzSegment.adjust_line_lengthEs€ô&ÑB¸TÔBÓBˆ ð ˜Ò ÙØ¡3 s¨f°{Ñ.BÑ'CÀUÓ#KÐ"LÑLð&ˆð# ¡˜7ð"ˆð!˜6Ò !؈HØ—_‘_ˆF؈KØò     Ø!(×!4Ñ!4Ø Ñ/°&Ò8¸G¿OºOÙ˜7”OØ >Ñ1‘Kà-4Ñ*D˜-¨Ü(¨¨v¸ Ñ/CÓDDÙ™3˜t ]Ó3Ô4Øðˆð     ðˆð™AwˆH؈rEcó8‡—tŠtˆfd„|D««S)zÜGet 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.
        c3ó<•K—|]\}}}|rŒ
‰|«–—Œy­wrRrD)rsrIrJrKÚ    _cell_lens    €rFruz*Segment.get_line_length.<locals>.<genexpr>}søèø€ÒSÑ'; t¨U°GÊ7‘9˜T—?ÑSùsƒ  )rr)rbrnr•s  @rFÚget_line_lengthzSegment.get_line_lengthrsø€ôˆ    ÜÓS¸tÔSÓSÐSrEÚlinescóf‡—|jŠ|rtˆfd„|D««nd}|t|«fS)zîGet 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.
        c3ó.•K—|] }‰|«–—Œy­wrRrD)rsrnr–s  €rFruz$Segment.get_shape.<locals>.<genexpr>Šsøèø€Ò@°$™¨×-Ñ@ùsƒr)r–Úmaxra)rbr—Ú    max_widthr–s   @rFÚ    get_shapezSegment.get_shapes3ø€ð×-Ñ-ˆÙDI”CÓ@¸%Ô@Ô@Èqˆ    Øœ3˜u›:Ð&Ð&rEÚwidthÚheightÚ    new_linescó$—|xs t|«}|r|d|zdz|«gn |d|z|«g}|j}|d|}    |D
cgc] }
||
||¬«‘Œc}
|    ddt|    «|kr!|    j|g|t|    «z
z«|    Scc}
w)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.
        r_rmN)rJ)rarˆÚextend) rbr—rržrJrŸÚ_heightÚblankrˆÚ shaped_linesrns            rFÚ    set_shapezSegment.set_shapes·€ð*Ò&œC ›Jˆñ1:‰Su‘˜tÑ# UÓ +Ñ ,ÁÀCÈ%ÁKÐQVÓ@WÐ?Xð    ð!×3Ñ3ÐØ˜X˜gˆ àEJö
Ø=AÑ ˜t U°%Ö 8ò
ˆ ‘Qˆô ˆ|Ó ˜wÒ &Ø × Ñ   ¨7´S¸Ó5FÑ+FÑ GÔ HØÐùò 
sÁB rbcóˆ—|t|«z
}|s|ddS|d|}|r|d|zdz|«n |d|z|«}||gg|zz}|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.
        Nr_rm©ra©rbr—rržrJrŸÚ extra_linesr£s        rFÚ    align_topzSegment.align_top±sf€ð*œs 5›zÑ)ˆ ÙØ™8ˆOؐgvˆÙ2;‘C˜%‘K $Ñ&¨Ô.ÁÀSÈ5Á[ÐRWÓAXˆØ˜%˜˜     KÑ/Ñ/ˆØˆ rEcóˆ—|t|«z
}|s|ddS|d|}|r|d|zdz|«n |d|z|«}|gg|z|z}|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.
        Nr_rmr§r¨s        rFÚ align_bottomzSegment.align_bottomÎsf€ð*œs 5›zÑ)ˆ ÙØ™8ˆOؐgvˆÙ2;‘C˜%‘K $Ñ&¨Ô.ÁÀSÈ5Á[ÐRWÓAXˆØ    ˜KÑ'¨%Ñ/ˆØˆ rEcó¬—|t|«z
}|s|ddS|d|}|r|d|zdz|«n |d|z|«}|dz}||z
}    |gg|z|z|gg|    zz}|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.
        Nr_rmr!r§)
rbr—rržrJrŸr©r£Ú    top_linesÚ bottom_liness
          rFÚ align_middlezSegment.align_middleësˆ€ð*œs 5›zÑ)ˆ ÙØ™8ˆOؐgvˆÙ2;‘C˜%‘K $Ñ&¨Ô.ÁÀSÈ5Á[ÐRWÓAXˆØ 1Ñ$ˆ    Ø" YÑ.ˆ ؐ    ˜IÑ%¨Ñ-°%°°    ¸LÑ0HÑHˆØˆ rEc#ó&K—t|«}    t|«}t}|D]X}|j|jk(r7|j
s+||j |j z|j«}ŒS|–—|}ŒZ|–—y#t$rYywxYw­w)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Ú StopIterationrHrJrKrI)rbroÚ iter_segmentsÚ last_segmentrcrZs      rFÚsimplifyzSegment.simplify
sšèø€ô˜X›ˆ ð    Ü  Ó.ˆLôˆØ$ò    'ˆGØ×!Ñ! W§]¡]Ò2¸7¿?º?Ù'Ø ×%Ñ%¨¯ © Ñ4°l×6HÑ6Hó ‘ ð#Ò"Ø&‘ ð    'ðÓøôò    Ù ð    üs(‚ B BšA(B    B B BÂBc#óœK—|D]C}|js |j€|–—Œ |\}}}|||r|jd«nd«–—ŒEy­w)zÆRemove all links from an iterable of styles.
 
        Args:
            segments (Iterable[Segment]): An iterable segments.
 
        Yields:
            Segment: Segments with link removed.
        N)rKrJÚ update_link)rbrorZrIrJÚ_controls      rFÚ strip_linkszSegment.strip_links%sVèø€ð ò    LˆGØŠ '§-¡-Ð"7Ø“ à(/Ñ%e˜XÙ˜$¹5 × 1Ñ 1°$Ô 7ÀdÓKÓKñ     Lùs‚A
A c#ó:K—|D]\}}}||d|«–—Œy­w)zÔRemove all styles from an iterable of segments.
 
        Args:
            segments (Iterable[Segment]): An iterable segments.
 
        Yields:
            Segment: Segments with styles replace with None
        NrD)rbrorIrOrKs     rFÚ strip_styleszSegment.strip_styles6s-èø€ð&.ò    +Ñ !ˆD&˜'ِd˜D 'Ó*Ó *ñ    +ùs‚c#ó¤K—i}|D]E\}}}|r1|j|«}|€|j}|||<||||«–—Œ:||d|«–—ŒGy­w)zËRemove all color from an iterable of segments.
 
        Args:
            segments (Iterable[Segment]): An iterable segments.
 
        Yields:
            Segment: Segments with colorless style.
        N)ÚgetÚ without_color)rbroÚcacherIrJrKÚcolorless_styles       rFÚ remove_colorzSegment.remove_colorCslèø€ð%'ˆØ$,ò    /Ñ  ˆD%˜ÙØ"'§)¡)¨EÓ"2Ø"Ð*Ø&+×&9Ñ&9OØ#2E˜%‘LÙ˜$ °Ó9Ó9á˜$  gÓ.Ó.ñ    /ùs‚AAÚcutsc#óVK—g}|j}t|«}    t|d«}|dk(ry|dk7rng–—Œd}|j}|j}    t
}
|D]À} | \} } }| sŒ |r|n
||
| «z}||kr || «|}Œ+||k(r9|| «|    «–—|«|}t|d«}|dk(r |r    |    «–—yŒi| j ||z
«\}} | \} } }||«|    «–—|«|}t|d«}|dk(r |r    |    «–—y| rŒµŒÂ|    «–—y­w)zâDivides 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^Nr)r~r²r³r‰Úcopyrrk)rbrorÄÚsplit_segmentsÚ add_segmentÚ    iter_cutsr[reÚsegments_clearÚ segments_copyr•rZrIrOrKÚend_posrfs                 rFÚdividezSegment.divideYspèø€ð+-ˆØ$×+Ñ+ˆ 䘓Jˆ    àܐy "Ó%ˆCؐbŠyØØaŠxØØŠHð ðˆà'×-Ñ-ˆØ&×+Ñ+ˆ ä#ˆ    Øò#    ˆGØ$+Ñ !ˆD&˜'ÚÙ!(™#¨c±I¸d³OÑ.CØ˜S’=Ù Ô(Ø!CØà˜c’>Ù Ô(Ù'›/Ò)Ù"Ô$Ø!Cä˜y¨"Ó-Cؘb’yÙ)Ù"/£/Ò1Ùàð'.×&9Ñ&9¸#À¹)Ó&D‘OF˜GØ,3Ñ)D˜& 'Ù Ô'Ù'›/Ò)Ù"Ô$ؐCä˜9 bÓ)Ø˜"’9Ù%Ù+›oÒ-ÙóCð#    ñJ‹oÓùs‚A%D)Á(B4D)Ä D))rLrH)NN©F)NTT)NT)NNF)-r0r1r2r3ÚstrÚ__annotations__rJr rrKrÚ ControlCodeÚpropertyr`rPrrTrVrWrYÚ classmethodrrrirkrnr
ryr|r rƒrrˆr–rœr¥rrªr¬r°r·r»r½rÃrÍrDrErFrHrH?s‘…ñ
ð ƒIØ!€Eˆ8E‰?Ó!Ø/3€GˆXh˜{Ñ+Ñ ,Ó3à ð0˜Sò0óð0ð˜vóð˜$óðð(˜Dò(óð(ðÙˆyÓð- 9ð-°3ð-¸5ÐAUÑ;Vò-óóð-ð^,˜sð, uÐ-AÑ'Bó,ð4òóððð"&Ø&*ñ    &à˜9Ñ%ð&ð˜‰ð&ð˜U‘Oð    &ð
 
)Ñ    ò &óð&ðPà?Dñ@Ø     Ñ*ð@Ø8<ð@à    )Ñ    ò@óð@ð$ð 8¨IÑ#6ð¸8ÀDÈÁOÑ;Tòóðð8ð
"&ØØ"&ñ ,Ià˜9Ñ%ð,Iðð,Ið˜‰ð    ,Ið
ð ,Ið  ð ,Ið
$y‘/Ñ    "ò,Ióð,Ið\ð
"&Øñ *à9‰oð*ðð*ð˜‰ð    *ð
ð *ð
ˆi‰ò *óð*ðXð
T 4¨    ¡?ð
T°sò
Tóð
Tðð '˜d 4¨    ¡?Ñ3ð '¸¸cÀ3¸h¹ò 'óð 'ðð
!%Ø!%Øñ !àD˜‘OÑ$ð!ðð!𘑠𠠠 !ð
˜‰ð !ð ð !ð
ˆd9‰oÑ    ò!óð!ðFð ñ Ø )‰_ðàD˜‘OÑ$ððððð    ð
ð ð ð ð
ˆd9‰oÑ    òóðð8ð ñ Ø )‰_ðàD˜‘OÑ$ððððð    ð
ð ð ð ð
ˆd9‰oÑ    òóðð8ð ñ Ø )‰_ðàD˜‘OÑ$ððððð    ð
ð ð ð ð
ˆd9‰oÑ    òóðð<ð ¨Ñ 3ð¸ÀÑ8Kòóðð4ðL 8¨IÑ#6ðL¸8ÀIÑ;NòLóðLð ð
+ H¨YÑ$7ð
+¸HÀYÑ<Oò
+óð
+ðð/ H¨YÑ$7ð/¸HÀYÑ<Oò/óð/ð*ðBØ     Ñ*ðBØ2:¸3±-ðBà    $y‘/Ñ    "òBóñBrErHcó@—eZdZdZddeededdfd„Z                        d    d„Zy)
Ú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.
    rorŸrLNcó2—t|«|_||_yrR)ÚlistrorŸ)rNrorŸs   rFÚ__init__zSegments.__init__¨s€Ü˜X›ˆŒ Ø"ˆrEc#ó¬K—|jr.tj«}|jD]
}|–—|–—Œ y|jEd{–—†y7Œ­wrR)rŸrHrnro)rNÚconsoleÚoptionsrnrZs     rFÚ__rich_console__zSegments.__rich_console__¬sFèø€ð >Š>Ü—<‘<“>ˆDØŸ=™=ò Ø’ Ø“
ñ ð—}‘}× $Ò $ús‚A
AÁ AÁ ArΩrÚrrÛrrLr)    r0r1r2r3r
rHrVrØrÜrDrErFrÕr՟sD„ññ# ¨'Ñ!2ð#¸tð#ÐPTó#ð    %Ø ð    %Ø+;ð    %à    ô    %rErÕcóB—eZdZddeeededdfd„Z                        dd„Zy)    Ú SegmentLinesr—rŸrLNcó2—t|«|_||_y)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×r—rŸ)rNr—rŸs   rFrØzSegmentLines.__init__¹s€ô˜%“[ˆŒ
Ø"ˆrEc#óÊK—|jr4tj«}|jD]}|Ed{–—†|–—Œy|jD] }|Ed{–—†Œy7Œ'7Œ    ­wrR)rŸrHrnr—)rNrÚrÛr‚rns     rFrÜzSegmentLines.__rich_console__Äs`èø€ð >Š>Ü—|‘|“~ˆHØŸ
™
ò Ø—Ø“ñ ðŸ
™
ò  Ø—‘ñ  ð øð ús!‚5A#·A¸A#ÁA!ÁA#Á!A#rÎrÝ)    r0r1r2r
r rHrVrØrÜrDrErFrßr߸sC„ñ    #˜h t¨G¡}Ñ5ð    #À$ð    #ÐSWó    #ð
 Ø ð
 Ø+;ð
 à    ô
 rErßÚ__main__)r)ÚSyntax)ÚTextz‚from rich.console import Console
console = Console()
text = Text.from_markup("Hello, [bold magenta]World[/]!")
console.print(text)zHello, [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)Ú line_numberszRWhen you call [b]print()[/b], Rich [i]renders[/i] the object in to 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Útypingrr    r
r r r rrrrÚcellsrrrrrÚreprrrrJrrÚrrrÚlogr r`rÏrÑrHrÕrßr0Úpip._vendor.rich.consoleÚpip._vendor.rich.syntaxrãÚpip._vendor.rich.texträÚcodeÚ from_markuprIÚruleÚprintr×ÚrenderÚ    fragmentsrDrErFú<module>rùsªðÝÝÝ!ÝÝ÷ ÷ ÷ ÷õ÷$Ýáß>Ñ>áÓ€ô'ôð*Ø    ˆ+ÑØ    ˆ+u˜S #˜X‘Ð
&Ñ'Ø    ˆ+s˜CÐ
Ñ ð"ñ€ ñ ƒô\    ˆjó\    ó ð\    ÷~%ñ%÷2 ñ ð2 ˆzÓÝ0Ý.Ý*ð €Dð
ˆ4× Ñ Ð<Ó =€Dá‹i€Gà ‡LLÔ Ø ‡MMØgôð ‡MMÐ4Ô5Ø ‡MM‘&˜˜x°dÔ;Ô<Ø ‡MM„OØ ‡MMØ]ôñW—^‘^ DÓ)Ó*€IØ ‡MM)ÔØ ‡MM„OØ ‡MMÐVÔWØ ‡MM$ÔØ ‡MMØ^õð;rE