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 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__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. |
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