Linux premium71.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
LiteSpeed
Server IP : 198.187.29.8 & Your IP : 216.73.216.155
Domains :
Cant Read [ /etc/named.conf ]
User : cleahvkv
Terminal
Auto Root
Create File
Create Folder
Localroot Suggester
Backdoor Destroyer
Readme
/
opt /
alt /
python313 /
lib64 /
python3.13 /
_pyrepl /
Delete
Unzip
Name
Size
Permission
Date
Action
__pycache__
[ DIR ]
drwxr-xr-x
2025-05-13 10:36
__init__.py
925
B
-rw-r--r--
2025-04-25 15:04
__main__.py
263
B
-rw-r--r--
2025-04-25 15:04
_minimal_curses.py
1.8
KB
-rw-r--r--
2025-04-25 15:04
_threading_handler.py
2.12
KB
-rw-r--r--
2025-04-25 15:04
commands.py
11.91
KB
-rw-r--r--
2025-04-25 15:04
completing_reader.py
9.81
KB
-rw-r--r--
2025-04-25 15:04
console.py
6.71
KB
-rw-r--r--
2025-04-25 15:04
curses.py
1.21
KB
-rw-r--r--
2025-04-25 15:04
fancy_termios.py
2.11
KB
-rw-r--r--
2025-04-25 15:04
historical_reader.py
12.93
KB
-rw-r--r--
2025-04-25 15:04
input.py
3.69
KB
-rw-r--r--
2025-04-25 15:04
keymap.py
6.31
KB
-rw-r--r--
2025-04-25 15:04
main.py
1.89
KB
-rw-r--r--
2025-04-25 15:04
mypy.ini
870
B
-rw-r--r--
2025-04-08 13:54
pager.py
5.68
KB
-rw-r--r--
2025-04-25 15:04
reader.py
27.06
KB
-rw-r--r--
2025-04-25 15:04
readline.py
19.75
KB
-rw-r--r--
2025-04-25 15:04
simple_interact.py
5.15
KB
-rw-r--r--
2025-04-25 15:04
trace.py
433
B
-rw-r--r--
2025-04-25 15:04
types.py
354
B
-rw-r--r--
2025-04-25 15:04
unix_console.py
24.88
KB
-rw-r--r--
2025-04-25 15:04
unix_eventqueue.py
4.92
KB
-rw-r--r--
2025-04-25 15:04
utils.py
2.18
KB
-rw-r--r--
2025-04-25 15:04
windows_console.py
19.05
KB
-rw-r--r--
2025-04-25 15:04
Save
Rename
import re import unicodedata import functools from .types import CharBuffer, CharWidths from .trace import trace ANSI_ESCAPE_SEQUENCE = re.compile(r"\x1b\[[ -@]*[A-~]") ZERO_WIDTH_BRACKET = re.compile(r"\x01.*?\x02") ZERO_WIDTH_TRANS = str.maketrans({"\x01": "", "\x02": ""}) @functools.cache def str_width(c: str) -> int: if ord(c) < 128: return 1 w = unicodedata.east_asian_width(c) if w in ("N", "Na", "H", "A"): return 1 return 2 def wlen(s: str) -> int: if len(s) == 1 and s != "\x1a": return str_width(s) length = sum(str_width(i) for i in s) # remove lengths of any escape sequences sequence = ANSI_ESCAPE_SEQUENCE.findall(s) ctrl_z_cnt = s.count("\x1a") return length - sum(len(i) for i in sequence) + ctrl_z_cnt def unbracket(s: str, including_content: bool = False) -> str: r"""Return `s` with \001 and \002 characters removed. If `including_content` is True, content between \001 and \002 is also stripped. """ if including_content: return ZERO_WIDTH_BRACKET.sub("", s) return s.translate(ZERO_WIDTH_TRANS) def disp_str(buffer: str) -> tuple[CharBuffer, CharWidths]: r"""Decompose the input buffer into a printable variant. Returns a tuple of two lists: - the first list is the input buffer, character by character; - the second list is the visible width of each character in the input buffer. Examples: >>> utils.disp_str("a = 9") (['a', ' ', '=', ' ', '9'], [1, 1, 1, 1, 1]) """ chars: CharBuffer = [] char_widths: CharWidths = [] if not buffer: return chars, char_widths for c in buffer: if c == "\x1a": # CTRL-Z on Windows chars.append(c) char_widths.append(2) elif ord(c) < 128: chars.append(c) char_widths.append(1) elif unicodedata.category(c).startswith("C"): c = r"\u%04x" % ord(c) chars.append(c) char_widths.append(len(c)) else: chars.append(c) char_widths.append(str_width(c)) trace("disp_str({buffer}) = {s}, {b}", buffer=repr(buffer), s=chars, b=char_widths) return chars, char_widths