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: box.py
Close
import sys from typing import TYPE_CHECKING, Iterable, List if sys.version_info >= (3, 8): from typing import Literal else: from pip._vendor.typing_extensions import Literal # pragma: no cover from ._loop import loop_last if TYPE_CHECKING: from pip._vendor.rich.console import ConsoleOptions class Box: """Defines characters to render boxes. โโโฌโ top โ โโ head โโโผโค head_row โ โโ mid โโโผโค row โโโผโค foot_row โ โโ foot โโโดโ bottom Args: box (str): Characters making up box. ascii (bool, optional): True if this box uses ascii characters only. Default is False. """ def __init__(self, box: str, *, ascii: bool = False) -> None: self._box = box self.ascii = ascii line1, line2, line3, line4, line5, line6, line7, line8 = box.splitlines() # top self.top_left, self.top, self.top_divider, self.top_right = iter(line1) # head self.head_left, _, self.head_vertical, self.head_right = iter(line2) # head_row ( self.head_row_left, self.head_row_horizontal, self.head_row_cross, self.head_row_right, ) = iter(line3) # mid self.mid_left, _, self.mid_vertical, self.mid_right = iter(line4) # row self.row_left, self.row_horizontal, self.row_cross, self.row_right = iter(line5) # foot_row ( self.foot_row_left, self.foot_row_horizontal, self.foot_row_cross, self.foot_row_right, ) = iter(line6) # foot self.foot_left, _, self.foot_vertical, self.foot_right = iter(line7) # bottom self.bottom_left, self.bottom, self.bottom_divider, self.bottom_right = iter( line8 ) def __repr__(self) -> str: return "Box(...)" def __str__(self) -> str: return self._box def substitute(self, options: "ConsoleOptions", safe: bool = True) -> "Box": """Substitute this box for another if it won't render due to platform issues. Args: options (ConsoleOptions): Console options used in rendering. safe (bool, optional): Substitute this for another Box if there are known problems displaying on the platform (currently only relevant on Windows). Default is True. Returns: Box: A different Box or the same Box. """ box = self if options.legacy_windows and safe: box = LEGACY_WINDOWS_SUBSTITUTIONS.get(box, box) if options.ascii_only and not box.ascii: box = ASCII return box def get_plain_headed_box(self) -> "Box": """If this box uses special characters for the borders of the header, then return the equivalent box that does not. Returns: Box: The most similar Box that doesn't use header-specific box characters. If the current Box already satisfies this criterion, then it's returned. """ return PLAIN_HEADED_SUBSTITUTIONS.get(self, self) def get_top(self, widths: Iterable[int]) -> str: """Get the top of a simple box. Args: widths (List[int]): Widths of columns. Returns: str: A string of box characters. """ parts: List[str] = [] append = parts.append append(self.top_left) for last, width in loop_last(widths): append(self.top * width) if not last: append(self.top_divider) append(self.top_right) return "".join(parts) def get_row( self, widths: Iterable[int], level: Literal["head", "row", "foot", "mid"] = "row", edge: bool = True, ) -> str: """Get the top of a simple box. Args: width (List[int]): Widths of columns. Returns: str: A string of box characters. """ if level == "head": left = self.head_row_left horizontal = self.head_row_horizontal cross = self.head_row_cross right = self.head_row_right elif level == "row": left = self.row_left horizontal = self.row_horizontal cross = self.row_cross right = self.row_right elif level == "mid": left = self.mid_left horizontal = " " cross = self.mid_vertical right = self.mid_right elif level == "foot": left = self.foot_row_left horizontal = self.foot_row_horizontal cross = self.foot_row_cross right = self.foot_row_right else: raise ValueError("level must be 'head', 'row' or 'foot'") parts: List[str] = [] append = parts.append if edge: append(left) for last, width in loop_last(widths): append(horizontal * width) if not last: append(cross) if edge: append(right) return "".join(parts) def get_bottom(self, widths: Iterable[int]) -> str: """Get the bottom of a simple box. Args: widths (List[int]): Widths of columns. Returns: str: A string of box characters. """ parts: List[str] = [] append = parts.append append(self.bottom_left) for last, width in loop_last(widths): append(self.bottom * width) if not last: append(self.bottom_divider) append(self.bottom_right) return "".join(parts) ASCII: Box = Box( """\ +--+ | || |-+| | || |-+| |-+| | || +--+ """, ascii=True, ) ASCII2: Box = Box( """\ +-++ | || +-++ | || +-++ +-++ | || +-++ """, ascii=True, ) ASCII_DOUBLE_HEAD: Box = Box( """\ +-++ | || +=++ | || +-++ +-++ | || +-++ """, ascii=True, ) SQUARE: Box = Box( """\ โโโฌโ โ โโ โโโผโค โ โโ โโโผโค โโโผโค โ โโ โโโดโ """ ) SQUARE_DOUBLE_HEAD: Box = Box( """\ โโโฌโ โ โโ โโโชโก โ โโ โโโผโค โโโผโค โ โโ โโโดโ """ ) MINIMAL: Box = Box( """\ โท โ โถโโผโด โ โถโโผโด โถโโผโด โ โต """ ) MINIMAL_HEAVY_HEAD: Box = Box( """\ โท โ โบโโฟโธ โ โถโโผโด โถโโผโด โ โต """ ) MINIMAL_DOUBLE_HEAD: Box = Box( """\ โท โ โโช โ โโผ โโผ โ โต """ ) SIMPLE: Box = Box( """\ โโ โโ """ ) SIMPLE_HEAD: Box = Box( """\ โโ """ ) SIMPLE_HEAVY: Box = Box( """\ โโ โโ """ ) HORIZONTALS: Box = Box( """\ โโ โโ โโ โโ โโ """ ) ROUNDED: Box = Box( """\ โญโโฌโฎ โ โโ โโโผโค โ โโ โโโผโค โโโผโค โ โโ โฐโโดโฏ """ ) HEAVY: Box = Box( """\ โโโณโ โ โโ โฃโโโซ โ โโ โฃโโโซ โฃโโโซ โ โโ โโโปโ """ ) HEAVY_EDGE: Box = Box( """\ โโโฏโ โ โโ โ โโผโจ โ โโ โ โโผโจ โ โโผโจ โ โโ โโโทโ """ ) HEAVY_HEAD: Box = Box( """\ โโโณโ โ โโ โกโโโฉ โ โโ โโโผโค โโโผโค โ โโ โโโดโ """ ) DOUBLE: Box = Box( """\ โโโฆโ โ โโ โ โโฌโฃ โ โโ โ โโฌโฃ โ โโฌโฃ โ โโ โโโฉโ """ ) DOUBLE_EDGE: Box = Box( """\ โโโคโ โ โโ โโโผโข โ โโ โโโผโข โโโผโข โ โโ โโโงโ """ ) MARKDOWN: Box = Box( """\ | || |-|| | || |-|| |-|| | || """, ascii=True, ) # Map Boxes that don't render with raster fonts on to equivalent that do LEGACY_WINDOWS_SUBSTITUTIONS = { ROUNDED: SQUARE, MINIMAL_HEAVY_HEAD: MINIMAL, SIMPLE_HEAVY: SIMPLE, HEAVY: SQUARE, HEAVY_EDGE: SQUARE, HEAVY_HEAD: SQUARE, } # Map headed boxes to their headerless equivalents PLAIN_HEADED_SUBSTITUTIONS = { HEAVY_HEAD: SQUARE, SQUARE_DOUBLE_HEAD: SQUARE, MINIMAL_DOUBLE_HEAD: MINIMAL, MINIMAL_HEAVY_HEAD: MINIMAL, ASCII_DOUBLE_HEAD: ASCII2, } if __name__ == "__main__": # pragma: no cover from pip._vendor.rich.columns import Columns from pip._vendor.rich.panel import Panel from . import box as box from .console import Console from .table import Table from .text import Text console = Console(record=True) BOXES = [ "ASCII", "ASCII2", "ASCII_DOUBLE_HEAD", "SQUARE", "SQUARE_DOUBLE_HEAD", "MINIMAL", "MINIMAL_HEAVY_HEAD", "MINIMAL_DOUBLE_HEAD", "SIMPLE", "SIMPLE_HEAD", "SIMPLE_HEAVY", "HORIZONTALS", "ROUNDED", "HEAVY", "HEAVY_EDGE", "HEAVY_HEAD", "DOUBLE", "DOUBLE_EDGE", "MARKDOWN", ] console.print(Panel("[bold green]Box Constants", style="green"), justify="center") console.print() columns = Columns(expand=True, padding=2) for box_name in sorted(BOXES): table = Table( show_footer=True, style="dim", border_style="not dim", expand=True ) table.add_column("Header 1", "Footer 1") table.add_column("Header 2", "Footer 2") table.add_row("Cell", "Cell") table.add_row("Cell", "Cell") table.box = getattr(box, box_name) table.title = Text(f"box.{box_name}", style="magenta") columns.add_renderable(table) console.print(columns) # console.save_svg("box.svg")