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

from typing import TYPE_CHECKING, Any, Dict, Iterable, List, Sequence

if TYPE_CHECKING:
    from pip._vendor.rich.console import ConsoleRenderable

from . import get_console
from .segment import Segment
from .terminal_theme import DEFAULT_TERMINAL_THEME

if TYPE_CHECKING:
    from pip._vendor.rich.console import ConsoleRenderable

JUPYTER_HTML_FORMAT = """\
<pre style="white-space:pre;overflow-x:auto;line-height:normal;font-family:Menlo,'DejaVu Sans Mono',consolas,'Courier New',monospace">{code}</pre>
"""


class JupyterRenderable:
    """A shim to write html to Jupyter notebook."""

    def __init__(self, html: str, text: str) -> None:
        self.html = html
        self.text = text

    def _repr_mimebundle_(
        self, include: Sequence[str], exclude: Sequence[str], **kwargs: Any
    ) -> Dict[str, str]:
        data = {"text/plain": self.text, "text/html": self.html}
        if include:
            data = {k: v for (k, v) in data.items() if k in include}
        if exclude:
            data = {k: v for (k, v) in data.items() if k not in exclude}
        return data


class JupyterMixin:
    """Add to an Rich renderable to make it render in Jupyter notebook."""

    __slots__ = ()

    def _repr_mimebundle_(
        self: "ConsoleRenderable",
        include: Sequence[str],
        exclude: Sequence[str],
        **kwargs: Any,
    ) -> Dict[str, str]:
        console = get_console()
        segments = list(console.render(self, console.options))
        html = _render_segments(segments)
        text = console._render_buffer(segments)
        data = {"text/plain": text, "text/html": html}
        if include:
            data = {k: v for (k, v) in data.items() if k in include}
        if exclude:
            data = {k: v for (k, v) in data.items() if k not in exclude}
        return data


def _render_segments(segments: Iterable[Segment]) -> str:
    def escape(text: str) -> str:
        """Escape html."""
        return text.replace("&", "&amp;").replace("<", "&lt;").replace(">", "&gt;")

    fragments: List[str] = []
    append_fragment = fragments.append
    theme = DEFAULT_TERMINAL_THEME
    for text, style, control in Segment.simplify(segments):
        if control:
            continue
        text = escape(text)
        if style:
            rule = style.get_html_style(theme)
            text = f'<span style="{rule}">{text}</span>' if rule else text
            if style.link:
                text = f'<a href="{style.link}" target="_blank">{text}</a>'
        append_fragment(text)

    code = "".join(fragments)
    html = JUPYTER_HTML_FORMAT.format(code=code)

    return html


def display(segments: Iterable[Segment], text: str) -> None:
    """Render segments to Jupyter."""
    html = _render_segments(segments)
    jupyter_renderable = JupyterRenderable(html, text)
    try:
        from IPython.display import display as ipython_display

        ipython_display(jupyter_renderable)
    except ModuleNotFoundError:
        # Handle the case where the Console has force_jupyter=True,
        # but IPython is not installed.
        pass


def print(*args: Any, **kwargs: Any) -> None:
    """Proxy for Console print."""
    console = get_console()
    return console.print(*args, **kwargs)

SILENT KILLER Tool