GRAYBYTE WORDPRESS FILE MANAGER9651

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/cloudlinux/venv/lib/python3.11/site-packages/pip/_vendor/rich/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/cloudlinux/venv/lib/python3.11/site-packages/pip/_vendor/rich//repr.py
import inspect
from functools import partial
from typing import (
    Any,
    Callable,
    Iterable,
    List,
    Optional,
    Tuple,
    Type,
    TypeVar,
    Union,
    overload,
)

T = TypeVar("T")


Result = Iterable[Union[Any, Tuple[Any], Tuple[str, Any], Tuple[str, Any, Any]]]
RichReprResult = Result


class ReprError(Exception):
    """An error occurred when attempting to build a repr."""


@overload
def auto(cls: Optional[Type[T]]) -> Type[T]:
    ...


@overload
def auto(*, angular: bool = False) -> Callable[[Type[T]], Type[T]]:
    ...


def auto(
    cls: Optional[Type[T]] = None, *, angular: Optional[bool] = None
) -> Union[Type[T], Callable[[Type[T]], Type[T]]]:
    """Class decorator to create __repr__ from __rich_repr__"""

    def do_replace(cls: Type[T], angular: Optional[bool] = None) -> Type[T]:
        def auto_repr(self: T) -> str:
            """Create repr string from __rich_repr__"""
            repr_str: List[str] = []
            append = repr_str.append

            angular: bool = getattr(self.__rich_repr__, "angular", False)  # type: ignore[attr-defined]
            for arg in self.__rich_repr__():  # type: ignore[attr-defined]
                if isinstance(arg, tuple):
                    if len(arg) == 1:
                        append(repr(arg[0]))
                    else:
                        key, value, *default = arg
                        if key is None:
                            append(repr(value))
                        else:
                            if default and default[0] == value:
                                continue
                            append(f"{key}={value!r}")
                else:
                    append(repr(arg))
            if angular:
                return f"<{self.__class__.__name__} {' '.join(repr_str)}>"
            else:
                return f"{self.__class__.__name__}({', '.join(repr_str)})"

        def auto_rich_repr(self: Type[T]) -> Result:
            """Auto generate __rich_rep__ from signature of __init__"""
            try:
                signature = inspect.signature(self.__init__)
                for name, param in signature.parameters.items():
                    if param.kind == param.POSITIONAL_ONLY:
                        yield getattr(self, name)
                    elif param.kind in (
                        param.POSITIONAL_OR_KEYWORD,
                        param.KEYWORD_ONLY,
                    ):
                        if param.default is param.empty:
                            yield getattr(self, param.name)
                        else:
                            yield param.name, getattr(self, param.name), param.default
            except Exception as error:
                raise ReprError(
                    f"Failed to auto generate __rich_repr__; {error}"
                ) from None

        if not hasattr(cls, "__rich_repr__"):
            auto_rich_repr.__doc__ = "Build a rich repr"
            cls.__rich_repr__ = auto_rich_repr  # type: ignore[attr-defined]

        auto_repr.__doc__ = "Return repr(self)"
        cls.__repr__ = auto_repr  # type: ignore[assignment]
        if angular is not None:
            cls.__rich_repr__.angular = angular  # type: ignore[attr-defined]
        return cls

    if cls is None:
        return partial(do_replace, angular=angular)
    else:
        return do_replace(cls, angular=angular)


@overload
def rich_repr(cls: Optional[Type[T]]) -> Type[T]:
    ...


@overload
def rich_repr(*, angular: bool = False) -> Callable[[Type[T]], Type[T]]:
    ...


def rich_repr(
    cls: Optional[Type[T]] = None, *, angular: bool = False
) -> Union[Type[T], Callable[[Type[T]], Type[T]]]:
    if cls is None:
        return auto(angular=angular)
    else:
        return auto(cls)


