Current Path: > > opt > alt > python38 > lib > > python3.8 > site-packages > > pip > _vendor > rich
Operation : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
__init__.py | File | 5944 bytes | November 13 2023 21:40:26. | |
__main__.py | File | 8808 bytes | November 13 2023 21:40:26. | |
_cell_widths.py | File | 10096 bytes | November 13 2023 21:40:26. | |
_emoji_codes.py | File | 140235 bytes | November 13 2023 21:40:26. | |
_emoji_replace.py | File | 1064 bytes | November 13 2023 21:40:26. | |
_export_format.py | File | 2114 bytes | November 13 2023 21:40:26. | |
_extension.py | File | 265 bytes | November 13 2023 21:40:26. | |
_inspect.py | File | 9695 bytes | November 13 2023 21:40:26. | |
_log_render.py | File | 3225 bytes | November 13 2023 21:40:26. | |
_loop.py | File | 1236 bytes | November 13 2023 21:40:26. | |
_palettes.py | File | 7063 bytes | November 13 2023 21:40:26. | |
_pick.py | File | 423 bytes | November 13 2023 21:40:26. | |
_ratio.py | File | 5472 bytes | November 13 2023 21:40:26. | |
_spinners.py | File | 19919 bytes | November 13 2023 21:40:26. | |
_stack.py | File | 351 bytes | November 13 2023 21:40:26. | |
_timer.py | File | 417 bytes | November 13 2023 21:40:26. | |
_win32_console.py | File | 22820 bytes | November 13 2023 21:40:26. | |
_windows.py | File | 1926 bytes | November 13 2023 21:40:26. | |
_windows_renderer.py | File | 2783 bytes | November 13 2023 21:40:26. | |
_wrap.py | File | 1840 bytes | November 13 2023 21:40:26. | |
abc.py | File | 890 bytes | November 13 2023 21:40:26. | |
align.py | File | 10368 bytes | November 13 2023 21:40:26. | |
ansi.py | File | 6820 bytes | November 13 2023 21:40:26. | |
bar.py | File | 3264 bytes | November 13 2023 21:40:26. | |
box.py | File | 9864 bytes | November 13 2023 21:40:26. | |
cells.py | File | 4503 bytes | November 13 2023 21:40:26. | |
color.py | File | 17957 bytes | November 13 2023 21:40:26. | |
color_triplet.py | File | 1054 bytes | November 13 2023 21:40:26. | |
columns.py | File | 7131 bytes | November 13 2023 21:40:26. | |
console.py | File | 95885 bytes | November 13 2023 21:40:26. | |
constrain.py | File | 1288 bytes | November 13 2023 21:40:26. | |
containers.py | File | 5497 bytes | November 13 2023 21:40:26. | |
control.py | File | 6630 bytes | November 13 2023 21:40:26. | |
default_styles.py | File | 7954 bytes | November 13 2023 21:40:26. | |
diagnose.py | File | 972 bytes | November 13 2023 21:40:26. | |
emoji.py | File | 2501 bytes | November 13 2023 21:40:26. | |
errors.py | File | 642 bytes | November 13 2023 21:40:26. | |
file_proxy.py | File | 1616 bytes | November 13 2023 21:40:26. | |
filesize.py | File | 2507 bytes | November 13 2023 21:40:26. | |
highlighter.py | File | 9585 bytes | November 13 2023 21:40:26. | |
json.py | File | 5051 bytes | November 13 2023 21:40:26. | |
jupyter.py | File | 3252 bytes | November 13 2023 21:40:26. | |
layout.py | File | 14074 bytes | November 13 2023 21:40:26. | |
live.py | File | 14172 bytes | November 13 2023 21:40:26. | |
live_render.py | File | 3667 bytes | November 13 2023 21:40:26. | |
logging.py | File | 11471 bytes | November 13 2023 21:40:26. | |
markup.py | File | 8198 bytes | November 13 2023 21:40:26. | |
measure.py | File | 5305 bytes | November 13 2023 21:40:26. | |
padding.py | File | 4970 bytes | November 13 2023 21:40:26. | |
pager.py | File | 828 bytes | November 13 2023 21:40:26. | |
palette.py | File | 3396 bytes | November 13 2023 21:40:26. | |
panel.py | File | 8744 bytes | November 13 2023 21:40:26. | |
pretty.py | File | 36576 bytes | November 13 2023 21:40:26. | |
progress.py | File | 59746 bytes | November 13 2023 21:40:26. | |
progress_bar.py | File | 8161 bytes | November 13 2023 21:40:26. | |
prompt.py | File | 11303 bytes | November 13 2023 21:40:26. | |
protocol.py | File | 1391 bytes | November 13 2023 21:40:26. | |
region.py | File | 166 bytes | November 13 2023 21:40:26. | |
repr.py | File | 4449 bytes | November 13 2023 21:40:26. | |
rule.py | File | 4773 bytes | November 13 2023 21:40:26. | |
scope.py | File | 2842 bytes | November 13 2023 21:40:26. | |
screen.py | File | 1591 bytes | November 13 2023 21:40:26. | |
segment.py | File | 24224 bytes | November 13 2023 21:40:26. | |
spinner.py | File | 4374 bytes | November 13 2023 21:40:26. | |
status.py | File | 4425 bytes | November 13 2023 21:40:26. | |
style.py | File | 26240 bytes | November 13 2023 21:40:26. | |
styled.py | File | 1258 bytes | November 13 2023 21:40:26. | |
syntax.py | File | 34697 bytes | November 13 2023 21:40:26. | |
table.py | File | 39515 bytes | November 13 2023 21:40:26. | |
terminal_theme.py | File | 3370 bytes | November 13 2023 21:40:26. | |
text.py | File | 44666 bytes | November 13 2023 21:40:26. | |
theme.py | File | 3627 bytes | November 13 2023 21:40:26. | |
themes.py | File | 102 bytes | November 13 2023 21:40:26. | |
traceback.py | File | 26060 bytes | November 13 2023 21:40:26. | |
tree.py | File | 9169 bytes | November 13 2023 21:40:26. |
import sys from typing import TYPE_CHECKING, Iterable, List if sys.version_info >= (3, 8): from typing import Literal else: from pip._vendor.typing_extensions import Literal # pragma: no cover from ._loop import loop_last if TYPE_CHECKING: from pip._vendor.rich.console import ConsoleOptions class Box: """Defines characters to render boxes. ┌─┬┐ top │ ││ head ├─┼┤ head_row │ ││ mid ├─┼┤ row ├─┼┤ foot_row │ ││ foot └─┴┘ bottom Args: box (str): Characters making up box. ascii (bool, optional): True if this box uses ascii characters only. Default is False. """ def __init__(self, box: str, *, ascii: bool = False) -> None: self._box = box self.ascii = ascii line1, line2, line3, line4, line5, line6, line7, line8 = box.splitlines() # top self.top_left, self.top, self.top_divider, self.top_right = iter(line1) # head self.head_left, _, self.head_vertical, self.head_right = iter(line2) # head_row ( self.head_row_left, self.head_row_horizontal, self.head_row_cross, self.head_row_right, ) = iter(line3) # mid self.mid_left, _, self.mid_vertical, self.mid_right = iter(line4) # row self.row_left, self.row_horizontal, self.row_cross, self.row_right = iter(line5) # foot_row ( self.foot_row_left, self.foot_row_horizontal, self.foot_row_cross, self.foot_row_right, ) = iter(line6) # foot self.foot_left, _, self.foot_vertical, self.foot_right = iter(line7) # bottom self.bottom_left, self.bottom, self.bottom_divider, self.bottom_right = iter( line8 ) def __repr__(self) -> str: return "Box(...)" def __str__(self) -> str: return self._box def substitute(self, options: "ConsoleOptions", safe: bool = True) -> "Box": """Substitute this box for another if it won't render due to platform issues. Args: options (ConsoleOptions): Console options used in rendering. safe (bool, optional): Substitute this for another Box if there are known problems displaying on the platform (currently only relevant on Windows). Default is True. Returns: Box: A different Box or the same Box. """ box = self if options.legacy_windows and safe: box = LEGACY_WINDOWS_SUBSTITUTIONS.get(box, box) if options.ascii_only and not box.ascii: box = ASCII return box def get_plain_headed_box(self) -> "Box": """If this box uses special characters for the borders of the header, then return the equivalent box that does not. Returns: Box: The most similar Box that doesn't use header-specific box characters. If the current Box already satisfies this criterion, then it's returned. """ return PLAIN_HEADED_SUBSTITUTIONS.get(self, self) def get_top(self, widths: Iterable[int]) -> str: """Get the top of a simple box. Args: widths (List[int]): Widths of columns. Returns: str: A string of box characters. """ parts: List[str] = [] append = parts.append append(self.top_left) for last, width in loop_last(widths): append(self.top * width) if not last: append(self.top_divider) append(self.top_right) return "".join(parts) def get_row( self, widths: Iterable[int], level: Literal["head", "row", "foot", "mid"] = "row", edge: bool = True, ) -> str: """Get the top of a simple box. Args: width (List[int]): Widths of columns. Returns: str: A string of box characters. """ if level == "head": left = self.head_row_left horizontal = self.head_row_horizontal cross = self.head_row_cross right = self.head_row_right elif level == "row": left = self.row_left horizontal = self.row_horizontal cross = self.row_cross right = self.row_right elif level == "mid": left = self.mid_left horizontal = " " cross = self.mid_vertical right = self.mid_right elif level == "foot": left = self.foot_row_left horizontal = self.foot_row_horizontal cross = self.foot_row_cross right = self.foot_row_right else: raise ValueError("level must be 'head', 'row' or 'foot'") parts: List[str] = [] append = parts.append if edge: append(left) for last, width in loop_last(widths): append(horizontal * width) if not last: append(cross) if edge: append(right) return "".join(parts) def get_bottom(self, widths: Iterable[int]) -> str: """Get the bottom of a simple box. Args: widths (List[int]): Widths of columns. Returns: str: A string of box characters. """ parts: List[str] = [] append = parts.append append(self.bottom_left) for last, width in loop_last(widths): append(self.bottom * width) if not last: append(self.bottom_divider) append(self.bottom_right) return "".join(parts) ASCII: Box = Box( """\ +--+ | || |-+| | || |-+| |-+| | || +--+ """, ascii=True, ) ASCII2: Box = Box( """\ +-++ | || +-++ | || +-++ +-++ | || +-++ """, ascii=True, ) ASCII_DOUBLE_HEAD: Box = Box( """\ +-++ | || +=++ | || +-++ +-++ | || +-++ """, ascii=True, ) SQUARE: Box = Box( """\ ┌─┬┐ │ ││ ├─┼┤ │ ││ ├─┼┤ ├─┼┤ │ ││ └─┴┘ """ ) SQUARE_DOUBLE_HEAD: Box = Box( """\ ┌─┬┐ │ ││ ╞═╪╡ │ ││ ├─┼┤ ├─┼┤ │ ││ └─┴┘ """ ) MINIMAL: Box = Box( """\ ╷ │ ╶─┼╴ │ ╶─┼╴ ╶─┼╴ │ ╵ """ ) MINIMAL_HEAVY_HEAD: Box = Box( """\ ╷ │ ╺━┿╸ │ ╶─┼╴ ╶─┼╴ │ ╵ """ ) MINIMAL_DOUBLE_HEAD: Box = Box( """\ ╷ │ ═╪ │ ─┼ ─┼ │ ╵ """ ) SIMPLE: Box = Box( """\ ── ── """ ) SIMPLE_HEAD: Box = Box( """\ ── """ ) SIMPLE_HEAVY: Box = Box( """\ ━━ ━━ """ ) HORIZONTALS: Box = Box( """\ ── ── ── ── ── """ ) ROUNDED: Box = Box( """\ ╭─┬╮ │ ││ ├─┼┤ │ ││ ├─┼┤ ├─┼┤ │ ││ ╰─┴╯ """ ) HEAVY: Box = Box( """\ ┏━┳┓ ┃ ┃┃ ┣━╋┫ ┃ ┃┃ ┣━╋┫ ┣━╋┫ ┃ ┃┃ ┗━┻┛ """ ) HEAVY_EDGE: Box = Box( """\ ┏━┯┓ ┃ │┃ ┠─┼┨ ┃ │┃ ┠─┼┨ ┠─┼┨ ┃ │┃ ┗━┷┛ """ ) HEAVY_HEAD: Box = Box( """\ ┏━┳┓ ┃ ┃┃ ┡━╇┩ │ ││ ├─┼┤ ├─┼┤ │ ││ └─┴┘ """ ) DOUBLE: Box = Box( """\ ╔═╦╗ ║ ║║ ╠═╬╣ ║ ║║ ╠═╬╣ ╠═╬╣ ║ ║║ ╚═╩╝ """ ) DOUBLE_EDGE: Box = Box( """\ ╔═╤╗ ║ │║ ╟─┼╢ ║ │║ ╟─┼╢ ╟─┼╢ ║ │║ ╚═╧╝ """ ) MARKDOWN: Box = Box( """\ | || |-|| | || |-|| |-|| | || """, ascii=True, ) # Map Boxes that don't render with raster fonts on to equivalent that do LEGACY_WINDOWS_SUBSTITUTIONS = { ROUNDED: SQUARE, MINIMAL_HEAVY_HEAD: MINIMAL, SIMPLE_HEAVY: SIMPLE, HEAVY: SQUARE, HEAVY_EDGE: SQUARE, HEAVY_HEAD: SQUARE, } # Map headed boxes to their headerless equivalents PLAIN_HEADED_SUBSTITUTIONS = { HEAVY_HEAD: SQUARE, SQUARE_DOUBLE_HEAD: SQUARE, MINIMAL_DOUBLE_HEAD: MINIMAL, MINIMAL_HEAVY_HEAD: MINIMAL, ASCII_DOUBLE_HEAD: ASCII2, } if __name__ == "__main__": # pragma: no cover from pip._vendor.rich.columns import Columns from pip._vendor.rich.panel import Panel from . import box as box from .console import Console from .table import Table from .text import Text console = Console(record=True) BOXES = [ "ASCII", "ASCII2", "ASCII_DOUBLE_HEAD", "SQUARE", "SQUARE_DOUBLE_HEAD", "MINIMAL", "MINIMAL_HEAVY_HEAD", "MINIMAL_DOUBLE_HEAD", "SIMPLE", "SIMPLE_HEAD", "SIMPLE_HEAVY", "HORIZONTALS", "ROUNDED", "HEAVY", "HEAVY_EDGE", "HEAVY_HEAD", "DOUBLE", "DOUBLE_EDGE", "MARKDOWN", ] console.print(Panel("[bold green]Box Constants", style="green"), justify="center") console.print() columns = Columns(expand=True, padding=2) for box_name in sorted(BOXES): table = Table( show_footer=True, style="dim", border_style="not dim", expand=True ) table.add_column("Header 1", "Footer 1") table.add_column("Header 2", "Footer 2") table.add_row("Cell", "Cell") table.add_row("Cell", "Cell") table.box = getattr(box, box_name) table.title = Text(f"box.{box_name}", style="magenta") columns.add_renderable(table) console.print(columns) # console.save_html("box.html", inline_styles=True)
SILENT KILLER Tool