GRAYBYTE WORDPRESS FILE MANAGER9220

Server IP : 198.54.121.189 / Your IP : 216.73.216.112
System : Linux premium69.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
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich//ansi.py
import re
import sys
from contextlib import suppress
from typing import Iterable, NamedTuple, Optional

from .color import Color
from .style import Style
from .text import Text

re_ansi = re.compile(
    r"""
(?:\x1b\](.*?)\x1b\\)|
(?:\x1b([(@-Z\\-_]|\[[0-?]*[ -/]*[@-~]))
""",
    re.VERBOSE,
)


class _AnsiToken(NamedTuple):
    """Result of ansi tokenized string."""

    plain: str = ""
    sgr: Optional[str] = ""
    osc: Optional[str] = ""


def _ansi_tokenize(ansi_text: str) -> Iterable[_AnsiToken]:
    """Tokenize a string in to plain text and ANSI codes.

    Args:
        ansi_text (str): A String containing ANSI codes.

    Yields:
        AnsiToken: A named tuple of (plain, sgr, osc)
    """

    position = 0
    sgr: Optional[str]
    osc: Optional[str]
    for match in re_ansi.finditer(ansi_text):
        start, end = match.span(0)
        osc, sgr = match.groups()
        if start > position:
            yield _AnsiToken(ansi_text[position:start])
        if sgr:
            if sgr == "(":
                position = end + 1
                continue
            if sgr.endswith("m"):
                yield _AnsiToken("", sgr[1:-1], osc)
        else:
            yield _AnsiToken("", sgr, osc)
        position = end
    if position < len(ansi_text):
        yield _AnsiToken(ansi_text[position:])


SGR_STYLE_MAP = {
    1: "bold",
    2: "dim",
    3: "italic",
    4: "underline",
    5: "blink",
    6: "blink2",
    7: "reverse",
    8: "conceal",
    9: "strike",
    21: "underline2",
    22: "not dim not bold",
    23: "not italic",
    24: "not underline",
    25: "not blink",
    26: "not blink2",
    27: "not reverse",
    28: "not conceal",
    29: "not strike",
    30: "color(0)",
    31: "color(1)",
    32: "color(2)",
    33: "color(3)",
    34: "color(4)",
    35: "color(5)",
    36: "color(6)",
    37: "color(7)",
    39: "default",
    40: "on color(0)",
    41: "on color(1)",
    42: "on color(2)",
    43: "on color(3)",
    44: "on color(4)",
    45: "on color(5)",
    46: "on color(6)",
    47: "on color(7)",
    49: "on default",
    51: "frame",
    52: "encircle",
    53: "overline",
    54: "not frame not encircle",
    55: "not overline",
    90: "color(8)",
    91: "color(9)",
    92: "color(10)",
    93: "color(11)",
    94: "color(12)",
    95: "color(13)",
    96: "color(14)",
    97: "color(15)",
    100: "on color(8)",
    101: "on color(9)",
    102: "on color(10)",
    103: "on color(11)",
    104: "on color(12)",
    105: "on color(13)",
    106: "on color(14)",
    107: "on color(15)",
}


class AnsiDecoder:
    """Translate ANSI code in to styled Text."""

    def __init__(self) -> None:
        self.style = Style.null()

    def decode(self, terminal_text: str) -> Iterable[Text]:
        """Decode ANSI codes in an iterable of lines.

        Args:
            lines (Iterable[str]): An iterable of lines of terminal output.

        Yields:
            Text: Marked up Text.
        """
        for line in terminal_text.splitlines():
            yield self.decode_line(line)

    def decode_line(self, line: str) -> Text:
        """Decode a line containing ansi codes.

        Args:
            line (str): A line of terminal output.

        Returns:
            Text: A Text instance marked up according to ansi codes.
        """
        from_ansi = Color.from_ansi
        from_rgb = Color.from_rgb
        _Style = Style
        text = Text()
        append = text.append
        line = line.rsplit("\r", 1)[-1]
        for plain_text, sgr, osc in _ansi_tokenize(line):
            if plain_text:
                append(plain_text, self.style or None)
            elif osc is not None:
                if osc.startswith("8;"):
                    _params, semicolon, link = osc[2:].partition(";")
                    if semicolon:
                        self.style = self.style.update_link(link or None)
            elif sgr is not None:
                # Translate in to semi-colon separated codes
                # Ignore invalid codes, because we want to be lenient
                codes = [
                    min(255, int(_code) if _code else 0)
                    for _code in sgr.split(";")
                    if _code.isdigit() or _code == ""
                ]
                iter_codes = iter(codes)
                for code in iter_codes:
                    if code == 0:
                        # reset
                        self.style = _Style.null()
                    elif code in SGR_STYLE_MAP:
                        # styles
                        self.style += _Style.parse(SGR_STYLE_MAP[code])
                    elif code == 38:
                        #  Foreground
                        with suppress(StopIteration):
                            color_type = next(iter_codes)
                            if color_type == 5:
                                self.style += _Style.from_color(
                                    from_ansi(next(iter_codes))
                                )
                            elif color_type == 2:
                                self.style += _Style.from_color(
                                    from_rgb(
                                        next(iter_codes),
                                        next(iter_codes),
                                        next(iter_codes),
                                    )
                                )
                    elif code == 48:
                        # Background
                        with suppress(StopIteration):
                            color_type = next(iter_codes)
                            if color_type == 5:
                                self.style += _Style.from_color(
                                    None, from_ansi(next(iter_codes))
                                )
                            elif color_type == 2:
                                self.style += _Style.from_color(
                                    None,
                                    from_rgb(
                                        next(iter_codes),
                                        next(iter_codes),
                                        next(iter_codes),
                                    ),
                                )

        return text


