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 /
local /
lib /
python3.11 /
dist-packages /
rich /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2025-04-08 17:01
__init__.py
5.92
KB
-rw-r--r--
2025-04-08 17:01
__main__.py
8.14
KB
-rw-r--r--
2025-04-08 17:01
_cell_widths.py
9.97
KB
-rw-r--r--
2025-04-08 17:01
_emoji_codes.py
136.95
KB
-rw-r--r--
2025-04-08 17:01
_emoji_replace.py
1.04
KB
-rw-r--r--
2025-04-08 17:01
_export_format.py
2.08
KB
-rw-r--r--
2025-04-08 17:01
_extension.py
241
B
-rw-r--r--
2025-04-08 17:01
_fileno.py
799
B
-rw-r--r--
2025-04-08 17:01
_inspect.py
9.43
KB
-rw-r--r--
2025-04-08 17:01
_log_render.py
3.14
KB
-rw-r--r--
2025-04-08 17:01
_loop.py
1.21
KB
-rw-r--r--
2025-04-08 17:01
_null_file.py
1.36
KB
-rw-r--r--
2025-04-08 17:01
_palettes.py
6.9
KB
-rw-r--r--
2025-04-08 17:01
_pick.py
423
B
-rw-r--r--
2025-04-08 17:01
_ratio.py
5.33
KB
-rw-r--r--
2025-04-08 17:01
_spinners.py
19.45
KB
-rw-r--r--
2025-04-08 17:01
_stack.py
351
B
-rw-r--r--
2025-04-08 17:01
_timer.py
417
B
-rw-r--r--
2025-04-08 17:01
_win32_console.py
22.19
KB
-rw-r--r--
2025-04-08 17:01
_windows.py
1.86
KB
-rw-r--r--
2025-04-08 17:01
_windows_renderer.py
2.69
KB
-rw-r--r--
2025-04-08 17:01
_wrap.py
3.32
KB
-rw-r--r--
2025-04-08 17:01
abc.py
878
B
-rw-r--r--
2025-04-08 17:01
align.py
10.18
KB
-rw-r--r--
2025-04-08 17:01
ansi.py
6.76
KB
-rw-r--r--
2025-04-08 17:01
bar.py
3.19
KB
-rw-r--r--
2025-04-08 17:01
box.py
10.53
KB
-rw-r--r--
2025-04-08 17:01
cells.py
5.01
KB
-rw-r--r--
2025-04-08 17:01
color.py
17.78
KB
-rw-r--r--
2025-04-08 17:01
color_triplet.py
1.03
KB
-rw-r--r--
2025-04-08 17:01
columns.py
6.96
KB
-rw-r--r--
2025-04-08 17:01
console.py
98.14
KB
-rw-r--r--
2025-04-08 17:01
constrain.py
1.26
KB
-rw-r--r--
2025-04-08 17:01
containers.py
5.37
KB
-rw-r--r--
2025-04-08 17:01
control.py
6.45
KB
-rw-r--r--
2025-04-08 17:01
default_styles.py
8.03
KB
-rw-r--r--
2025-04-08 17:01
diagnose.py
950
B
-rw-r--r--
2025-04-08 17:01
emoji.py
2.41
KB
-rw-r--r--
2025-04-08 17:01
errors.py
642
B
-rw-r--r--
2025-04-08 17:01
file_proxy.py
1.64
KB
-rw-r--r--
2025-04-08 17:01
filesize.py
2.43
KB
-rw-r--r--
2025-04-08 17:01
highlighter.py
9.36
KB
-rw-r--r--
2025-04-08 17:01
json.py
4.9
KB
-rw-r--r--
2025-04-08 17:01
jupyter.py
3.15
KB
-rw-r--r--
2025-04-08 17:01
layout.py
13.62
KB
-rw-r--r--
2025-04-08 17:01
live.py
13.94
KB
-rw-r--r--
2025-04-08 17:01
live_render.py
3.57
KB
-rw-r--r--
2025-04-08 17:01
logging.py
12.15
KB
-rw-r--r--
2025-04-08 17:01
markdown.py
25.36
KB
-rw-r--r--
2025-04-08 17:01
markup.py
8.23
KB
-rw-r--r--
2025-04-08 17:01
measure.py
5.18
KB
-rw-r--r--
2025-04-08 17:01
padding.py
4.78
KB
-rw-r--r--
2025-04-08 17:01
pager.py
828
B
-rw-r--r--
2025-04-08 17:01
palette.py
3.21
KB
-rw-r--r--
2025-04-08 17:01
panel.py
10.96
KB
-rw-r--r--
2025-04-08 17:01
pretty.py
35.5
KB
-rw-r--r--
2025-04-08 17:01
progress.py
58.92
KB
-rw-r--r--
2025-04-08 17:01
progress_bar.py
7.97
KB
-rw-r--r--
2025-04-08 17:01
prompt.py
12.14
KB
-rw-r--r--
2025-04-08 17:01
protocol.py
1.33
KB
-rw-r--r--
2025-04-08 17:01
py.typed
0
B
-rw-r--r--
2025-04-08 17:01
region.py
166
B
-rw-r--r--
2025-04-08 17:01
repr.py
4.32
KB
-rw-r--r--
2025-04-08 17:01
rule.py
4.48
KB
-rw-r--r--
2025-04-08 17:01
scope.py
2.76
KB
-rw-r--r--
2025-04-08 17:01
screen.py
1.54
KB
-rw-r--r--
2025-04-08 17:01
segment.py
24.13
KB
-rw-r--r--
2025-04-08 17:01
spinner.py
4.26
KB
-rw-r--r--
2025-04-08 17:01
status.py
4.32
KB
-rw-r--r--
2025-04-08 17:01
style.py
26.42
KB
-rw-r--r--
2025-04-08 17:01
styled.py
1.21
KB
-rw-r--r--
2025-04-08 17:01
syntax.py
34.82
KB
-rw-r--r--
2025-04-08 17:01
table.py
39.09
KB
-rw-r--r--
2025-04-08 17:01
terminal_theme.py
3.29
KB
-rw-r--r--
2025-04-08 17:01
text.py
46.43
KB
-rw-r--r--
2025-04-08 17:01
theme.py
3.68
KB
-rw-r--r--
2025-04-08 17:01
themes.py
102
B
-rw-r--r--
2025-04-08 17:01
traceback.py
34.28
KB
-rw-r--r--
2025-04-08 17:01
tree.py
9.17
KB
-rw-r--r--
2025-04-08 17:01
Save
Rename
from typing import cast, List, Optional, TYPE_CHECKING, Union from ._spinners import SPINNERS from .measure import Measurement from .table import Table from .text import Text if TYPE_CHECKING: from .console import Console, ConsoleOptions, RenderResult, RenderableType from .style import StyleType class Spinner: """A spinner animation. Args: name (str): Name of spinner (run python -m rich.spinner). text (RenderableType, optional): A renderable to display at the right of the spinner (str or Text typically). Defaults to "". style (StyleType, optional): Style for spinner animation. Defaults to None. speed (float, optional): Speed factor for animation. Defaults to 1.0. Raises: KeyError: If name isn't one of the supported spinner animations. """ def __init__( self, name: str, text: "RenderableType" = "", *, style: Optional["StyleType"] = None, speed: float = 1.0, ) -> None: try: spinner = SPINNERS[name] except KeyError: raise KeyError(f"no spinner called {name!r}") self.text: "Union[RenderableType, Text]" = ( Text.from_markup(text) if isinstance(text, str) else text ) self.name = name self.frames = cast(List[str], spinner["frames"])[:] self.interval = cast(float, spinner["interval"]) self.start_time: Optional[float] = None self.style = style self.speed = speed self.frame_no_offset: float = 0.0 self._update_speed = 0.0 def __rich_console__( self, console: "Console", options: "ConsoleOptions" ) -> "RenderResult": yield self.render(console.get_time()) def __rich_measure__( self, console: "Console", options: "ConsoleOptions" ) -> Measurement: text = self.render(0) return Measurement.get(console, options, text) def render(self, time: float) -> "RenderableType": """Render the spinner for a given time. Args: time (float): Time in seconds. Returns: RenderableType: A renderable containing animation frame. """ if self.start_time is None: self.start_time = time frame_no = ((time - self.start_time) * self.speed) / ( self.interval / 1000.0 ) + self.frame_no_offset frame = Text( self.frames[int(frame_no) % len(self.frames)], style=self.style or "" ) if self._update_speed: self.frame_no_offset = frame_no self.start_time = time self.speed = self._update_speed self._update_speed = 0.0 if not self.text: return frame elif isinstance(self.text, (str, Text)): return Text.assemble(frame, " ", self.text) else: table = Table.grid(padding=1) table.add_row(frame, self.text) return table def update( self, *, text: "RenderableType" = "", style: Optional["StyleType"] = None, speed: Optional[float] = None, ) -> None: """Updates attributes of a spinner after it has been started. Args: text (RenderableType, optional): A renderable to display at the right of the spinner (str or Text typically). Defaults to "". style (StyleType, optional): Style for spinner animation. Defaults to None. speed (float, optional): Speed factor for animation. Defaults to None. """ if text: self.text = Text.from_markup(text) if isinstance(text, str) else text if style: self.style = style if speed: self._update_speed = speed if __name__ == "__main__": # pragma: no cover from time import sleep from .columns import Columns from .panel import Panel from .live import Live all_spinners = Columns( [ Spinner(spinner_name, text=Text(repr(spinner_name), style="green")) for spinner_name in sorted(SPINNERS.keys()) ], column_first=True, expand=True, ) with Live( Panel(all_spinners, title="Spinners", border_style="blue"), refresh_per_second=20, ) as live: while True: sleep(0.1)