OXIESEC PANEL
- Current Dir:
/
/
snap
/
certbot
/
4737
/
lib
/
python3.12
/
site-packages
/
pip
/
_vendor
/
rich
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
π
..
-
06/12/2025 06:19:48 PM
rwxr-xr-x
π
__init__.py
5.95 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
__main__.py
8.28 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
__pycache__
-
06/12/2025 06:19:48 PM
rwxr-xr-x
π
_cell_widths.py
9.97 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_emoji_codes.py
136.95 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_emoji_replace.py
1.04 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_export_format.py
2.08 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_extension.py
265 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
_fileno.py
799 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
_inspect.py
9.43 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_log_render.py
3.15 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_loop.py
1.21 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_null_file.py
1.36 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_palettes.py
6.9 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_pick.py
423 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
_ratio.py
5.34 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_spinners.py
19.45 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_stack.py
351 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
_timer.py
417 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
_win32_console.py
22.22 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_windows.py
1.88 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_windows_renderer.py
2.72 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
_wrap.py
3.32 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
abc.py
890 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
align.py
10.22 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
ansi.py
6.76 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
bar.py
3.19 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
box.py
10.58 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
cells.py
5.01 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
color.py
17.78 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
color_triplet.py
1.03 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
columns.py
6.96 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
console.py
98.21 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
constrain.py
1.26 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
containers.py
5.37 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
control.py
6.47 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
default_styles.py
8.06 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
diagnose.py
998 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
emoji.py
2.44 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
errors.py
642 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
file_proxy.py
1.64 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
filesize.py
2.43 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
highlighter.py
9.36 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
json.py
4.91 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
jupyter.py
3.18 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
layout.py
13.68 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
live.py
13.94 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
live_render.py
3.58 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
logging.py
12.17 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
markup.py
8.25 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
measure.py
5.18 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
padding.py
4.79 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
pager.py
828 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
palette.py
3.32 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
panel.py
10.96 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
pretty.py
35.54 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
progress.py
58.94 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
progress_bar.py
7.97 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
prompt.py
12.16 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
protocol.py
1.36 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
py.typed
0 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
region.py
166 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
repr.py
4.33 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
rule.py
4.49 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
scope.py
2.78 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
screen.py
1.55 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
segment.py
24.16 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
spinner.py
4.26 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
status.py
4.32 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
style.py
26.42 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
styled.py
1.23 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
syntax.py
34.92 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
table.py
39.11 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
terminal_theme.py
3.29 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
text.py
46.44 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
theme.py
3.68 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
themes.py
102 bytes
06/12/2025 06:19:25 PM
rw-r--r--
π
traceback.py
34.35 KB
06/12/2025 06:19:25 PM
rw-r--r--
π
tree.py
9.23 KB
06/12/2025 06:19:25 PM
rw-r--r--
Editing: cells.py
Close
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)