if sys.platform != "win32" and __name__ == "__main__":  # pragma: no cover
    import io
    import os
    import pty
    import sys

    decoder = AnsiDecoder()

    stdout = io.BytesIO()

    def read(fd: int) -> bytes:
        data = os.read(fd, 1024)
        stdout.write(data)
        return data

    pty.spawn(sys.argv[1:], read)

    from .console import Console

    console = Console(record=True)

    stdout_result = stdout.getvalue().decode("utf-8")
    print(stdout_result)

    for line in decoder.decode(stdout_result):
        console.print(line)

    console.save_html("stdout.html")

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
January 15 2025 09:40:17
root / linksafe
0755
__pycache__
--
January 15 2025 09:40:17
root / linksafe
0755
__init__.py
5.947 KB
December 01 2024 12:47:36
root / linksafe
0644
__main__.py
8.279 KB
December 01 2024 12:47:36
root / linksafe
0644
_cell_widths.py
9.859 KB
December 01 2024 12:47:36
root / linksafe
0644
_emoji_codes.py
136.948 KB
December 01 2024 12:47:36
root / linksafe
0644
_emoji_replace.py
1.039 KB
December 01 2024 12:47:36
root / linksafe
0644
_export_format.py
2.051 KB
December 01 2024 12:47:36
root / linksafe
0644
_extension.py
0.259 KB
December 01 2024 12:47:36
root / linksafe
0644
_fileno.py
0.78 KB
December 01 2024 12:47:36
root / linksafe
0644
_inspect.py
9.468 KB
December 01 2024 12:47:36
root / linksafe
0644
_log_render.py
3.149 KB
December 01 2024 12:47:36
root / linksafe
0644
_loop.py
1.207 KB
December 01 2024 12:47:36
root / linksafe
0644
_null_file.py
1.354 KB
December 01 2024 12:47:36
root / linksafe
0644
_palettes.py
6.897 KB
December 01 2024 12:47:36
root / linksafe
0644
_pick.py
0.413 KB
December 01 2024 12:47:36
root / linksafe
0644
_ratio.py
5.344 KB
December 01 2024 12:47:36
root / linksafe
0644
_spinners.py
19.452 KB
December 01 2024 12:47:36
root / linksafe
0644
_stack.py
0.343 KB
December 01 2024 12:47:36
root / linksafe
0644
_timer.py
0.407 KB
December 01 2024 12:47:36
root / linksafe
0644
_win32_console.py
22.285 KB
December 01 2024 12:47:36
root / linksafe
0644
_windows.py
1.881 KB
December 01 2024 12:47:36
root / linksafe
0644
_windows_renderer.py
2.718 KB
December 01 2024 12:47:36
root / linksafe
0644
_wrap.py
1.797 KB
December 01 2024 12:47:36
root / linksafe
0644
abc.py
0.869 KB
December 01 2024 12:47:36
root / linksafe
0644
align.py
10.125 KB
December 01 2024 12:47:36
root / linksafe
0644
ansi.py
6.744 KB
December 01 2024 12:47:36
root / linksafe
0644
bar.py
3.188 KB
December 01 2024 12:47:36
root / linksafe
0644
box.py
9.611 KB
December 01 2024 12:47:36
root / linksafe
0644
cells.py
4.403 KB
December 01 2024 12:47:36
root / linksafe
0644
color.py
17.797 KB
December 01 2024 12:47:36
root / linksafe
0644
color_triplet.py
1.029 KB
December 01 2024 12:47:36
root / linksafe
0644
columns.py
6.964 KB
December 01 2024 12:47:36
root / linksafe
0644
console.py
96.893 KB
December 01 2024 12:47:36
root / linksafe
0644
constrain.py
1.258 KB
December 01 2024 12:47:36
root / linksafe
0644
containers.py
5.368 KB
December 01 2024 12:47:36
root / linksafe
0644
control.py
6.475 KB
December 01 2024 12:47:36
root / linksafe
0644
default_styles.py
7.893 KB
December 01 2024 12:47:36
root / linksafe
0644
diagnose.py
0.949 KB
December 01 2024 12:47:36
root / linksafe
0644
emoji.py
2.442 KB
December 01 2024 12:47:36
root / linksafe
0644
errors.py
0.627 KB
December 01 2024 12:47:36
root / linksafe
0644
file_proxy.py
1.644 KB
December 01 2024 12:47:36
root / linksafe
0644
filesize.py
2.449 KB
December 01 2024 12:47:36
root / linksafe
0644
highlighter.py
9.359 KB
December 01 2024 12:47:36
root / linksafe
0644
json.py
4.914 KB
December 01 2024 12:47:36
root / linksafe
0644
jupyter.py
3.176 KB
December 01 2024 12:47:36
root / linksafe
0644
layout.py
13.679 KB
December 01 2024 12:47:36
root / linksafe
0644
live.py
13.938 KB
December 01 2024 12:47:36
root / linksafe
0644
live_render.py
3.581 KB
December 01 2024 12:47:36
root / linksafe
0644
logging.py
11.624 KB
December 01 2024 12:47:36
root / linksafe
0644
markup.py
8.006 KB
December 01 2024 12:47:36
root / linksafe
0644
measure.py
5.181 KB
December 01 2024 12:47:36
root / linksafe
0644
padding.py
4.854 KB
December 01 2024 12:47:36
root / linksafe
0644
pager.py
0.809 KB
December 01 2024 12:47:36
root / linksafe
0644
palette.py
3.316 KB
December 01 2024 12:47:36
root / linksafe
0644
panel.py
10.326 KB
December 01 2024 12:47:36
root / linksafe
0644
pretty.py
35.012 KB
December 01 2024 12:47:36
root / linksafe
0644
progress.py
58.307 KB
December 01 2024 12:47:36
root / linksafe
0644
progress_bar.py
7.974 KB
December 01 2024 12:47:36
root / linksafe
0644
prompt.py
11.038 KB
December 01 2024 12:47:36
root / linksafe
0644
protocol.py
1.358 KB
December 01 2024 12:47:36
root / linksafe
0644
py.typed
0 KB
December 01 2024 12:47:36
root / linksafe
0644
region.py
0.162 KB
December 01 2024 12:47:36
root / linksafe
0644
repr.py
4.327 KB
December 01 2024 12:47:36
root / linksafe
0644
rule.py
4.494 KB
December 01 2024 12:47:36
root / linksafe
0644
scope.py
2.776 KB
December 01 2024 12:47:36
root / linksafe
0644
screen.py
1.554 KB
December 01 2024 12:47:36
root / linksafe
0644
segment.py
23.679 KB
December 01 2024 12:47:36
root / linksafe
0644
spinner.py
4.237 KB
December 01 2024 12:47:36
root / linksafe
0644
status.py
4.321 KB
December 01 2024 12:47:36
root / linksafe
0644
style.py
26.438 KB
December 01 2024 12:47:36
root / linksafe
0644
styled.py
1.229 KB
December 01 2024 12:47:36
root / linksafe
0644
syntax.py
34.349 KB
December 01 2024 12:47:36
root / linksafe
0644
table.py
38.754 KB
December 01 2024 12:47:36
root / linksafe
0644
terminal_theme.py
3.291 KB
December 01 2024 12:47:36
root / linksafe
0644
text.py
44.458 KB
December 01 2024 12:47:36
root / linksafe
0644
theme.py
3.688 KB
December 01 2024 12:47:36
root / linksafe
0644
themes.py
0.1 KB
December 01 2024 12:47:36
root / linksafe
0644
traceback.py
28.91 KB
December 01 2024 12:47:36
root / linksafe
0644
tree.py
8.954 KB
December 01 2024 12:47:36
root / linksafe
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF