OXIESEC PANEL
- Current Dir:
/
/
opt
/
alt
/
python311
/
lib
/
python3.11
/
site-packages
/
rich
Server IP: 2a02:4780:11:1594:0:ef5:22d7:a
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
01/09/2025 02:18:04 AM
rwxr-xr-x
📄
__init__.py
5.92 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
__main__.py
8.14 KB
05/14/2024 03:18:15 PM
rw-r--r--
📁
__pycache__
-
05/14/2024 03:18:15 PM
rwxr-xr-x
📄
_cell_widths.py
9.97 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_emoji_codes.py
136.95 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_emoji_replace.py
1.04 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_export_format.py
2.08 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_extension.py
241 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
_fileno.py
799 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
_inspect.py
9.47 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_log_render.py
3.14 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_loop.py
1.21 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_null_file.py
1.35 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_palettes.py
6.9 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_pick.py
423 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
_ratio.py
5.33 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_spinners.py
19.45 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_stack.py
351 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
_timer.py
417 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
_win32_console.py
22.25 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_windows.py
1.86 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_windows_renderer.py
2.69 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
_wrap.py
3.32 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
abc.py
878 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
align.py
10.08 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
ansi.py
6.74 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
bar.py
3.19 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
box.py
10.53 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
cells.py
4.67 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
color.py
17.8 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
color_triplet.py
1.03 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
columns.py
6.96 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
console.py
96.78 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
constrain.py
1.26 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
containers.py
5.37 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
control.py
6.45 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
default_styles.py
7.86 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
diagnose.py
924 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
emoji.py
2.41 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
errors.py
642 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
file_proxy.py
1.64 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
filesize.py
2.45 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
highlighter.py
9.36 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
json.py
4.9 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
jupyter.py
3.15 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
layout.py
13.62 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
live.py
13.94 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
live_render.py
3.57 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
logging.py
11.61 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
markdown.py
25.55 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
markup.py
8.23 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
measure.py
5.18 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
padding.py
4.84 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
pager.py
828 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
palette.py
3.21 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
panel.py
10.45 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
pretty.py
34.97 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
progress.py
58.3 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
progress_bar.py
7.97 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
prompt.py
11.03 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
protocol.py
1.33 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
py.typed
0 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
region.py
166 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
repr.py
4.32 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
rule.py
4.48 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
scope.py
2.76 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
screen.py
1.54 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
segment.py
23.64 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
spinner.py
4.24 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
status.py
4.32 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
style.py
26.44 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
styled.py
1.21 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
syntax.py
34.54 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
table.py
38.71 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
terminal_theme.py
3.29 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
text.py
46.19 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
theme.py
3.69 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
themes.py
102 bytes
05/14/2024 03:18:15 PM
rw-r--r--
📄
traceback.py
28.84 KB
05/14/2024 03:18:15 PM
rw-r--r--
📄
tree.py
8.89 KB
05/14/2024 03:18:15 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 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 rich.color import Color from rich.style import Style from rich.text import Text from 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 rich.color import Color from rich.console import Console, ConsoleOptions from rich.segment import Segment from 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())