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 __future__ import annotations from functools import lru_cache from typing import Callable from ._cell_widths import CELL_WIDTHS # Ranges of unicode ordinals that produce a 1-cell wide character # This is non-exhaustive, but covers most common Western characters _SINGLE_CELL_UNICODE_RANGES: list[tuple[int, int]] = [ (0x20, 0x7E), # Latin (excluding non-printable) (0xA0, 0xAC), (0xAE, 0x002FF), (0x00370, 0x00482), # Greek / Cyrillic (0x02500, 0x025FC), # Box drawing, box elements, geometric shapes (0x02800, 0x028FF), # Braille ] # A set of characters that are a single cell wide _SINGLE_CELLS = frozenset( [ character for _start, _end in _SINGLE_CELL_UNICODE_RANGES for character in map(chr, range(_start, _end + 1)) ] ) # When called with a string this will return True if all # characters are single-cell, otherwise False _is_single_cell_widths: Callable[[str], bool] = _SINGLE_CELLS.issuperset @lru_cache(4096) def cached_cell_len(text: str) -> int: """Get the number of cells required to display text. This method always caches, which may use up a lot of memory. It is recommended to use `cell_len` over this method. Args: text (str): Text to display. Returns: int: Get the number of cells required to display text. """ if _is_single_cell_widths(text): return len(text) return sum(map(get_character_cell_size, text)) def cell_len(text: str, _cell_len: Callable[[str], int] = cached_cell_len) -> int: """Get the number of cells required to display text. Args: text (str): Text to display. Returns: int: Get the number of cells required to display text. """ if len(text) < 512: return _cell_len(text) if _is_single_cell_widths(text): return len(text) return sum(map(get_character_cell_size, text)) @lru_cache(maxsize=4096) def get_character_cell_size(character: str) -> int: """Get the cell size of a character. Args: character (str): A single character. Returns: int: Number of cells (0, 1 or 2) occupied by that character. """ codepoint = ord(character) _table = CELL_WIDTHS lower_bound = 0 upper_bound = len(_table) - 1 index = (lower_bound + upper_bound) // 2 while True: start, end, width = _table[index] if codepoint < start: upper_bound = index - 1 elif codepoint > end: lower_bound = index + 1 else: return 0 if width == -1 else width if upper_bound < lower_bound: break index = (lower_bound + upper_bound) // 2 return 1 def set_cell_size(text: str, total: int) -> str: """Set the length of a string to fit within given number of cells.""" if _is_single_cell_widths(text): size = len(text) if size < total: return text + " " * (total - size) return text[:total] if total <= 0: return "" cell_size = cell_len(text) if cell_size == total: return text if cell_size < total: return text + " " * (total - cell_size) start = 0 end = len(text) # Binary search until we find the right size while True: pos = (start + end) // 2 before = text[: pos + 1] before_len = cell_len(before) if before_len == total + 1 and cell_len(before[-1]) == 2: return before[:-1] + " " if before_len == total: return before if before_len > total: end = pos else: start = pos def chop_cells( text: str, width: int, ) -> list[str]: """Split text into lines such that each line fits within the available (cell) width. Args: text: The text to fold such that it fits in the given width. width: The width available (number of cells). Returns: A list of strings such that each string in the list has cell width less than or equal to the available width. """ _get_character_cell_size = get_character_cell_size lines: list[list[str]] = [[]] append_new_line = lines.append append_to_last_line = lines[-1].append total_width = 0 for character in text: cell_width = _get_character_cell_size(character) char_doesnt_fit = total_width + cell_width > width if char_doesnt_fit: append_new_line([character]) append_to_last_line = lines[-1].append total_width = cell_width else: append_to_last_line(character) total_width += cell_width return ["".join(line) for line in lines] if __name__ == "__main__": # pragma: no cover print(get_character_cell_size("😽")) for line in chop_cells("""这是对亚洲语言支持的测试。面对模棱两可的想法,拒绝猜测的诱惑。""", 8): print(line) for n in range(80, 1, -1): print(set_cell_size("""这是对亚洲语言支持的测试。面对模棱两可的想法,拒绝猜测的诱惑。""", n) + "|") print("x" * n)