SILENT KILLERPanel

Current Path: > > > usr > lib64 > python3.6 > encodings


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: ///usr/lib64/python3.6/encodings

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 5642 bytes December 23 2018 21:37:14.
aliases.py File 15577 bytes December 23 2018 21:37:14.
ascii.py File 1248 bytes December 23 2018 21:37:14.
base64_codec.py File 1533 bytes December 23 2018 21:37:14.
big5.py File 1019 bytes December 23 2018 21:37:14.
big5hkscs.py File 1039 bytes December 23 2018 21:37:14.
bz2_codec.py File 2249 bytes December 23 2018 21:37:14.
charmap.py File 2084 bytes December 23 2018 21:37:14.
cp037.py File 13121 bytes December 23 2018 21:37:14.
cp1006.py File 13568 bytes December 23 2018 21:37:14.
cp1026.py File 13113 bytes December 23 2018 21:37:14.
cp1125.py File 34597 bytes December 23 2018 21:37:14.
cp1140.py File 13105 bytes December 23 2018 21:37:14.
cp1250.py File 13686 bytes December 23 2018 21:37:14.
cp1251.py File 13361 bytes December 23 2018 21:37:14.
cp1252.py File 13511 bytes December 23 2018 21:37:14.
cp1253.py File 13094 bytes December 23 2018 21:37:14.
cp1254.py File 13502 bytes December 23 2018 21:37:14.
cp1255.py File 12466 bytes December 23 2018 21:37:14.
cp1256.py File 12814 bytes December 23 2018 21:37:14.
cp1257.py File 13374 bytes December 23 2018 21:37:14.
cp1258.py File 13364 bytes December 23 2018 21:37:14.
cp273.py File 14132 bytes December 23 2018 21:37:14.
cp424.py File 12055 bytes December 23 2018 21:37:14.
cp437.py File 34564 bytes December 23 2018 21:37:14.
cp500.py File 13121 bytes December 23 2018 21:37:14.
cp65001.py File 1106 bytes December 23 2018 21:37:14.
cp720.py File 13686 bytes December 23 2018 21:37:14.
cp737.py File 34681 bytes December 23 2018 21:37:14.
cp775.py File 34476 bytes December 23 2018 21:37:14.
cp850.py File 34105 bytes December 23 2018 21:37:14.
cp852.py File 35002 bytes December 23 2018 21:37:14.
cp855.py File 33850 bytes December 23 2018 21:37:14.
cp856.py File 12423 bytes December 23 2018 21:37:14.
cp857.py File 33908 bytes December 23 2018 21:37:14.
cp858.py File 34015 bytes December 23 2018 21:37:14.
cp860.py File 34681 bytes December 23 2018 21:37:14.
cp861.py File 34633 bytes December 23 2018 21:37:14.
cp862.py File 33370 bytes December 23 2018 21:37:14.
cp863.py File 34252 bytes December 23 2018 21:37:14.
cp864.py File 33663 bytes December 23 2018 21:37:14.
cp865.py File 34618 bytes December 23 2018 21:37:14.
cp866.py File 34396 bytes December 23 2018 21:37:14.
cp869.py File 32965 bytes December 23 2018 21:37:14.
cp874.py File 12595 bytes December 23 2018 21:37:14.
cp875.py File 12854 bytes December 23 2018 21:37:14.
cp932.py File 1023 bytes December 23 2018 21:37:14.
cp949.py File 1023 bytes December 23 2018 21:37:14.
cp950.py File 1023 bytes December 23 2018 21:37:14.
euc_jis_2004.py File 1051 bytes December 23 2018 21:37:14.
euc_jisx0213.py File 1051 bytes December 23 2018 21:37:14.
euc_jp.py File 1027 bytes December 23 2018 21:37:14.
euc_kr.py File 1027 bytes December 23 2018 21:37:14.
gb18030.py File 1031 bytes December 23 2018 21:37:14.
gb2312.py File 1027 bytes December 23 2018 21:37:14.
gbk.py File 1015 bytes December 23 2018 21:37:14.
hex_codec.py File 1508 bytes December 23 2018 21:37:14.
hp_roman8.py File 13475 bytes December 23 2018 21:37:14.
hz.py File 1011 bytes December 23 2018 21:37:14.
idna.py File 9098 bytes July 01 2025 22:09:53.
iso2022_jp.py File 1053 bytes December 23 2018 21:37:14.
iso2022_jp_1.py File 1061 bytes December 23 2018 21:37:14.
iso2022_jp_2.py File 1061 bytes December 23 2018 21:37:14.
iso2022_jp_2004.py File 1073 bytes December 23 2018 21:37:14.
iso2022_jp_3.py File 1061 bytes December 23 2018 21:37:14.
iso2022_jp_ext.py File 1069 bytes December 23 2018 21:37:14.
iso2022_kr.py File 1053 bytes December 23 2018 21:37:14.
iso8859_1.py File 13176 bytes December 23 2018 21:37:14.
iso8859_10.py File 13589 bytes December 23 2018 21:37:14.
iso8859_11.py File 12335 bytes December 23 2018 21:37:14.
iso8859_13.py File 13271 bytes December 23 2018 21:37:14.
iso8859_14.py File 13652 bytes December 23 2018 21:37:14.
iso8859_15.py File 13212 bytes December 23 2018 21:37:14.
iso8859_16.py File 13557 bytes December 23 2018 21:37:14.
iso8859_2.py File 13404 bytes December 23 2018 21:37:14.
iso8859_3.py File 13089 bytes December 23 2018 21:37:14.
iso8859_4.py File 13376 bytes December 23 2018 21:37:14.
iso8859_5.py File 13015 bytes December 23 2018 21:37:14.
iso8859_6.py File 10833 bytes December 23 2018 21:37:14.
iso8859_7.py File 12844 bytes December 23 2018 21:37:14.
iso8859_8.py File 11036 bytes December 23 2018 21:37:14.
iso8859_9.py File 13156 bytes December 23 2018 21:37:14.
johab.py File 1023 bytes December 23 2018 21:37:14.
koi8_r.py File 13779 bytes December 23 2018 21:37:14.
koi8_t.py File 13193 bytes December 23 2018 21:37:14.
koi8_u.py File 13762 bytes December 23 2018 21:37:14.
kz1048.py File 13723 bytes December 23 2018 21:37:14.
latin_1.py File 1264 bytes December 23 2018 21:37:14.
mac_arabic.py File 36467 bytes December 23 2018 21:37:14.
mac_centeuro.py File 14102 bytes December 23 2018 21:37:14.
mac_croatian.py File 13633 bytes December 23 2018 21:37:14.
mac_cyrillic.py File 13454 bytes December 23 2018 21:37:14.
mac_farsi.py File 15170 bytes December 23 2018 21:37:14.
mac_greek.py File 13721 bytes December 23 2018 21:37:14.
mac_iceland.py File 13498 bytes December 23 2018 21:37:14.
mac_latin2.py File 14118 bytes December 23 2018 21:37:14.
mac_roman.py File 13480 bytes December 23 2018 21:37:14.
mac_romanian.py File 13661 bytes December 23 2018 21:37:14.
mac_turkish.py File 13513 bytes December 23 2018 21:37:14.
mbcs.py File 1211 bytes December 23 2018 21:37:14.
oem.py File 1019 bytes December 23 2018 21:37:14.
palmos.py File 13519 bytes December 23 2018 21:37:14.
ptcp154.py File 14015 bytes December 23 2018 21:37:14.
punycode.py File 6881 bytes December 23 2018 21:37:14.
quopri_codec.py File 1525 bytes December 23 2018 21:37:14.
raw_unicode_escape.py File 1208 bytes December 23 2018 21:37:14.
rot_13.py File 2438 bytes December 23 2018 21:37:14.
shift_jis.py File 1039 bytes December 23 2018 21:37:14.
shift_jis_2004.py File 1059 bytes December 23 2018 21:37:14.
shift_jisx0213.py File 1059 bytes December 23 2018 21:37:14.
tis_620.py File 12300 bytes December 23 2018 21:37:14.
undefined.py File 1299 bytes December 23 2018 21:37:14.
unicode_escape.py File 1184 bytes December 23 2018 21:37:14.
unicode_internal.py File 1196 bytes December 23 2018 21:37:14.
utf_16.py File 5236 bytes December 23 2018 21:37:14.
utf_16_be.py File 1037 bytes December 23 2018 21:37:14.
utf_16_le.py File 1037 bytes December 23 2018 21:37:14.
utf_32.py File 5129 bytes December 23 2018 21:37:14.
utf_32_be.py File 930 bytes December 23 2018 21:37:14.
utf_32_le.py File 930 bytes December 23 2018 21:37:14.
utf_7.py File 946 bytes December 23 2018 21:37:14.
utf_8.py File 1005 bytes December 23 2018 21:37:14.
utf_8_sig.py File 4133 bytes December 23 2018 21:37:14.
uu_codec.py File 2721 bytes December 23 2018 21:37:14.
zlib_codec.py File 2204 bytes December 23 2018 21:37:14.

