SILENT KILLERPanel

Current Path: > > opt > > hc_python > lib > python3.12 > 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 ]

Files and Folders in: //opt//hc_python/lib/python3.12/site-packages/pip//_vendor/rich

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 6090 bytes May 23 2025 10:34:25.
__main__.py File 8477 bytes May 23 2025 10:34:25.
_cell_widths.py File 10209 bytes May 23 2025 10:34:25.
_emoji_codes.py File 140235 bytes May 23 2025 10:34:25.
_emoji_replace.py File 1064 bytes May 23 2025 10:34:25.
_export_format.py File 2128 bytes May 23 2025 10:34:25.
_extension.py File 265 bytes May 23 2025 10:34:25.
_fileno.py File 799 bytes May 23 2025 10:34:25.
_inspect.py File 9655 bytes May 23 2025 10:34:25.
_log_render.py File 3225 bytes May 23 2025 10:34:25.
_loop.py File 1236 bytes May 23 2025 10:34:25.
_null_file.py File 1394 bytes May 23 2025 10:34:25.
_palettes.py File 7063 bytes May 23 2025 10:34:25.
_pick.py File 423 bytes May 23 2025 10:34:25.
_ratio.py File 5471 bytes May 23 2025 10:34:25.
_spinners.py File 19919 bytes May 23 2025 10:34:25.
_stack.py File 351 bytes May 23 2025 10:34:25.
_timer.py File 417 bytes May 23 2025 10:34:25.
_win32_console.py File 22755 bytes May 23 2025 10:34:25.
_windows.py File 1925 bytes May 23 2025 10:34:25.
_windows_renderer.py File 2783 bytes May 23 2025 10:34:25.
_wrap.py File 3404 bytes May 23 2025 10:34:25.
abc.py File 890 bytes May 23 2025 10:34:25.
align.py File 10469 bytes May 23 2025 10:34:25.
ansi.py File 6921 bytes May 23 2025 10:34:25.
bar.py File 3263 bytes May 23 2025 10:34:25.
box.py File 10831 bytes May 23 2025 10:34:25.
cells.py File 5130 bytes May 23 2025 10:34:25.
color.py File 18211 bytes May 23 2025 10:34:25.
color_triplet.py File 1054 bytes May 23 2025 10:34:25.
columns.py File 7131 bytes May 23 2025 10:34:25.
console.py File 100565 bytes May 23 2025 10:34:25.
constrain.py File 1288 bytes May 23 2025 10:34:25.
containers.py File 5502 bytes May 23 2025 10:34:25.
control.py File 6630 bytes May 23 2025 10:34:25.
default_styles.py File 8257 bytes May 23 2025 10:34:25.
diagnose.py File 998 bytes May 23 2025 10:34:25.
emoji.py File 2501 bytes May 23 2025 10:34:25.
errors.py File 642 bytes May 23 2025 10:34:25.
file_proxy.py File 1683 bytes May 23 2025 10:34:25.
filesize.py File 2484 bytes May 23 2025 10:34:25.
highlighter.py File 9586 bytes May 23 2025 10:34:25.
json.py File 5031 bytes May 23 2025 10:34:25.
jupyter.py File 3252 bytes May 23 2025 10:34:25.
layout.py File 14004 bytes May 23 2025 10:34:25.
live.py File 14270 bytes May 23 2025 10:34:25.
live_render.py File 3666 bytes May 23 2025 10:34:25.
logging.py File 12458 bytes May 23 2025 10:34:25.
markup.py File 8451 bytes May 23 2025 10:34:25.
measure.py File 5305 bytes May 23 2025 10:34:25.
padding.py File 4908 bytes May 23 2025 10:34:25.
pager.py File 828 bytes May 23 2025 10:34:25.
palette.py File 3396 bytes May 23 2025 10:34:25.
panel.py File 11225 bytes May 23 2025 10:34:25.
pretty.py File 36391 bytes May 23 2025 10:34:25.
progress.py File 60357 bytes May 23 2025 10:34:25.
progress_bar.py File 8162 bytes May 23 2025 10:34:25.
prompt.py File 12447 bytes May 23 2025 10:34:25.
protocol.py File 1391 bytes May 23 2025 10:34:25.
py.typed File 0 bytes May 23 2025 10:34:25.
region.py File 166 bytes May 23 2025 10:34:25.
repr.py File 4431 bytes May 23 2025 10:34:25.
rule.py File 4602 bytes May 23 2025 10:34:25.
scope.py File 2843 bytes May 23 2025 10:34:25.
screen.py File 1591 bytes May 23 2025 10:34:25.
segment.py File 24743 bytes May 23 2025 10:34:25.
spinner.py File 4364 bytes May 23 2025 10:34:25.
status.py File 4424 bytes May 23 2025 10:34:25.
style.py File 27059 bytes May 23 2025 10:34:25.
styled.py File 1258 bytes May 23 2025 10:34:25.
syntax.py File 35763 bytes May 23 2025 10:34:25.
table.py File 40049 bytes May 23 2025 10:34:25.
terminal_theme.py File 3370 bytes May 23 2025 10:34:25.
text.py File 47552 bytes May 23 2025 10:34:25.
theme.py File 3771 bytes May 23 2025 10:34:25.
themes.py File 102 bytes May 23 2025 10:34:25.
traceback.py File 35170 bytes May 23 2025 10:34:25.
tree.py File 9451 bytes May 23 2025 10:34:25.

