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/measure.py

from operator import itemgetter
from typing import TYPE_CHECKING, Callable, NamedTuple, Optional, Sequence

from . import errors
from .protocol import is_renderable, rich_cast

if TYPE_CHECKING:
    from .console import Console, ConsoleOptions, RenderableType


class Measurement(NamedTuple):
    """Stores the minimum and maximum widths (in characters) required to render an object."""

    minimum: int
    """Minimum number of cells required to render."""
    maximum: int
    """Maximum number of cells required to render."""

    @property
    def span(self) -> int:
        """Get difference between maximum and minimum."""
        return self.maximum - self.minimum

    def normalize(self) -> "Measurement":
        """Get measurement that ensures that minimum <= maximum and minimum >= 0

        Returns:
            Measurement: A normalized measurement.
        """
        minimum, maximum = self
        minimum = min(max(0, minimum), maximum)
        return Measurement(max(0, minimum), max(0, max(minimum, maximum)))

    def with_maximum(self, width: int) -> "Measurement":
        """Get a RenderableWith where the widths are <= width.

        Args:
            width (int): Maximum desired width.

        Returns:
            Measurement: New Measurement object.
        """
        minimum, maximum = self
        return Measurement(min(minimum, width), min(maximum, width))

    def with_minimum(self, width: int) -> "Measurement":
        """Get a RenderableWith where the widths are >= width.

        Args:
            width (int): Minimum desired width.

        Returns:
            Measurement: New Measurement object.
        """
        minimum, maximum = self
        width = max(0, width)
        return Measurement(max(minimum, width), max(maximum, width))

    def clamp(
        self, min_width: Optional[int] = None, max_width: Optional[int] = None
    ) -> "Measurement":
        """Clamp a measurement within the specified range.

        Args:
            min_width (int): Minimum desired width, or ``None`` for no minimum. Defaults to None.
            max_width (int): Maximum desired width, or ``None`` for no maximum. Defaults to None.

        Returns:
            Measurement: New Measurement object.
        """
        measurement = self
        if min_width is not None:
            measurement = measurement.with_minimum(min_width)
        if max_width is not None:
            measurement = measurement.with_maximum(max_width)
        return measurement

    @classmethod
    def get(
        cls, console: "Console", options: "ConsoleOptions", renderable: "RenderableType"
    ) -> "Measurement":
        """Get a measurement for a renderable.

        Args:
            console (~rich.console.Console): Console instance.
            options (~rich.console.ConsoleOptions): Console options.
            renderable (RenderableType): An object that may be rendered with Rich.

        Raises:
            errors.NotRenderableError: If the object is not renderable.

        Returns:
            Measurement: Measurement object containing range of character widths required to render the object.
        """
        _max_width = options.max_width
        if _max_width < 1:
            return Measurement(0, 0)
        if isinstance(renderable, str):
            renderable = console.render_str(
                renderable, markup=options.markup, highlight=False
            )
        renderable = rich_cast(renderable)
        if is_renderable(renderable):
            get_console_width: Optional[
                Callable[["Console", "ConsoleOptions"], "Measurement"]
            ] = getattr(renderable, "__rich_measure__", None)
            if get_console_width is not None:
                render_width = (
                    get_console_width(console, options)
                    .normalize()
                    .with_maximum(_max_width)
                )
                if render_width.maximum < 1:
                    return Measurement(0, 0)
                return render_width.normalize()
            else:
                return Measurement(0, _max_width)
        else:
            raise errors.NotRenderableError(
                f"Unable to get render width for {renderable!r}; "
                "a str, Segment, or object with __rich_console__ method is required"
            )


def measure_renderables(
    console: "Console",
    options: "ConsoleOptions",
    renderables: Sequence["RenderableType"],
) -> "Measurement":
    """Get a measurement that would fit a number of renderables.

    Args:
        console (~rich.console.Console): Console instance.
        options (~rich.console.ConsoleOptions): Console options.
        renderables (Iterable[RenderableType]): One or more renderable objects.

    Returns:
        Measurement: Measurement object containing range of character widths required to
            contain all given renderables.
    """
    if not renderables:
        return Measurement(0, 0)
    get_measurement = Measurement.get
    measurements = [
        get_measurement(console, options, renderable) for renderable in renderables
    ]
    measured_width = Measurement(
        max(measurements, key=itemgetter(0)).minimum,
        max(measurements, key=itemgetter(1)).maximum,
    )
    return measured_width

SILENT KILLER Tool