Reading File: ///usr/lib64/python3.6/encodings/punycode.py

""" Codec for the Punicode encoding, as specified in RFC 3492

Written by Martin v. Löwis.
"""

import codecs

##################### Encoding #####################################

def segregate(str):
    """3.1 Basic code point segregation"""
    base = bytearray()
    extended = set()
    for c in str:
        if ord(c) < 128:
            base.append(ord(c))
        else:
            extended.add(c)
    extended = sorted(extended)
    return bytes(base), extended

def selective_len(str, max):
    """Return the length of str, considering only characters below max."""
    res = 0
    for c in str:
        if ord(c) < max:
            res += 1
    return res

def selective_find(str, char, index, pos):
    """Return a pair (index, pos), indicating the next occurrence of
    char in str. index is the position of the character considering
    only ordinals up to and including char, and pos is the position in
    the full string. index/pos is the starting position in the full
    string."""

    l = len(str)
    while 1:
        pos += 1
        if pos == l:
            return (-1, -1)
        c = str[pos]
        if c == char:
            return index+1, pos
        elif c < char:
            index += 1

def insertion_unsort(str, extended):
    """3.2 Insertion unsort coding"""
    oldchar = 0x80
    result = []
    oldindex = -1
    for c in extended:
        index = pos = -1
        char = ord(c)
        curlen = selective_len(str, char)
        delta = (curlen+1) * (char - oldchar)
        while 1:
            index,pos = selective_find(str,c,index,pos)
            if index == -1:
                break
            delta += index - oldindex
            result.append(delta-1)
            oldindex = index
            delta = 0
        oldchar = char

    return result