Reading File: //opt//hc_python/lib/python3.12/site-packages/pip//_vendor/rich/padding.py

from typing import TYPE_CHECKING, List, Optional, Tuple, Union

if TYPE_CHECKING:
    from .console import (
        Console,
        ConsoleOptions,
        RenderableType,
        RenderResult,
    )

from .jupyter import JupyterMixin
from .measure import Measurement
from .segment import Segment
from .style import Style

PaddingDimensions = Union[int, Tuple[int], Tuple[int, int], Tuple[int, int, int, int]]


class Padding(JupyterMixin):
    """Draw space around content.

    Example:
        >>> print(Padding("Hello", (2, 4), style="on blue"))

    Args:
        renderable (RenderableType): String or other renderable.
        pad (Union[int, Tuple[int]]): Padding for top, right, bottom, and left borders.
            May be specified with 1, 2, or 4 integers (CSS style).
        style (Union[str, Style], optional): Style for padding characters. Defaults to "none".
        expand (bool, optional): Expand padding to fit available width. Defaults to True.
    """

    def __init__(
        self,
        renderable: "RenderableType",
        pad: "PaddingDimensions" = (0, 0, 0, 0),
        *,
        style: Union[str, Style] = "none",
        expand: bool = True,
    ):
        self.renderable = renderable
        self.top, self.right, self.bottom, self.left = self.unpack(pad)
        self.style = style
        self.expand = expand

    @classmethod
    def indent(cls, renderable: "RenderableType", level: int) -> "Padding":
        """Make padding instance to render an indent.

        Args:
            renderable (RenderableType): String or other renderable.
            level (int): Number of characters to indent.

        Returns:
            Padding: A Padding instance.
        """

        return Padding(renderable, pad=(0, 0, 0, level), expand=False)

    @staticmethod
    def unpack(pad: "PaddingDimensions") -> Tuple[int, int, int, int]:
        """Unpack padding specified in CSS style."""
        if isinstance(pad, int):
            return (pad, pad, pad, pad)
        if len(pad) == 1:
            _pad = pad[0]
            return (_pad, _pad, _pad, _pad)
        if len(pad) == 2:
            pad_top, pad_right = pad
            return (pad_top, pad_right, pad_top, pad_right)
        if len(pad) == 4:
            top, right, bottom, left = pad
            return (top, right, bottom, left)
        raise ValueError(f"1, 2 or 4 integers required for padding; {len(pad)} given")

    def __repr__(self) -> str:
        return f"Padding({self.renderable!r}, ({self.top},{self.right},{self.bottom},{self.left}))"

    def __rich_console__(
        self, console: "Console", options: "ConsoleOptions"
    ) -> "RenderResult":
        style = console.get_style(self.style)
        if self.expand:
            width = options.max_width
        else:
            width = min(
                Measurement.get(console, options, self.renderable).maximum
                + self.left
                + self.right,
                options.max_width,
            )
        render_options = options.update_width(width - self.left - self.right)
        if render_options.height is not None:
            render_options = render_options.update_height(
                height=render_options.height - self.top - self.bottom
            )
        lines = console.render_lines(
            self.renderable, render_options, style=style, pad=True
        )
        _Segment = Segment

        left = _Segment(" " * self.left, style) if self.left else None
        right = (
            [_Segment(f'{" " * self.right}', style), _Segment.line()]
            if self.right
            else [_Segment.line()]
        )
        blank_line: Optional[List[Segment]] = None
        if self.top:
            blank_line = [_Segment(f'{" " * width}\n', style)]
            yield from blank_line * self.top
        if left:
            for line in lines:
                yield left
                yield from line
                yield from right
        else:
            for line in lines:
                yield from line
                yield from right
        if self.bottom:
            blank_line = blank_line or [_Segment(f'{" " * width}\n', style)]
            yield from blank_line * self.bottom

    def __rich_measure__(
        self, console: "Console", options: "ConsoleOptions"
    ) -> "Measurement":
        max_width = options.max_width
        extra_width = self.left + self.right
        if max_width - extra_width < 1:
            return Measurement(max_width, max_width)
        measure_min, measure_max = Measurement.get(console, options, self.renderable)
        measurement = Measurement(measure_min + extra_width, measure_max + extra_width)
        measurement = measurement.with_maximum(max_width)
        return measurement


if __name__ == "__main__":  #  pragma: no cover
    from pip._vendor.rich import print

    print(Padding("Hello, World", (2, 4), style="on blue"))

SILENT KILLER Tool