OXIESEC PANEL
- Current Dir:
/
/
snap
/
certbot
/
4737
/
usr
/
lib
/
python3
/
dist-packages
/
pip
/
_vendor
/
rich
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
06/12/2025 06:19:49 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: palette.py
Close
from math import sqrt from functools import lru_cache from typing import Sequence, Tuple, TYPE_CHECKING from .color_triplet import ColorTriplet if TYPE_CHECKING: from pip._vendor.rich.table import Table class Palette: """A palette of available colors.""" def __init__(self, colors: Sequence[Tuple[int, int, int]]): self._colors = colors def __getitem__(self, number: int) -> ColorTriplet: return ColorTriplet(*self._colors[number]) def __rich__(self) -> "Table": from pip._vendor.rich.color import Color from pip._vendor.rich.style import Style from pip._vendor.rich.text import Text from pip._vendor.rich.table import Table table = Table( "index", "RGB", "Color", title="Palette", caption=f"{len(self._colors)} colors", highlight=True, caption_justify="right", ) for index, color in enumerate(self._colors): table.add_row( str(index), repr(color), Text(" " * 16, style=Style(bgcolor=Color.from_rgb(*color))), ) return table # This is somewhat inefficient and needs caching @lru_cache(maxsize=1024) def match(self, color: Tuple[int, int, int]) -> int: """Find a color from a palette that most closely matches a given color. Args: color (Tuple[int, int, int]): RGB components in range 0 > 255. Returns: int: Index of closes matching color. """ red1, green1, blue1 = color _sqrt = sqrt get_color = self._colors.__getitem__ def get_color_distance(index: int) -> float: """Get the distance to a color.""" red2, green2, blue2 = get_color(index) red_mean = (red1 + red2) // 2 red = red1 - red2 green = green1 - green2 blue = blue1 - blue2 return _sqrt( (((512 + red_mean) * red * red) >> 8) + 4 * green * green + (((767 - red_mean) * blue * blue) >> 8) ) min_index = min(range(len(self._colors)), key=get_color_distance) return min_index if __name__ == "__main__": # pragma: no cover import colorsys from typing import Iterable from pip._vendor.rich.color import Color from pip._vendor.rich.console import Console, ConsoleOptions from pip._vendor.rich.segment import Segment from pip._vendor.rich.style import Style class ColorBox: def __rich_console__( self, console: Console, options: ConsoleOptions ) -> Iterable[Segment]: height = console.size.height - 3 for y in range(0, height): for x in range(options.max_width): h = x / options.max_width l = y / (height + 1) r1, g1, b1 = colorsys.hls_to_rgb(h, l, 1.0) r2, g2, b2 = colorsys.hls_to_rgb(h, l + (1 / height / 2), 1.0) bgcolor = Color.from_rgb(r1 * 255, g1 * 255, b1 * 255) color = Color.from_rgb(r2 * 255, g2 * 255, b2 * 255) yield Segment("▄", Style(color=color, bgcolor=bgcolor)) yield Segment.line() console = Console() console.print(ColorBox())