404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.139.87.151: ~ $
"""Helper to provide extensibility for pickle.

This is only useful to add pickle support for extension types defined in
C, not for instances of user-defined classes.
"""

__all__ = ["pickle", "constructor",
           "add_extension", "remove_extension", "clear_extension_cache"]

dispatch_table = {}

def pickle(ob_type, pickle_function, constructor_ob=None):
    if not callable(pickle_function):
        raise TypeError("reduction functions must be callable")
    dispatch_table[ob_type] = pickle_function

    # The constructor_ob function is a vestige of safe for unpickling.
    # There is no reason for the caller to pass it anymore.
    if constructor_ob is not None:
        constructor(constructor_ob)

def constructor(object):
    if not callable(object):
        raise TypeError("constructors must be callable")

# Example: provide pickling support for complex numbers.

try:
    complex
except NameError:
    pass
else:

    def pickle_complex(c):
        return complex, (c.real, c.imag)

    pickle(complex, pickle_complex, complex)

def pickle_union(obj):
    import functools, operator
    return functools.reduce, (operator.or_, obj.__args__)

pickle(type(int | str), pickle_union)

# Support for pickling new-style objects

def _reconstructor(cls, base, state):
    if base is object:
        obj = object.__new__(cls)
    else:
        obj = base.__new__(cls, state)
        if base.__init__ != object.__init__:
            base.__init__(obj, state)
    return obj

_HEAPTYPE = 1<<9
_new_type = type(int.__new__)

# Python code for object.__reduce_ex__ for protocols 0 and 1

def _reduce_ex(self, proto):
    assert proto < 2
    cls = self.__class__
    for base in cls.__mro__:
        if hasattr(base, '__flags__') and not base.__flags__ & _HEAPTYPE:
            break
        new = base.__new__
        if isinstance(new, _new_type) and new.__self__ is base:
            break
    else:
        base = object # not really reachable
    if base is object:
        state = None
    else:
        if base is cls:
            raise TypeError(f"cannot pickle {cls.__name__!r} object")
        state = base(self)
    args = (cls, base, state)
    try:
        getstate = self.__getstate__
    except AttributeError:
        if getattr(self, "__slots__", None):
            raise TypeError(f"cannot pickle {cls.__name__!r} object: "
                            f"a class that defines __slots__ without "
                            f"defining __getstate__ cannot be pickled "
                            f"with protocol {proto}") from None
        try:
            dict = self.__dict__
        except AttributeError:
            dict = None
    else:
        if (type(self).__getstate__ is object.__getstate__ and
            getattr(self, "__slots__", None)):
            raise TypeError("a class that defines __slots__ without "
                            "defining __getstate__ cannot be pickled")
        dict = getstate()
    if dict:
        return _reconstructor, args, dict
    else:
        return _reconstructor, args

# Helper for __reduce_ex__ protocol 2

def __newobj__(cls, *args):
    return cls.__new__(cls, *args)

def __newobj_ex__(cls, args, kwargs):
    """Used by pickle protocol 4, instead of __newobj__ to allow classes with
    keyword-only arguments to be pickled correctly.
    """
    return cls.__new__(cls, *args, **kwargs)

def _slotnames(cls):
    """Return a list of slot names for a given class.

    This needs to find slots defined by the class and its bases, so we
    can't simply return the __slots__ attribute.  We must walk down
    the Method Resolution Order and concatenate the __slots__ of each
    class found there.  (This assumes classes don't modify their
    __slots__ attribute to misrepresent their slots after the class is
    defined.)
    """

    # Get the value from a cache in the class if possible
    names = cls.__dict__.get("__slotnames__")
    if names is not None:
        return names

    # Not cached -- calculate the value
    names = []
    if not hasattr(cls, "__slots__"):
        # This class has no slots
        pass
    else:
        # Slots found -- gather slot names from all base classes
        for c in cls.__mro__:
            if "__slots__" in c.__dict__:
                slots = c.__dict__['__slots__']
                # if class has a single slot, it can be given as a string
                if isinstance(slots, str):
                    slots = (slots,)
                for name in slots:
                    # special descriptors
                    if name in ("__dict__", "__weakref__"):
                        continue
                    # mangled names
                    elif name.startswith('__') and not name.endswith('__'):
                        stripped = c.__name__.lstrip('_')
                        if stripped:
                            names.append('_%s%s' % (stripped, name))
                        else:
                            names.append(name)
                    else:
                        names.append(name)

    # Cache the outcome in the class if at all possible
    try:
        cls.__slotnames__ = names
    except:
        pass # But don't die if we can't

    return names

# A registry of extension codes.  This is an ad-hoc compression
# mechanism.  Whenever a global reference to <module>, <name> is about
# to be pickled, the (<module>, <name>) tuple is looked up here to see
# if it is a registered extension code for it.  Extension codes are
# universal, so that the meaning of a pickle does not depend on
# context.  (There are also some codes reserved for local use that
# don't have this restriction.)  Codes are positive ints; 0 is
# reserved.

