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
from typing import Union from .align import AlignMethod from .cells import cell_len, set_cell_size from .console import Console, ConsoleOptions, RenderResult from .jupyter import JupyterMixin from .measure import Measurement from .style import Style from .text import Text class Rule(JupyterMixin): """A console renderable to draw a horizontal rule (line). Args: title (Union[str, Text], optional): Text to render in the rule. Defaults to "". characters (str, optional): Character(s) used to draw the line. Defaults to "─". style (StyleType, optional): Style of Rule. Defaults to "rule.line". end (str, optional): Character at end of Rule. defaults to "\\\\n" align (str, optional): How to align the title, one of "left", "center", or "right". Defaults to "center". """ def __init__( self, title: Union[str, Text] = "", *, characters: str = "─", style: Union[str, Style] = "rule.line", end: str = "\n", align: AlignMethod = "center", ) -> None: if cell_len(characters) < 1: raise ValueError( "'characters' argument must have a cell width of at least 1" ) if align not in ("left", "center", "right"): raise ValueError( f'invalid value for align, expected "left", "center", "right" (not {align!r})' ) self.title = title self.characters = characters self.style = style self.end = end self.align = align def __repr__(self) -> str: return f"Rule({self.title!r}, {self.characters!r})" def __rich_console__( self, console: Console, options: ConsoleOptions ) -> RenderResult: width = options.max_width # Python3.6 doesn't have an isascii method on str isascii = getattr(str, "isascii", None) or ( lambda s: all(ord(c) < 128 for c in s) ) characters = ( "-" if (options.ascii_only and not isascii(self.characters)) else self.characters ) chars_len = cell_len(characters) if not self.title: yield self._rule_line(chars_len, width) return if isinstance(self.title, Text): title_text = self.title else: title_text = console.render_str(self.title, style="rule.text") title_text.plain = title_text.plain.replace("\n", " ") title_text.expand_tabs() required_space = 4 if self.align == "center" else 2 truncate_width = max(0, width - required_space) if not truncate_width: yield self._rule_line(chars_len, width) return rule_text = Text(end=self.end) if self.align == "center": title_text.truncate(truncate_width, overflow="ellipsis") side_width = (width - cell_len(title_text.plain)) // 2 left = Text(characters * (side_width // chars_len + 1)) left.truncate(side_width - 1) right_length = width - cell_len(left.plain) - cell_len(title_text.plain) right = Text(characters * (side_width // chars_len + 1)) right.truncate(right_length) rule_text.append(left.plain + " ", self.style) rule_text.append(title_text) rule_text.append(" " + right.plain, self.style) elif self.align == "left": title_text.truncate(truncate_width, overflow="ellipsis") rule_text.append(title_text) rule_text.append(" ") rule_text.append(characters * (width - rule_text.cell_len), self.style) elif self.align == "right": title_text.truncate(truncate_width, overflow="ellipsis") rule_text.append(characters * (width - title_text.cell_len - 1), self.style) rule_text.append(" ") rule_text.append(title_text) rule_text.plain = set_cell_size(rule_text.plain, width) yield rule_text def _rule_line(self, chars_len: int, width: int) -> Text: rule_text = Text(self.characters * ((width // chars_len) + 1), self.style) rule_text.truncate(width) rule_text.plain = set_cell_size(rule_text.plain, width) return rule_text def __rich_measure__( self, console: Console, options: ConsoleOptions ) -> Measurement: return Measurement(1, 1) if __name__ == "__main__": # pragma: no cover import sys from pip._vendor.rich.console import Console try: text = sys.argv[1] except IndexError: text = "Hello, World" console = Console() console.print(Rule(title=text)) console = Console() console.print(Rule("foo"), width=4)