def T(j, bias):
    # Punycode parameters: tmin = 1, tmax = 26, base = 36
    res = 36 * (j + 1) - bias
    if res < 1: return 1
    if res > 26: return 26
    return res

digits = b"abcdefghijklmnopqrstuvwxyz0123456789"
def generate_generalized_integer(N, bias):
    """3.3 Generalized variable-length integers"""
    result = bytearray()
    j = 0
    while 1:
        t = T(j, bias)
        if N < t:
            result.append(digits[N])
            return bytes(result)
        result.append(digits[t + ((N - t) % (36 - t))])
        N = (N - t) // (36 - t)
        j += 1

def adapt(delta, first, numchars):
    if first:
        delta //= 700
    else:
        delta //= 2
    delta += delta // numchars
    # ((base - tmin) * tmax) // 2 == 455
    divisions = 0
    while delta > 455:
        delta = delta // 35 # base - tmin
        divisions += 36
    bias = divisions + (36 * delta // (delta + 38))
    return bias


def generate_integers(baselen, deltas):
    """3.4 Bias adaptation"""
    # Punycode parameters: initial bias = 72, damp = 700, skew = 38
    result = bytearray()
    bias = 72
    for points, delta in enumerate(deltas):
        s = generate_generalized_integer(delta, bias)
        result.extend(s)
        bias = adapt(delta, points==0, baselen+points+1)
    return bytes(result)

def punycode_encode(text):
    base, extended = segregate(text)
    deltas = insertion_unsort(text, extended)
    extended = generate_integers(len(base), deltas)
    if base:
        return base + b"-" + extended
    return extended

##################### Decoding #####################################

def decode_generalized_number(extended, extpos, bias, errors):
    """3.3 Generalized variable-length integers"""
    result = 0
    w = 1
    j = 0
    while 1:
        try:
            char = ord(extended[extpos])
        except IndexError:
            if errors == "strict":
                raise UnicodeError("incomplete punicode string")
            return extpos + 1, None
        extpos += 1
        if 0x41 <= char <= 0x5A: # A-Z
            digit = char - 0x41
        elif 0x30 <= char <= 0x39:
            digit = char - 22 # 0x30-26
        elif errors == "strict":
            raise UnicodeError("Invalid extended code point '%s'"
                               % extended[extpos])
        else:
            return extpos, None
        t = T(j, bias)
        result += digit * w
        if digit < t:
            return extpos, result
        w = w * (36 - t)
        j += 1


def insertion_sort(base, extended, errors):
    """3.2 Insertion unsort coding"""
    char = 0x80
    pos = -1
    bias = 72
    extpos = 0
    while extpos < len(extended):
        newpos, delta = decode_generalized_number(extended, extpos,
                                                  bias, errors)
        if delta is None:
            # There was an error in decoding. We can't continue because
            # synchronization is lost.
            return base
        pos += delta+1
        char += pos // (len(base) + 1)
        if char > 0x10FFFF:
            if errors == "strict":
                raise UnicodeError("Invalid character U+%x" % char)
            char = ord('?')
        pos = pos % (len(base) + 1)
        base = base[:pos] + chr(char) + base[pos:]
        bias = adapt(delta, (extpos == 0), len(base))
        extpos = newpos
    return base

def punycode_decode(text, errors):
    if isinstance(text, str):
        text = text.encode("ascii")
    if isinstance(text, memoryview):
        text = bytes(text)
    pos = text.rfind(b"-")
    if pos == -1:
        base = ""
        extended = str(text, "ascii").upper()
    else:
        base = str(text[:pos], "ascii", errors)
        extended = str(text[pos+1:], "ascii").upper()
    return insertion_sort(base, extended, errors)

### Codec APIs

class Codec(codecs.Codec):

    def encode(self, input, errors='strict'):
        res = punycode_encode(input)
        return res, len(input)

    def decode(self, input, errors='strict'):
        if errors not in ('strict', 'replace', 'ignore'):
            raise UnicodeError("Unsupported error handling "+errors)
        res = punycode_decode(input, errors)
        return res, len(input)

class IncrementalEncoder(codecs.IncrementalEncoder):
    def encode(self, input, final=False):
        return punycode_encode(input)

class IncrementalDecoder(codecs.IncrementalDecoder):
    def decode(self, input, final=False):
        if self.errors not in ('strict', 'replace', 'ignore'):
            raise UnicodeError("Unsupported error handling "+self.errors)
        return punycode_decode(input, self.errors)

class StreamWriter(Codec,codecs.StreamWriter):
    pass

class StreamReader(Codec,codecs.StreamReader):
    pass

### encodings module API

def getregentry():
    return codecs.CodecInfo(
        name='punycode',
        encode=Codec().encode,
        decode=Codec().decode,
        incrementalencoder=IncrementalEncoder,
        incrementaldecoder=IncrementalDecoder,
        streamwriter=StreamWriter,
        streamreader=StreamReader,
    )

SILENT KILLER Tool