OXIESEC PANEL
- Current Dir:
/
/
snap
/
certbot
/
4730
/
usr
/
lib
/
python3
/
dist-packages
/
pip
/
_vendor
/
rich
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
06/10/2025 09:51:14 PM
rwxr-xr-x
📄
__init__.py
5.95 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
__main__.py
8.28 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_cell_widths.py
9.86 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_emoji_codes.py
136.95 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_emoji_replace.py
1.04 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_export_format.py
2.05 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_extension.py
265 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
_fileno.py
799 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
_inspect.py
9.47 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_log_render.py
3.15 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_loop.py
1.21 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_null_file.py
1.35 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_palettes.py
6.9 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_pick.py
423 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
_ratio.py
5.34 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_spinners.py
19.45 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_stack.py
351 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
_timer.py
417 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
_win32_console.py
22.29 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_windows.py
1.88 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_windows_renderer.py
2.72 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
_wrap.py
1.8 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
abc.py
890 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
align.py
10.13 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
ansi.py
6.74 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
bar.py
3.19 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
box.py
9.61 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
cells.py
4.4 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
color.py
17.8 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
color_triplet.py
1.03 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
columns.py
6.96 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
console.py
96.89 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
constrain.py
1.26 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
containers.py
5.37 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
control.py
6.47 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
default_styles.py
7.89 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
diagnose.py
972 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
emoji.py
2.44 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
errors.py
642 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
file_proxy.py
1.64 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
filesize.py
2.45 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
highlighter.py
9.36 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
json.py
4.91 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
jupyter.py
3.18 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
layout.py
13.68 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
live.py
13.94 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
live_render.py
3.58 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
logging.py
11.62 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
markup.py
8.01 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
measure.py
5.18 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
padding.py
4.85 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
pager.py
828 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
palette.py
3.32 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
panel.py
10.33 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
pretty.py
35.01 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
progress.py
58.31 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
progress_bar.py
7.97 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
prompt.py
11.04 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
protocol.py
1.36 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
region.py
166 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
repr.py
4.33 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
rule.py
4.49 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
scope.py
2.78 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
screen.py
1.55 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
segment.py
23.68 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
spinner.py
4.24 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
status.py
4.32 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
style.py
26.44 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
styled.py
1.23 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
syntax.py
34.35 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
table.py
38.75 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
terminal_theme.py
3.29 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
text.py
44.46 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
theme.py
3.69 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
themes.py
102 bytes
10/18/2024 05:04:47 PM
rw-r--r--
📄
traceback.py
28.91 KB
10/18/2024 05:04:47 PM
rw-r--r--
📄
tree.py
8.95 KB
10/18/2024 05:04:47 PM
rw-r--r--
Editing: measure.py
Close
from operator import itemgetter from typing import TYPE_CHECKING, Callable, NamedTuple, Optional, Sequence from . import errors from .protocol import is_renderable, rich_cast if TYPE_CHECKING: from .console import Console, ConsoleOptions, RenderableType class Measurement(NamedTuple): """Stores the minimum and maximum widths (in characters) required to render an object.""" minimum: int """Minimum number of cells required to render.""" maximum: int """Maximum number of cells required to render.""" @property def span(self) -> int: """Get difference between maximum and minimum.""" return self.maximum - self.minimum def normalize(self) -> "Measurement": """Get measurement that ensures that minimum <= maximum and minimum >= 0 Returns: Measurement: A normalized measurement. """ minimum, maximum = self minimum = min(max(0, minimum), maximum) return Measurement(max(0, minimum), max(0, max(minimum, maximum))) def with_maximum(self, width: int) -> "Measurement": """Get a RenderableWith where the widths are <= width. Args: width (int): Maximum desired width. Returns: Measurement: New Measurement object. """ minimum, maximum = self return Measurement(min(minimum, width), min(maximum, width)) def with_minimum(self, width: int) -> "Measurement": """Get a RenderableWith where the widths are >= width. Args: width (int): Minimum desired width. Returns: Measurement: New Measurement object. """ minimum, maximum = self width = max(0, width) return Measurement(max(minimum, width), max(maximum, width)) def clamp( self, min_width: Optional[int] = None, max_width: Optional[int] = None ) -> "Measurement": """Clamp a measurement within the specified range. Args: min_width (int): Minimum desired width, or ``None`` for no minimum. Defaults to None. max_width (int): Maximum desired width, or ``None`` for no maximum. Defaults to None. Returns: Measurement: New Measurement object. """ measurement = self if min_width is not None: measurement = measurement.with_minimum(min_width) if max_width is not None: measurement = measurement.with_maximum(max_width) return measurement @classmethod def get( cls, console: "Console", options: "ConsoleOptions", renderable: "RenderableType" ) -> "Measurement": """Get a measurement for a renderable. Args: console (~rich.console.Console): Console instance. options (~rich.console.ConsoleOptions): Console options. renderable (RenderableType): An object that may be rendered with Rich. Raises: errors.NotRenderableError: If the object is not renderable. Returns: Measurement: Measurement object containing range of character widths required to render the object. """ _max_width = options.max_width if _max_width < 1: return Measurement(0, 0) if isinstance(renderable, str): renderable = console.render_str( renderable, markup=options.markup, highlight=False ) renderable = rich_cast(renderable) if is_renderable(renderable): get_console_width: Optional[ Callable[["Console", "ConsoleOptions"], "Measurement"] ] = getattr(renderable, "__rich_measure__", None) if get_console_width is not None: render_width = ( get_console_width(console, options) .normalize() .with_maximum(_max_width) ) if render_width.maximum < 1: return Measurement(0, 0) return render_width.normalize() else: return Measurement(0, _max_width) else: raise errors.NotRenderableError( f"Unable to get render width for {renderable!r}; " "a str, Segment, or object with __rich_console__ method is required" ) def measure_renderables( console: "Console", options: "ConsoleOptions", renderables: Sequence["RenderableType"], ) -> "Measurement": """Get a measurement that would fit a number of renderables. Args: console (~rich.console.Console): Console instance. options (~rich.console.ConsoleOptions): Console options. renderables (Iterable[RenderableType]): One or more renderable objects. Returns: Measurement: Measurement object containing range of character widths required to contain all given renderables. """ if not renderables: return Measurement(0, 0) get_measurement = Measurement.get measurements = [ get_measurement(console, options, renderable) for renderable in renderables ] measured_width = Measurement( max(measurements, key=itemgetter(0)).minimum, max(measurements, key=itemgetter(1)).maximum, ) return measured_width