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/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