SILENT KILLERPanel

Current Path: > > opt > alt > python313 > lib > python3.13 > site-packages > pip > _vendor > rich


Operation   : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Software     : Apache
Server IP    : 198.54.126.42 | Your IP: 216.73.216.8
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 6090 bytes December 01 2024 12:47:36.
__main__.py File 8478 bytes December 01 2024 12:47:36.
_cell_widths.py File 10096 bytes December 01 2024 12:47:36.
_emoji_codes.py File 140235 bytes December 01 2024 12:47:36.
_emoji_replace.py File 1064 bytes December 01 2024 12:47:36.
_export_format.py File 2100 bytes December 01 2024 12:47:36.
_extension.py File 265 bytes December 01 2024 12:47:36.
_fileno.py File 799 bytes December 01 2024 12:47:36.
_inspect.py File 9695 bytes December 01 2024 12:47:36.
_log_render.py File 3225 bytes December 01 2024 12:47:36.
_loop.py File 1236 bytes December 01 2024 12:47:36.
_null_file.py File 1387 bytes December 01 2024 12:47:36.
_palettes.py File 7063 bytes December 01 2024 12:47:36.
_pick.py File 423 bytes December 01 2024 12:47:36.
_ratio.py File 5472 bytes December 01 2024 12:47:36.
_spinners.py File 19919 bytes December 01 2024 12:47:36.
_stack.py File 351 bytes December 01 2024 12:47:36.
_timer.py File 417 bytes December 01 2024 12:47:36.
_win32_console.py File 22820 bytes December 01 2024 12:47:36.
_windows.py File 1926 bytes December 01 2024 12:47:36.
_windows_renderer.py File 2783 bytes December 01 2024 12:47:36.
_wrap.py File 1840 bytes December 01 2024 12:47:36.
abc.py File 890 bytes December 01 2024 12:47:36.
align.py File 10368 bytes December 01 2024 12:47:36.
ansi.py File 6906 bytes December 01 2024 12:47:36.
bar.py File 3264 bytes December 01 2024 12:47:36.
box.py File 9842 bytes December 01 2024 12:47:36.
cells.py File 4509 bytes December 01 2024 12:47:36.
color.py File 18224 bytes December 01 2024 12:47:36.
color_triplet.py File 1054 bytes December 01 2024 12:47:36.
columns.py File 7131 bytes December 01 2024 12:47:36.
console.py File 99218 bytes December 01 2024 12:47:36.
constrain.py File 1288 bytes December 01 2024 12:47:36.
containers.py File 5497 bytes December 01 2024 12:47:36.
control.py File 6630 bytes December 01 2024 12:47:36.
default_styles.py File 8082 bytes December 01 2024 12:47:36.
diagnose.py File 972 bytes December 01 2024 12:47:36.
emoji.py File 2501 bytes December 01 2024 12:47:36.
errors.py File 642 bytes December 01 2024 12:47:36.
file_proxy.py File 1683 bytes December 01 2024 12:47:36.
filesize.py File 2508 bytes December 01 2024 12:47:36.
highlighter.py File 9584 bytes December 01 2024 12:47:36.
json.py File 5032 bytes December 01 2024 12:47:36.
jupyter.py File 3252 bytes December 01 2024 12:47:36.
layout.py File 14007 bytes December 01 2024 12:47:36.
live.py File 14273 bytes December 01 2024 12:47:36.
live_render.py File 3667 bytes December 01 2024 12:47:36.
logging.py File 11903 bytes December 01 2024 12:47:36.
markup.py File 8198 bytes December 01 2024 12:47:36.
measure.py File 5305 bytes December 01 2024 12:47:36.
padding.py File 4970 bytes December 01 2024 12:47:36.
pager.py File 828 bytes December 01 2024 12:47:36.
palette.py File 3396 bytes December 01 2024 12:47:36.
panel.py File 10574 bytes December 01 2024 12:47:36.
pretty.py File 35852 bytes December 01 2024 12:47:36.
progress.py File 59706 bytes December 01 2024 12:47:36.
progress_bar.py File 8165 bytes December 01 2024 12:47:36.
prompt.py File 11303 bytes December 01 2024 12:47:36.
protocol.py File 1391 bytes December 01 2024 12:47:36.
py.typed File 0 bytes December 01 2024 12:47:36.
region.py File 166 bytes December 01 2024 12:47:36.
repr.py File 4431 bytes December 01 2024 12:47:36.
rule.py File 4602 bytes December 01 2024 12:47:36.
scope.py File 2843 bytes December 01 2024 12:47:36.
screen.py File 1591 bytes December 01 2024 12:47:36.
segment.py File 24247 bytes December 01 2024 12:47:36.
spinner.py File 4339 bytes December 01 2024 12:47:36.
status.py File 4425 bytes December 01 2024 12:47:36.
style.py File 27073 bytes December 01 2024 12:47:36.
styled.py File 1258 bytes December 01 2024 12:47:36.
syntax.py File 35173 bytes December 01 2024 12:47:36.
table.py File 39684 bytes December 01 2024 12:47:36.
terminal_theme.py File 3370 bytes December 01 2024 12:47:36.
text.py File 45525 bytes December 01 2024 12:47:36.
theme.py File 3777 bytes December 01 2024 12:47:36.
themes.py File 102 bytes December 01 2024 12:47:36.
traceback.py File 29604 bytes December 01 2024 12:47:36.
tree.py File 9169 bytes December 01 2024 12:47:36.

