Linux vmi2545633.contaboserver.net 6.1.0-32-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.129-1 (2025-03-06) x86_64
Apache/2.4.62 (Debian)
Server IP : 127.0.0.1 & Your IP : 127.0.0.1
Domains :
Cant Read [ /etc/named.conf ]
User : www-data
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
usr /
lib /
python3 /
dist-packages /
pip /
_vendor /
rich /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2025-04-08 16:44
__init__.py
5.95
KB
-rw-r--r--
2023-02-19 14:19
__main__.py
8.28
KB
-rw-r--r--
2023-02-19 14:19
_cell_widths.py
9.86
KB
-rw-r--r--
2023-02-19 14:19
_emoji_codes.py
136.95
KB
-rw-r--r--
2023-02-19 14:19
_emoji_replace.py
1.04
KB
-rw-r--r--
2023-02-19 14:19
_export_format.py
2.06
KB
-rw-r--r--
2023-02-19 14:19
_extension.py
265
B
-rw-r--r--
2023-02-19 14:19
_inspect.py
9.47
KB
-rw-r--r--
2023-02-19 14:19
_log_render.py
3.15
KB
-rw-r--r--
2023-02-19 14:19
_loop.py
1.21
KB
-rw-r--r--
2023-02-19 14:19
_null_file.py
1.6
KB
-rw-r--r--
2023-02-19 14:19
_palettes.py
6.9
KB
-rw-r--r--
2023-02-19 14:19
_pick.py
423
B
-rw-r--r--
2023-02-19 14:19
_ratio.py
5.34
KB
-rw-r--r--
2023-02-19 14:19
_spinners.py
19.45
KB
-rw-r--r--
2023-02-19 14:19
_stack.py
351
B
-rw-r--r--
2023-02-19 14:19
_timer.py
417
B
-rw-r--r--
2023-02-19 14:19
_win32_console.py
22.29
KB
-rw-r--r--
2023-02-19 14:19
_windows.py
1.88
KB
-rw-r--r--
2023-02-19 14:19
_windows_renderer.py
2.72
KB
-rw-r--r--
2023-02-19 14:19
_wrap.py
1.8
KB
-rw-r--r--
2023-02-19 14:19
abc.py
890
B
-rw-r--r--
2023-02-19 14:19
align.py
10.13
KB
-rw-r--r--
2023-02-19 14:19
ansi.py
6.66
KB
-rw-r--r--
2023-02-19 14:19
bar.py
3.19
KB
-rw-r--r--
2023-02-19 14:19
box.py
9.61
KB
-rw-r--r--
2023-02-19 14:19
cells.py
4.4
KB
-rw-r--r--
2023-02-19 14:19
color.py
17.59
KB
-rw-r--r--
2023-02-19 14:19
color_triplet.py
1.03
KB
-rw-r--r--
2023-02-19 14:19
columns.py
6.96
KB
-rw-r--r--
2023-02-19 14:19
console.py
95.7
KB
-rw-r--r--
2023-02-19 14:19
constrain.py
1.26
KB
-rw-r--r--
2023-02-19 14:19
containers.py
5.37
KB
-rw-r--r--
2023-02-19 14:19
control.py
6.47
KB
-rw-r--r--
2023-02-19 14:19
default_styles.py
7.77
KB
-rw-r--r--
2023-02-19 14:19
diagnose.py
972
B
-rw-r--r--
2023-02-19 14:19
emoji.py
2.44
KB
-rw-r--r--
2023-02-19 14:19
errors.py
642
B
-rw-r--r--
2023-02-19 14:19
file_proxy.py
1.58
KB
-rw-r--r--
2023-02-19 14:19
filesize.py
2.45
KB
-rw-r--r--
2023-02-19 14:19
highlighter.py
9.36
KB
-rw-r--r--
2023-02-19 14:19
json.py
4.93
KB
-rw-r--r--
2023-02-19 14:19
jupyter.py
3.18
KB
-rw-r--r--
2023-02-19 14:19
layout.py
13.68
KB
-rw-r--r--
2023-02-19 14:19
live.py
13.84
KB
-rw-r--r--
2023-02-19 14:19
live_render.py
3.58
KB
-rw-r--r--
2023-02-19 14:19
logging.py
11.62
KB
-rw-r--r--
2023-02-19 14:19
markup.py
8.01
KB
-rw-r--r--
2023-02-19 14:19
measure.py
5.18
KB
-rw-r--r--
2023-02-19 14:19
padding.py
4.85
KB
-rw-r--r--
2023-02-19 14:19
pager.py
828
B
-rw-r--r--
2023-02-19 14:19
palette.py
3.32
KB
-rw-r--r--
2023-02-19 14:19
panel.py
10.33
KB
-rw-r--r--
2023-02-19 14:19
pretty.py
36.54
KB
-rw-r--r--
2023-02-19 14:19
progress.py
58.43
KB
-rw-r--r--
2023-02-19 14:19
progress_bar.py
7.97
KB
-rw-r--r--
2023-02-19 14:19
prompt.py
11.04
KB
-rw-r--r--
2023-02-19 14:19
protocol.py
1.36
KB
-rw-r--r--
2023-02-19 14:19
region.py
166
B
-rw-r--r--
2023-02-19 14:19
repr.py
4.33
KB
-rw-r--r--
2023-02-19 14:19
rule.py
4.66
KB
-rw-r--r--
2023-02-19 14:19
scope.py
2.78
KB
-rw-r--r--
2023-02-19 14:19
screen.py
1.55
KB
-rw-r--r--
2023-02-19 14:19
segment.py
23.66
KB
-rw-r--r--
2023-02-19 14:19
spinner.py
4.27
KB
-rw-r--r--
2023-02-19 14:19
status.py
4.32
KB
-rw-r--r--
2023-02-19 14:19
style.py
25.71
KB
-rw-r--r--
2023-02-19 14:19
styled.py
1.23
KB
-rw-r--r--
2023-02-19 14:19
syntax.py
34.17
KB
-rw-r--r--
2023-02-19 14:19
table.py
38.75
KB
-rw-r--r--
2023-02-19 14:19
terminal_theme.py
3.29
KB
-rw-r--r--
2023-02-19 14:19
text.py
44.62
KB
-rw-r--r--
2023-02-19 14:19
theme.py
3.54
KB
-rw-r--r--
2023-02-19 14:19
themes.py
102
B
-rw-r--r--
2023-02-19 14:19
traceback.py
25.46
KB
-rw-r--r--
2023-02-19 14:19
tree.py
8.95
KB
-rw-r--r--
2023-02-19 14:19
Save
Rename
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 len(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 == 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)