SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > > 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/cloudlinux/venv/lib64/python3.11//site-packages/pip/_vendor/rich

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

Reading File: //opt/cloudlinux/venv/lib64/python3.11//site-packages/pip/_vendor/rich/theme.py

import configparser
from typing import IO, Dict, List, Mapping, Optional

from .default_styles import DEFAULT_STYLES
from .style import Style, StyleType


class Theme:
    """A container for style information, used by :class:`~rich.console.Console`.

    Args:
        styles (Dict[str, Style], optional): A mapping of style names on to styles. Defaults to None for a theme with no styles.
        inherit (bool, optional): Inherit default styles. Defaults to True.
    """

    styles: Dict[str, Style]

    def __init__(
        self, styles: Optional[Mapping[str, StyleType]] = None, inherit: bool = True
    ):
        self.styles = DEFAULT_STYLES.copy() if inherit else {}
        if styles is not None:
            self.styles.update(
                {
                    name: style if isinstance(style, Style) else Style.parse(style)
                    for name, style in styles.items()
                }
            )

    @property
    def config(self) -> str:
        """Get contents of a config file for this theme."""
        config = "[styles]\n" + "\n".join(
            f"{name} = {style}" for name, style in sorted(self.styles.items())
        )
        return config

    @classmethod
    def from_file(
        cls, config_file: IO[str], source: Optional[str] = None, inherit: bool = True
    ) -> "Theme":
        """Load a theme from a text mode file.

        Args:
            config_file (IO[str]): An open conf file.
            source (str, optional): The filename of the open file. Defaults to None.
            inherit (bool, optional): Inherit default styles. Defaults to True.

        Returns:
            Theme: A New theme instance.
        """
        config = configparser.ConfigParser()
        config.read_file(config_file, source=source)
        styles = {name: Style.parse(value) for name, value in config.items("styles")}
        theme = Theme(styles, inherit=inherit)
        return theme

    @classmethod
    def read(
        cls, path: str, inherit: bool = True, encoding: Optional[str] = None
    ) -> "Theme":
        """Read a theme from a path.

        Args:
            path (str): Path to a config file readable by Python configparser module.
            inherit (bool, optional): Inherit default styles. Defaults to True.
            encoding (str, optional): Encoding of the config file. Defaults to None.

        Returns:
            Theme: A new theme instance.
        """
        with open(path, encoding=encoding) as config_file:
            return cls.from_file(config_file, source=path, inherit=inherit)


class ThemeStackError(Exception):
    """Base exception for errors related to the theme stack."""


class ThemeStack:
    """A stack of themes.

    Args:
        theme (Theme): A theme instance
    """

    def __init__(self, theme: Theme) -> None:
        self._entries: List[Dict[str, Style]] = [theme.styles]
        self.get = self._entries[-1].get

    def push_theme(self, theme: Theme, inherit: bool = True) -> None:
        """Push a theme on the top of the stack.

        Args:
            theme (Theme): A Theme instance.
            inherit (boolean, optional): Inherit styles from current top of stack.
        """
        styles: Dict[str, Style]
        styles = (
            {**self._entries[-1], **theme.styles} if inherit else theme.styles.copy()
        )
        self._entries.append(styles)
        self.get = self._entries[-1].get

    def pop_theme(self) -> None:
        """Pop (and discard) the top-most theme."""
        if len(self._entries) == 1:
            raise ThemeStackError("Unable to pop base theme")
        self._entries.pop()
        self.get = self._entries[-1].get


if __name__ == "__main__":  # pragma: no cover
    theme = Theme()
    print(theme.config)

SILENT KILLER Tool