SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > > site-packages > pip > _vendor > rich


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/cloudlinux/venv/lib64/python3.11//site-packages/pip/_vendor/rich

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 6090 bytes April 17 2025 13:10:58.
__main__.py File 8477 bytes April 17 2025 13:10:58.
_cell_widths.py File 10209 bytes April 17 2025 13:10:58.
_emoji_codes.py File 140235 bytes April 17 2025 13:10:58.
_emoji_replace.py File 1064 bytes April 17 2025 13:10:58.
_export_format.py File 2128 bytes April 17 2025 13:10:58.
_extension.py File 265 bytes April 17 2025 13:10:58.
_fileno.py File 799 bytes April 17 2025 13:10:58.
_inspect.py File 9655 bytes April 17 2025 13:10:58.
_log_render.py File 3225 bytes April 17 2025 13:10:58.
_loop.py File 1236 bytes April 17 2025 13:10:58.
_null_file.py File 1394 bytes April 17 2025 13:10:58.
_palettes.py File 7063 bytes April 17 2025 13:10:58.
_pick.py File 423 bytes April 17 2025 13:10:58.
_ratio.py File 5471 bytes April 17 2025 13:10:58.
_spinners.py File 19919 bytes April 17 2025 13:10:58.
_stack.py File 351 bytes April 17 2025 13:10:58.
_timer.py File 417 bytes April 17 2025 13:10:58.
_win32_console.py File 22755 bytes April 17 2025 13:10:58.
_windows.py File 1925 bytes April 17 2025 13:10:58.
_windows_renderer.py File 2783 bytes April 17 2025 13:10:58.
_wrap.py File 3404 bytes April 17 2025 13:10:58.
abc.py File 890 bytes April 17 2025 13:10:58.
align.py File 10469 bytes April 17 2025 13:10:58.
ansi.py File 6921 bytes April 17 2025 13:10:58.
bar.py File 3263 bytes April 17 2025 13:10:58.
box.py File 10831 bytes April 17 2025 13:10:58.
cells.py File 5130 bytes April 17 2025 13:10:58.
color.py File 18211 bytes April 17 2025 13:10:58.
color_triplet.py File 1054 bytes April 17 2025 13:10:58.
columns.py File 7131 bytes April 17 2025 13:10:58.
console.py File 100156 bytes April 17 2025 13:10:58.
constrain.py File 1288 bytes April 17 2025 13:10:58.
containers.py File 5502 bytes April 17 2025 13:10:58.
control.py File 6630 bytes April 17 2025 13:10:58.
default_styles.py File 8159 bytes April 17 2025 13:10:58.
diagnose.py File 972 bytes April 17 2025 13:10:58.
emoji.py File 2501 bytes April 17 2025 13:10:58.
errors.py File 642 bytes April 17 2025 13:10:58.
file_proxy.py File 1683 bytes April 17 2025 13:10:58.
filesize.py File 2484 bytes April 17 2025 13:10:58.
highlighter.py File 9586 bytes April 17 2025 13:10:58.
json.py File 5031 bytes April 17 2025 13:10:58.
jupyter.py File 3252 bytes April 17 2025 13:10:58.
layout.py File 14004 bytes April 17 2025 13:10:58.
live.py File 14270 bytes April 17 2025 13:10:58.
live_render.py File 3666 bytes April 17 2025 13:10:58.
logging.py File 12458 bytes April 17 2025 13:10:58.
markup.py File 8451 bytes April 17 2025 13:10:58.
measure.py File 5305 bytes April 17 2025 13:10:58.
padding.py File 4908 bytes April 17 2025 13:10:58.
pager.py File 828 bytes April 17 2025 13:10:58.
palette.py File 3396 bytes April 17 2025 13:10:58.
panel.py File 11235 bytes April 17 2025 13:10:58.
pretty.py File 36391 bytes April 17 2025 13:10:58.
progress.py File 60357 bytes April 17 2025 13:10:58.
progress_bar.py File 8162 bytes April 17 2025 13:10:58.
prompt.py File 12447 bytes April 17 2025 13:10:58.
protocol.py File 1391 bytes April 17 2025 13:10:58.
py.typed File 0 bytes April 17 2025 13:10:58.
region.py File 166 bytes April 17 2025 13:10:58.
repr.py File 4431 bytes April 17 2025 13:10:58.
rule.py File 4602 bytes April 17 2025 13:10:58.
scope.py File 2843 bytes April 17 2025 13:10:58.
screen.py File 1591 bytes April 17 2025 13:10:58.
segment.py File 24743 bytes April 17 2025 13:10:58.
spinner.py File 4364 bytes April 17 2025 13:10:58.
status.py File 4424 bytes April 17 2025 13:10:58.
style.py File 27067 bytes April 17 2025 13:10:58.
styled.py File 1258 bytes April 17 2025 13:10:58.
syntax.py File 35763 bytes April 17 2025 13:10:58.
table.py File 40103 bytes April 17 2025 13:10:58.
terminal_theme.py File 3370 bytes April 17 2025 13:10:58.
text.py File 47552 bytes April 17 2025 13:10:58.
theme.py File 3771 bytes April 17 2025 13:10:58.
themes.py File 102 bytes April 17 2025 13:10:58.
traceback.py File 31797 bytes April 17 2025 13:10:58.
tree.py File 9451 bytes April 17 2025 13:10:58.

