SILENT KILLERPanel

Current Path: > > opt > alt > python313 > lib > python3.13 > site-packages > pip > _vendor > rich


Operation   : Linux host59.registrar-servers.com 4.18.0-513.18.1.lve.2.el8.x86_64 #1 SMP Sat Mar 30 15:36:11 UTC 2024 x86_64
Software     : Apache
Server IP    : 198.54.126.42 | Your IP: 216.73.216.8
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 6090 bytes December 01 2024 12:47:36.
__main__.py File 8478 bytes December 01 2024 12:47:36.
_cell_widths.py File 10096 bytes December 01 2024 12:47:36.
_emoji_codes.py File 140235 bytes December 01 2024 12:47:36.
_emoji_replace.py File 1064 bytes December 01 2024 12:47:36.
_export_format.py File 2100 bytes December 01 2024 12:47:36.
_extension.py File 265 bytes December 01 2024 12:47:36.
_fileno.py File 799 bytes December 01 2024 12:47:36.
_inspect.py File 9695 bytes December 01 2024 12:47:36.
_log_render.py File 3225 bytes December 01 2024 12:47:36.
_loop.py File 1236 bytes December 01 2024 12:47:36.
_null_file.py File 1387 bytes December 01 2024 12:47:36.
_palettes.py File 7063 bytes December 01 2024 12:47:36.
_pick.py File 423 bytes December 01 2024 12:47:36.
_ratio.py File 5472 bytes December 01 2024 12:47:36.
_spinners.py File 19919 bytes December 01 2024 12:47:36.
_stack.py File 351 bytes December 01 2024 12:47:36.
_timer.py File 417 bytes December 01 2024 12:47:36.
_win32_console.py File 22820 bytes December 01 2024 12:47:36.
_windows.py File 1926 bytes December 01 2024 12:47:36.
_windows_renderer.py File 2783 bytes December 01 2024 12:47:36.
_wrap.py File 1840 bytes December 01 2024 12:47:36.
abc.py File 890 bytes December 01 2024 12:47:36.
align.py File 10368 bytes December 01 2024 12:47:36.
ansi.py File 6906 bytes December 01 2024 12:47:36.
bar.py File 3264 bytes December 01 2024 12:47:36.
box.py File 9842 bytes December 01 2024 12:47:36.
cells.py File 4509 bytes December 01 2024 12:47:36.
color.py File 18224 bytes December 01 2024 12:47:36.
color_triplet.py File 1054 bytes December 01 2024 12:47:36.
columns.py File 7131 bytes December 01 2024 12:47:36.
console.py File 99218 bytes December 01 2024 12:47:36.
constrain.py File 1288 bytes December 01 2024 12:47:36.
containers.py File 5497 bytes December 01 2024 12:47:36.
control.py File 6630 bytes December 01 2024 12:47:36.
default_styles.py File 8082 bytes December 01 2024 12:47:36.
diagnose.py File 972 bytes December 01 2024 12:47:36.
emoji.py File 2501 bytes December 01 2024 12:47:36.
errors.py File 642 bytes December 01 2024 12:47:36.
file_proxy.py File 1683 bytes December 01 2024 12:47:36.
filesize.py File 2508 bytes December 01 2024 12:47:36.
highlighter.py File 9584 bytes December 01 2024 12:47:36.
json.py File 5032 bytes December 01 2024 12:47:36.
jupyter.py File 3252 bytes December 01 2024 12:47:36.
layout.py File 14007 bytes December 01 2024 12:47:36.
live.py File 14273 bytes December 01 2024 12:47:36.
live_render.py File 3667 bytes December 01 2024 12:47:36.
logging.py File 11903 bytes December 01 2024 12:47:36.
markup.py File 8198 bytes December 01 2024 12:47:36.
measure.py File 5305 bytes December 01 2024 12:47:36.
padding.py File 4970 bytes December 01 2024 12:47:36.
pager.py File 828 bytes December 01 2024 12:47:36.
palette.py File 3396 bytes December 01 2024 12:47:36.
panel.py File 10574 bytes December 01 2024 12:47:36.
pretty.py File 35852 bytes December 01 2024 12:47:36.
progress.py File 59706 bytes December 01 2024 12:47:36.
progress_bar.py File 8165 bytes December 01 2024 12:47:36.
prompt.py File 11303 bytes December 01 2024 12:47:36.
protocol.py File 1391 bytes December 01 2024 12:47:36.
py.typed File 0 bytes December 01 2024 12:47:36.
region.py File 166 bytes December 01 2024 12:47:36.
repr.py File 4431 bytes December 01 2024 12:47:36.
rule.py File 4602 bytes December 01 2024 12:47:36.
scope.py File 2843 bytes December 01 2024 12:47:36.
screen.py File 1591 bytes December 01 2024 12:47:36.
segment.py File 24247 bytes December 01 2024 12:47:36.
spinner.py File 4339 bytes December 01 2024 12:47:36.
status.py File 4425 bytes December 01 2024 12:47:36.
style.py File 27073 bytes December 01 2024 12:47:36.
styled.py File 1258 bytes December 01 2024 12:47:36.
syntax.py File 35173 bytes December 01 2024 12:47:36.
table.py File 39684 bytes December 01 2024 12:47:36.
terminal_theme.py File 3370 bytes December 01 2024 12:47:36.
text.py File 45525 bytes December 01 2024 12:47:36.
theme.py File 3777 bytes December 01 2024 12:47:36.
themes.py File 102 bytes December 01 2024 12:47:36.
traceback.py File 29604 bytes December 01 2024 12:47:36.
tree.py File 9169 bytes December 01 2024 12:47:36.

Reading File: //opt/alt/python313/lib/python3.13/site-packages/pip/_vendor/rich/cells.py

import re
from functools import lru_cache
from typing import Callable, List

from ._cell_widths import CELL_WIDTHS

# Regex to match sequence of the most common character ranges
_is_single_cell_widths = re.compile("^[\u0020-\u006f\u00a0\u02ff\u0370-\u0482]*$").match


@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.
    """
    _get_size = get_character_cell_size
    total_size = sum(_get_size(character) for character in text)
    return total_size


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)
    _get_size = get_character_cell_size
    total_size = sum(_get_size(character) for character in text)
    return total_size


@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.
    """
    return _get_codepoint_cell_size(ord(character))


@lru_cache(maxsize=4096)
def _get_codepoint_cell_size(codepoint: int) -> int:
    """Get the cell size of a character.

    Args:
        codepoint (int): Codepoint of a character.

    Returns:
        int: Number of cells (0, 1 or 2) occupied by that 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


# TODO: This is inefficient
# TODO: This might not work with CWJ type characters
def chop_cells(text: str, max_size: int, position: int = 0) -> List[str]:
    """Break text in to equal (cell) length strings, returning the characters in reverse
    order"""
    _get_character_cell_size = get_character_cell_size
    characters = [
        (character, _get_character_cell_size(character)) for character in text
    ]
    total_size = position
    lines: List[List[str]] = [[]]
    append = lines[-1].append

    for character, size in reversed(characters):
        if total_size + size > max_size:
            lines.append([character])
            append = lines[-1].append
            total_size = size
        else:
            total_size += size
            append(character)

    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)

SILENT KILLER Tool