_extension_registry = {}                # key -> code
_inverted_registry = {}                 # code -> key
_extension_cache = {}                   # code -> object
# Don't ever rebind those names:  pickling grabs a reference to them when
# it's initialized, and won't see a rebinding.

def add_extension(module, name, code):
    """Register an extension code."""
    code = int(code)
    if not 1 <= code <= 0x7fffffff:
        raise ValueError("code out of range")
    key = (module, name)
    if (_extension_registry.get(key) == code and
        _inverted_registry.get(code) == key):
        return # Redundant registrations are benign
    if key in _extension_registry:
        raise ValueError("key %s is already registered with code %s" %
                         (key, _extension_registry[key]))
    if code in _inverted_registry:
        raise ValueError("code %s is already in use for key %s" %
                         (code, _inverted_registry[code]))
    _extension_registry[key] = code
    _inverted_registry[code] = key

def remove_extension(module, name, code):
    """Unregister an extension code.  For testing only."""
    key = (module, name)
    if (_extension_registry.get(key) != code or
        _inverted_registry.get(code) != key):
        raise ValueError("key %s is not registered with code %s" %
                         (key, code))
    del _extension_registry[key]
    del _inverted_registry[code]
    if code in _extension_cache:
        del _extension_cache[code]

def clear_extension_cache():
    _extension_cache.clear()

# Standard extension code assignments

# Reserved ranges

# First  Last Count  Purpose
#     1   127   127  Reserved for Python standard library
#   128   191    64  Reserved for Zope
#   192   239    48  Reserved for 3rd parties
#   240   255    16  Reserved for private use (will never be assigned)
#   256   Inf   Inf  Reserved for future assignment

# Extension codes are assigned by the Python Software Foundation.

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
asyncio Folder 0755
collections Folder 0755
concurrent Folder 0755
config-3.11-x86_64-linux-gnu Folder 0755
ctypes Folder 0755
curses Folder 0755
dbm Folder 0755
distutils Folder 0755
email Folder 0755
encodings Folder 0755
ensurepip Folder 0755
html Folder 0755
http Folder 0755
importlib Folder 0755
json Folder 0755
lib-dynload Folder 0755
lib2to3 Folder 0755
logging Folder 0755
multiprocessing Folder 0755
pydoc_data Folder 0755
re Folder 0755
site-packages Folder 0755
sqlite3 Folder 0755
tomllib Folder 0755
unittest Folder 0755
urllib Folder 0755
venv Folder 0755
wsgiref Folder 0755
xml Folder 0755
xmlrpc Folder 0755
zoneinfo Folder 0755
LICENSE.txt File 13.61 KB 0644
__future__.py File 5.1 KB 0644
__hello__.py File 227 B 0644
_aix_support.py File 3.31 KB 0644
_bootsubprocess.py File 2.61 KB 0644
_collections_abc.py File 29.49 KB 0644
_compat_pickle.py File 8.56 KB 0644
_compression.py File 5.55 KB 0644
_markupbase.py File 14.31 KB 0644
_osx_support.py File 21.51 KB 0644
_py_abc.py File 6.04 KB 0644
_pydecimal.py File 223.83 KB 0644
_pyio.py File 91.99 KB 0644
_sitebuiltins.py File 3.05 KB 0644
_strptime.py File 24.58 KB 0644
_sysconfigdata__linux_x86_64-linux-gnu.py File 57.28 KB 0644
_sysconfigdata_d_linux_x86_64-linux-gnu.py File 56.52 KB 0644
_threading_local.py File 7.05 KB 0644
_weakrefset.py File 5.75 KB 0644
abc.py File 6.38 KB 0644
aifc.py File 33.41 KB 0644
antigravity.py File 500 B 0644
argparse.py File 97.93 KB 0644
ast.py File 60 KB 0644
asynchat.py File 11.3 KB 0644
asyncore.py File 19.83 KB 0644
base64.py File 20.55 KB 0755
bdb.py File 31.7 KB 0644
bisect.py File 3.06 KB 0644
bz2.py File 11.57 KB 0644
cProfile.py File 6.21 KB 0755
calendar.py File 24.15 KB 0644
cgi.py File 33.63 KB 0755
cgitb.py File 12.13 KB 0644
chunk.py File 5.37 KB 0644
cmd.py File 14.52 KB 0644
code.py File 10.37 KB 0644
codecs.py File 36.28 KB 0644
codeop.py File 5.77 KB 0644
colorsys.py File 3.97 KB 0644
compileall.py File 19.78 KB 0644
configparser.py File 54.36 KB 0644
contextlib.py File 26.77 KB 0644
contextvars.py File 129 B 0644
copy.py File 8.48 KB 0644
copyreg.py File 7.5 KB 0644
crypt.py File 3.82 KB 0644
csv.py File 15.65 KB 0644
dataclasses.py File 57.1 KB 0644
datetime.py File 89.68 KB 0644
decimal.py File 320 B 0644
difflib.py File 81.36 KB 0644
dis.py File 28.23 KB 0644
doctest.py File 103.81 KB 0644
enum.py File 77.72 KB 0644
filecmp.py File 9.94 KB 0644
fileinput.py File 15.35 KB 0644
fnmatch.py File 5.86 KB 0644
fractions.py File 28 KB 0644
ftplib.py File 34.98 KB 0644
functools.py File 37.51 KB 0644
genericpath.py File 4.86 KB 0644
getopt.py File 7.31 KB 0644
getpass.py File 5.85 KB 0644
gettext.py File 20.82 KB 0644
glob.py File 8.53 KB 0644
graphlib.py File 9.43 KB 0644
gzip.py File 23.51 KB 0644
hashlib.py File 11.49 KB 0644
heapq.py File 22.48 KB 0644
hmac.py File 7.54 KB 0644
imaplib.py File 53.58 KB 0644
imghdr.py File 3.86 KB 0644
imp.py File 10.36 KB 0644
inspect.py File 120.53 KB 0644
io.py File 4.22 KB 0644
ipaddress.py File 76.52 KB 0644
keyword.py File 1.04 KB 0644
linecache.py File 5.52 KB 0644
locale.py File 77.24 KB 0644
lzma.py File 12.97 KB 0644
mailbox.py File 76.98 KB 0644
mailcap.py File 9.15 KB 0644
mimetypes.py File 22.42 KB 0644
modulefinder.py File 23.14 KB 0644
netrc.py File 6.77 KB 0644
nntplib.py File 40.12 KB 0644
ntpath.py File 29.51 KB 0644
nturl2path.py File 2.82 KB 0644
numbers.py File 10.11 KB 0644
opcode.py File 10.2 KB 0644
operator.py File 10.71 KB 0644
optparse.py File 58.95 KB 0644
os.py File 38.6 KB 0644
pathlib.py File 47.43 KB 0644
pdb.py File 62.68 KB 0755
pickle.py File 63.61 KB 0644
pickletools.py File 91.66 KB 0644
pipes.py File 8.77 KB 0644
pkgutil.py File 24.06 KB 0644
platform.py File 41.3 KB 0755
plistlib.py File 27.69 KB 0644
poplib.py File 14.84 KB 0644
posixpath.py File 16.61 KB 0644
pprint.py File 24.01 KB 0644
profile.py File 22.36 KB 0755
pstats.py File 28.67 KB 0644
pty.py File 6.17 KB 0644
py_compile.py File 7.65 KB 0644
pyclbr.py File 11.13 KB 0644
pydoc.py File 110.02 KB 0755
queue.py File 11.23 KB 0644
quopri.py File 7.11 KB 0755
random.py File 31.41 KB 0644
reprlib.py File 5.31 KB 0644
rlcompleter.py File 7.64 KB 0644
runpy.py File 12.85 KB 0644
sched.py File 6.2 KB 0644
secrets.py File 1.98 KB 0644
selectors.py File 19.21 KB 0644
shelve.py File 8.36 KB 0644
shlex.py File 13.18 KB 0644
shutil.py File 55.19 KB 0644
signal.py File 2.44 KB 0644
site.py File 22.45 KB 0644
smtpd.py File 30.44 KB 0755
smtplib.py File 44.37 KB 0755
sndhdr.py File 7.27 KB 0644
socket.py File 36.68 KB 0644
socketserver.py File 26.94 KB 0644
sre_compile.py File 231 B 0644
sre_constants.py File 232 B 0644
sre_parse.py File 229 B 0644
ssl.py File 53.03 KB 0644
stat.py File 5.36 KB 0644
statistics.py File 46.59 KB 0644
string.py File 11.51 KB 0644
stringprep.py File 12.61 KB 0644
struct.py File 257 B 0644
subprocess.py File 86.65 KB 0644
sunau.py File 18.05 KB 0644
symtable.py File 10.13 KB 0644
sysconfig.py File 29.6 KB 0644
tabnanny.py File 11.05 KB 0755
tarfile.py File 105.35 KB 0755
telnetlib.py File 22.75 KB 0644
tempfile.py File 31.13 KB 0644
textwrap.py File 19.26 KB 0644
this.py File 1003 B 0644
threading.py File 56.87 KB 0644
timeit.py File 13.21 KB 0755
token.py File 2.33 KB 0644
tokenize.py File 25.72 KB 0644
trace.py File 28.51 KB 0755
traceback.py File 39.6 KB 0644
tracemalloc.py File 17.62 KB 0644
tty.py File 879 B 0644
types.py File 9.83 KB 0644
typing.py File 118.12 KB 0644
uu.py File 7.17 KB 0644
uuid.py File 26.95 KB 0644
warnings.py File 20.62 KB 0644
wave.py File 21.31 KB 0644
weakref.py File 21.01 KB 0644
webbrowser.py File 24.56 KB 0755
xdrlib.py File 5.84 KB 0644
zipapp.py File 7.36 KB 0644
zipfile.py File 91.59 KB 0644
zipimport.py File 30.17 KB 0644