Reading File: //opt/cloudlinux/venv/lib64/python3.11//site-packages/pip/_vendor/rich/_ratio.py

import sys
from fractions import Fraction
from math import ceil
from typing import cast, List, Optional, Sequence

if sys.version_info >= (3, 8):
    from typing import Protocol
else:
    from pip._vendor.typing_extensions import Protocol  # pragma: no cover


class Edge(Protocol):
    """Any object that defines an edge (such as Layout)."""

    size: Optional[int] = None
    ratio: int = 1
    minimum_size: int = 1


def ratio_resolve(total: int, edges: Sequence[Edge]) -> List[int]:
    """Divide total space to satisfy size, ratio, and minimum_size, constraints.

    The returned list of integers should add up to total in most cases, unless it is
    impossible to satisfy all the constraints. For instance, if there are two edges
    with a minimum size of 20 each and `total` is 30 then the returned list will be
    greater than total. In practice, this would mean that a Layout object would
    clip the rows that would overflow the screen height.

    Args:
        total (int): Total number of characters.
        edges (List[Edge]): Edges within total space.

    Returns:
        List[int]: Number of characters for each edge.
    """
    # Size of edge or None for yet to be determined
    sizes = [(edge.size or None) for edge in edges]

    _Fraction = Fraction

    # While any edges haven't been calculated
    while None in sizes:
        # Get flexible edges and index to map these back on to sizes list
        flexible_edges = [
            (index, edge)
            for index, (size, edge) in enumerate(zip(sizes, edges))
            if size is None
        ]
        # Remaining space in total
        remaining = total - sum(size or 0 for size in sizes)
        if remaining <= 0:
            # No room for flexible edges
            return [
                ((edge.minimum_size or 1) if size is None else size)
                for size, edge in zip(sizes, edges)
            ]
        # Calculate number of characters in a ratio portion
        portion = _Fraction(
            remaining, sum((edge.ratio or 1) for _, edge in flexible_edges)
        )

        # If any edges will be less than their minimum, replace size with the minimum
        for index, edge in flexible_edges:
            if portion * edge.ratio <= edge.minimum_size:
                sizes[index] = edge.minimum_size
                # New fixed size will invalidate calculations, so we need to repeat the process
                break
        else:
            # Distribute flexible space and compensate for rounding error
            # Since edge sizes can only be integers we need to add the remainder
            # to the following line
            remainder = _Fraction(0)
            for index, edge in flexible_edges:
                size, remainder = divmod(portion * edge.ratio + remainder, 1)
                sizes[index] = size
            break
    # Sizes now contains integers only
    return cast(List[int], sizes)


def ratio_reduce(
    total: int, ratios: List[int], maximums: List[int], values: List[int]
) -> List[int]:
    """Divide an integer total in to parts based on ratios.

    Args:
        total (int): The total to divide.
        ratios (List[int]): A list of integer ratios.
        maximums (List[int]): List of maximums values for each slot.
        values (List[int]): List of values

    Returns:
        List[int]: A list of integers guaranteed to sum to total.
    """
    ratios = [ratio if _max else 0 for ratio, _max in zip(ratios, maximums)]
    total_ratio = sum(ratios)
    if not total_ratio:
        return values[:]
    total_remaining = total
    result: List[int] = []
    append = result.append
    for ratio, maximum, value in zip(ratios, maximums, values):
        if ratio and total_ratio > 0:
            distributed = min(maximum, round(ratio * total_remaining / total_ratio))
            append(value - distributed)
            total_remaining -= distributed
            total_ratio -= ratio
        else:
            append(value)
    return result


def ratio_distribute(
    total: int, ratios: List[int], minimums: Optional[List[int]] = None
) -> List[int]:
    """Distribute an integer total in to parts based on ratios.

    Args:
        total (int): The total to divide.
        ratios (List[int]): A list of integer ratios.
        minimums (List[int]): List of minimum values for each slot.

    Returns:
        List[int]: A list of integers guaranteed to sum to total.
    """
    if minimums:
        ratios = [ratio if _min else 0 for ratio, _min in zip(ratios, minimums)]
    total_ratio = sum(ratios)
    assert total_ratio > 0, "Sum of ratios must be > 0"

    total_remaining = total
    distributed_total: List[int] = []
    append = distributed_total.append
    if minimums is None:
        _minimums = [0] * len(ratios)
    else:
        _minimums = minimums
    for ratio, minimum in zip(ratios, _minimums):
        if total_ratio > 0:
            distributed = max(minimum, ceil(ratio * total_remaining / total_ratio))
        else:
            distributed = total_remaining
        append(distributed)
        total_ratio -= ratio
        total_remaining -= distributed
    return distributed_total


if __name__ == "__main__":
    from dataclasses import dataclass

    @dataclass
    class E:
        size: Optional[int] = None
        ratio: int = 1
        minimum_size: int = 1

    resolved = ratio_resolve(110, [E(None, 1, 1), E(None, 1, 1), E(None, 1, 1)])
    print(sum(resolved))

SILENT KILLER Tool