SILENT KILLERPanel

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 ]

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

NameTypeSizeLast ModifiedActions
__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.

Reading File: //opt/alt/python38/lib//python3.8/site-packages//pip/_vendor/rich/live_render.py

import sys
from typing import Optional, Tuple

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
from .console import Console, ConsoleOptions, RenderableType, RenderResult
from .control import Control
from .segment import ControlType, Segment
from .style import StyleType
from .text import Text

VerticalOverflowMethod = Literal["crop", "ellipsis", "visible"]


class LiveRender:
    """Creates a renderable that may be updated.

    Args:
        renderable (RenderableType): Any renderable object.
        style (StyleType, optional): An optional style to apply to the renderable. Defaults to "".
    """

    def __init__(
        self,
        renderable: RenderableType,
        style: StyleType = "",
        vertical_overflow: VerticalOverflowMethod = "ellipsis",
    ) -> None:
        self.renderable = renderable
        self.style = style
        self.vertical_overflow = vertical_overflow
        self._shape: Optional[Tuple[int, int]] = None

    def set_renderable(self, renderable: RenderableType) -> None:
        """Set a new renderable.

        Args:
            renderable (RenderableType): Any renderable object, including str.
        """
        self.renderable = renderable

    def position_cursor(self) -> Control:
        """Get control codes to move cursor to beginning of live render.

        Returns:
            Control: A control instance that may be printed.
        """
        if self._shape is not None:
            _, height = self._shape
            return Control(
                ControlType.CARRIAGE_RETURN,
                (ControlType.ERASE_IN_LINE, 2),
                *(
                    (
                        (ControlType.CURSOR_UP, 1),
                        (ControlType.ERASE_IN_LINE, 2),
                    )
                    * (height - 1)
                )
            )
        return Control()

    def restore_cursor(self) -> Control:
        """Get control codes to clear the render and restore the cursor to its previous position.

        Returns:
            Control: A Control instance that may be printed.
        """
        if self._shape is not None:
            _, height = self._shape
            return Control(
                ControlType.CARRIAGE_RETURN,
                *((ControlType.CURSOR_UP, 1), (ControlType.ERASE_IN_LINE, 2)) * height
            )
        return Control()

    def __rich_console__(
        self, console: Console, options: ConsoleOptions
    ) -> RenderResult:

        renderable = self.renderable
        style = console.get_style(self.style)
        lines = console.render_lines(renderable, options, style=style, pad=False)
        shape = Segment.get_shape(lines)

        _, height = shape
        if height > options.size.height:
            if self.vertical_overflow == "crop":
                lines = lines[: options.size.height]
                shape = Segment.get_shape(lines)
            elif self.vertical_overflow == "ellipsis":
                lines = lines[: (options.size.height - 1)]
                overflow_text = Text(
                    "...",
                    overflow="crop",
                    justify="center",
                    end="",
                    style="live.ellipsis",
                )
                lines.append(list(console.render(overflow_text)))
                shape = Segment.get_shape(lines)
        self._shape = shape

        new_line = Segment.line()
        for last, line in loop_last(lines):
            yield from line
            if not last:
                yield new_line

SILENT KILLER Tool