Reading File: //opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich/rule.py

from typing import Union

from .align import AlignMethod
from .cells import cell_len, set_cell_size
from .console import Console, ConsoleOptions, RenderResult
from .jupyter import JupyterMixin
from .measure import Measurement
from .style import Style
from .text import Text


class Rule(JupyterMixin):
    """A console renderable to draw a horizontal rule (line).

    Args:
        title (Union[str, Text], optional): Text to render in the rule. Defaults to "".
        characters (str, optional): Character(s) used to draw the line. Defaults to "─".
        style (StyleType, optional): Style of Rule. Defaults to "rule.line".
        end (str, optional): Character at end of Rule. defaults to "\\\\n"
        align (str, optional): How to align the title, one of "left", "center", or "right". Defaults to "center".
    """

    def __init__(
        self,
        title: Union[str, Text] = "",
        *,
        characters: str = "─",
        style: Union[str, Style] = "rule.line",
        end: str = "\n",
        align: AlignMethod = "center",
    ) -> None:
        if cell_len(characters) < 1:
            raise ValueError(
                "'characters' argument must have a cell width of at least 1"
            )
        if align not in ("left", "center", "right"):
            raise ValueError(
                f'invalid value for align, expected "left", "center", "right" (not {align!r})'
            )
        self.title = title
        self.characters = characters
        self.style = style
        self.end = end
        self.align = align

    def __repr__(self) -> str:
        return f"Rule({self.title!r}, {self.characters!r})"

    def __rich_console__(
        self, console: Console, options: ConsoleOptions
    ) -> RenderResult:
        width = options.max_width

        characters = (
            "-"
            if (options.ascii_only and not self.characters.isascii())
            else self.characters
        )

        chars_len = cell_len(characters)
        if not self.title:
            yield self._rule_line(chars_len, width)
            return

        if isinstance(self.title, Text):
            title_text = self.title
        else:
            title_text = console.render_str(self.title, style="rule.text")

        title_text.plain = title_text.plain.replace("\n", " ")
        title_text.expand_tabs()

        required_space = 4 if self.align == "center" else 2
        truncate_width = max(0, width - required_space)
        if not truncate_width:
            yield self._rule_line(chars_len, width)
            return

        rule_text = Text(end=self.end)
        if self.align == "center":
            title_text.truncate(truncate_width, overflow="ellipsis")
            side_width = (width - cell_len(title_text.plain)) // 2
            left = Text(characters * (side_width // chars_len + 1))
            left.truncate(side_width - 1)
            right_length = width - cell_len(left.plain) - cell_len(title_text.plain)
            right = Text(characters * (side_width // chars_len + 1))
            right.truncate(right_length)
            rule_text.append(left.plain + " ", self.style)
            rule_text.append(title_text)
            rule_text.append(" " + right.plain, self.style)
        elif self.align == "left":
            title_text.truncate(truncate_width, overflow="ellipsis")
            rule_text.append(title_text)
            rule_text.append(" ")
            rule_text.append(characters * (width - rule_text.cell_len), self.style)
        elif self.align == "right":
            title_text.truncate(truncate_width, overflow="ellipsis")
            rule_text.append(characters * (width - title_text.cell_len - 1), self.style)
            rule_text.append(" ")
            rule_text.append(title_text)

        rule_text.plain = set_cell_size(rule_text.plain, width)
        yield rule_text

    def _rule_line(self, chars_len: int, width: int) -> Text:
        rule_text = Text(self.characters * ((width // chars_len) + 1), self.style)
        rule_text.truncate(width)
        rule_text.plain = set_cell_size(rule_text.plain, width)
        return rule_text

    def __rich_measure__(
        self, console: Console, options: ConsoleOptions
    ) -> Measurement:
        return Measurement(1, 1)


if __name__ == "__main__":  # pragma: no cover
    import sys

    from pip._vendor.rich.console import Console

    try:
        text = sys.argv[1]
    except IndexError:
        text = "Hello, World"
    console = Console()
    console.print(Rule(title=text))

    console = Console()
    console.print(Rule("foo"), width=4)

SILENT KILLER Tool