if __name__ == "__main__":

    @auto
    class Foo:
        def __rich_repr__(self) -> Result:
            yield "foo"
            yield "bar", {"shopping": ["eggs", "ham", "pineapple"]}
            yield "buy", "hand sanitizer"

    foo = Foo()
    from pip._vendor.rich.console import Console

    console = Console()

    console.rule("Standard repr")
    console.print(foo)

    console.print(foo, width=60)
    console.print(foo, width=30)

    console.rule("Angular repr")
    Foo.__rich_repr__.angular = True  # type: ignore[attr-defined]

    console.print(foo)

    console.print(foo, width=60)
    console.print(foo, width=30)

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
May 15 2025 08:30:34
root / root
0755
__pycache__
--
June 07 2025 08:30:29
root / root
0755
__init__.py
5.947 KB
April 17 2025 13:10:58
root / root
0644
__main__.py
8.278 KB
April 17 2025 13:10:58
root / root
0644
_cell_widths.py
9.97 KB
April 17 2025 13:10:58
root / root
0644
_emoji_codes.py
136.948 KB
April 17 2025 13:10:58
root / root
0644
_emoji_replace.py
1.039 KB
April 17 2025 13:10:58
root / root
0644
_export_format.py
2.078 KB
April 17 2025 13:10:58
root / root
0644
_extension.py
0.259 KB
April 17 2025 13:10:58
root / root
0644
_fileno.py
0.78 KB
April 17 2025 13:10:58
root / root
0644
_inspect.py
9.429 KB
April 17 2025 13:10:58
root / root
0644
_log_render.py
3.149 KB
April 17 2025 13:10:58
root / root
0644
_loop.py
1.207 KB
April 17 2025 13:10:58
root / root
0644
_null_file.py
1.361 KB
April 17 2025 13:10:58
root / root
0644
_palettes.py
6.897 KB
April 17 2025 13:10:58
root / root
0644
_pick.py
0.413 KB
April 17 2025 13:10:58
root / root
0644
_ratio.py
5.343 KB
April 17 2025 13:10:58
root / root
0644
_spinners.py
19.452 KB
April 17 2025 13:10:58
root / root
0644
_stack.py
0.343 KB
April 17 2025 13:10:58
root / root
0644
_timer.py
0.407 KB
April 17 2025 13:10:58
root / root
0644
_win32_console.py
22.222 KB
April 17 2025 13:10:58
root / root
0644
_windows.py
1.88 KB
April 17 2025 13:10:58
root / root
0644
_windows_renderer.py
2.718 KB
April 17 2025 13:10:58
root / root
0644
_wrap.py
3.324 KB
April 17 2025 13:10:58
root / root
0644
abc.py
0.869 KB
April 17 2025 13:10:58
root / root
0644
align.py
10.224 KB
April 17 2025 13:10:58
root / root
0644
ansi.py
6.759 KB
April 17 2025 13:10:58
root / root
0644
bar.py
3.187 KB
April 17 2025 13:10:58
root / root
0644
box.py
10.577 KB
April 17 2025 13:10:58
root / root
0644
cells.py
5.01 KB
April 17 2025 13:10:58
root / root
0644
color.py
17.784 KB
April 17 2025 13:10:58
root / root
0644
color_triplet.py
1.029 KB
April 17 2025 13:10:58
root / root
0644
columns.py
6.964 KB
April 17 2025 13:10:58
root / root
0644
console.py
97.809 KB
April 17 2025 13:10:58
root / root
0644
constrain.py
1.258 KB
April 17 2025 13:10:58
root / root
0644
containers.py
5.373 KB
April 17 2025 13:10:58
root / root
0644
control.py
6.475 KB
April 17 2025 13:10:58
root / root
0644
default_styles.py
7.968 KB
April 17 2025 13:10:58
root / root
0644
diagnose.py
0.949 KB
April 17 2025 13:10:58
root / root
0644
emoji.py
2.442 KB
April 17 2025 13:10:58
root / root
0644
errors.py
0.627 KB
April 17 2025 13:10:58
root / root
0644
file_proxy.py
1.644 KB
April 17 2025 13:10:58
root / root
0644
filesize.py
2.426 KB
April 17 2025 13:10:58
root / root
0644
highlighter.py
9.361 KB
April 17 2025 13:10:58
root / root
0644
json.py
4.913 KB
April 17 2025 13:10:58
root / root
0644
jupyter.py
3.176 KB
April 17 2025 13:10:58
root / root
0644
layout.py
13.676 KB
April 17 2025 13:10:58
root / root
0644
live.py
13.936 KB
April 17 2025 13:10:58
root / root
0644
live_render.py
3.58 KB
April 17 2025 13:10:58
root / root
0644
logging.py
12.166 KB
April 17 2025 13:10:58
root / root
0644
markup.py
8.253 KB
April 17 2025 13:10:58
root / root
0644
measure.py
5.181 KB
April 17 2025 13:10:58
root / root
0644
padding.py
4.793 KB
April 17 2025 13:10:58
root / root
0644
pager.py
0.809 KB
April 17 2025 13:10:58
root / root
0644
palette.py
3.316 KB
April 17 2025 13:10:58
root / root
0644
panel.py
10.972 KB
April 17 2025 13:10:58
root / root
0644
pretty.py
35.538 KB
April 17 2025 13:10:58
root / root
0644
progress.py
58.942 KB
April 17 2025 13:10:58
root / root
0644
progress_bar.py
7.971 KB
April 17 2025 13:10:58
root / root
0644
prompt.py
12.155 KB
April 17 2025 13:10:58
root / root
0644
protocol.py
1.358 KB
April 17 2025 13:10:58
root / root
0644
py.typed
0 KB
April 17 2025 13:10:58
root / root
0644
region.py
0.162 KB
April 17 2025 13:10:58
root / root
0644
repr.py
4.327 KB
April 17 2025 13:10:58
root / root
0644
rule.py
4.494 KB
April 17 2025 13:10:58
root / root
0644
scope.py
2.776 KB
April 17 2025 13:10:58
root / root
0644
screen.py
1.554 KB
April 17 2025 13:10:58
root / root
0644
segment.py
24.163 KB
April 17 2025 13:10:58
root / root
0644
spinner.py
4.262 KB
April 17 2025 13:10:58
root / root
0644
status.py
4.32 KB
April 17 2025 13:10:58
root / root
0644
style.py
26.433 KB
April 17 2025 13:10:58
root / root
0644
styled.py
1.229 KB
April 17 2025 13:10:58
root / root
0644
syntax.py
34.925 KB
April 17 2025 13:10:58
root / root
0644
table.py
39.163 KB
April 17 2025 13:10:58
root / root
0644
terminal_theme.py
3.291 KB
April 17 2025 13:10:58
root / root
0644
text.py
46.438 KB
April 17 2025 13:10:58
root / root
0644
theme.py
3.683 KB
April 17 2025 13:10:58
root / root
0644
themes.py
0.1 KB
April 17 2025 13:10:58
root / root
0644
traceback.py
31.052 KB
April 17 2025 13:10:58
root / root
0644
tree.py
9.229 KB
April 17 2025 13:10:58
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF