$84 GRAYBYTE WORDPRESS FILE MANAGER $42

SERVER : in-mum-web1330.main-hosting.eu #1 SMP Mon Feb 10 22:45:17 UTC 2025
SERVER IP : 2.57.91.18 | ADMIN IP 216.73.216.21
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/usr/lib64/python3.8/

HOME
Current File : /usr/lib64/python3.8//selectors.py
"""Selectors module.

This module allows high-level and efficient I/O multiplexing, built upon the
`select` module primitives.
"""


from abc import ABCMeta, abstractmethod
from collections import namedtuple
from collections.abc import Mapping
import math
import select
import sys


# generic events, that must be mapped to implementation-specific ones
EVENT_READ = (1 << 0)
EVENT_WRITE = (1 << 1)


def _fileobj_to_fd(fileobj):
    """Return a file descriptor from a file object.

    Parameters:
    fileobj -- file object or file descriptor

    Returns:
    corresponding file descriptor

    Raises:
    ValueError if the object is invalid
    """
    if isinstance(fileobj, int):
        fd = fileobj
    else:
        try:
            fd = int(fileobj.fileno())
        except (AttributeError, TypeError, ValueError):
            raise ValueError("Invalid file object: "
                             "{!r}".format(fileobj)) from None
    if fd < 0:
        raise ValueError("Invalid file descriptor: {}".format(fd))
    return fd


SelectorKey = namedtuple('SelectorKey', ['fileobj', 'fd', 'events', 'data'])

SelectorKey.__doc__ = """SelectorKey(fileobj, fd, events, data)

    Object used to associate a file object to its backing
    file descriptor, selected event mask, and attached data.
"""
if sys.version_info >= (3, 5):
    SelectorKey.fileobj.__doc__ = 'File object registered.'
    SelectorKey.fd.__doc__ = 'Underlying file descriptor.'
    SelectorKey.events.__doc__ = 'Events that must be waited for on this file object.'
    SelectorKey.data.__doc__ = ('''Optional opaque data associated to this file object.
    For example, this could be used to store a per-client session ID.''')

class _SelectorMapping(Mapping):
    """Mapping of file objects to selector keys."""

    def __init__(self, selector):
        self._selector = selector

    def __len__(self):
        return len(self._selector._fd_to_key)

    def __getitem__(self, fileobj):
        try:
            fd = self._selector._fileobj_lookup(fileobj)
            return self._selector._fd_to_key[fd]
        except KeyError:
            raise KeyError("{!r} is not registered".format(fileobj)) from None

    def __iter__(self):
        return iter(self._selector._fd_to_key)


class BaseSelector(metaclass=ABCMeta):
    """Selector abstract base class.

    A selector supports registering file objects to be monitored for specific
    I/O events.

    A file object is a file descriptor or any object with a `fileno()` method.
    An arbitrary object can be attached to the file object, which can be used
    for example to store context information, a callback, etc.

    A selector can use various implementations (select(), poll(), epoll()...)
    depending on the platform. The default `Selector` class uses the most
    efficient implementation on the current platform.
    """

    @abstractmethod
    def register(self, fileobj, events, data=None):
        """Register a file object.

        Parameters:
        fileobj -- file object or file descriptor
        events  -- events to monitor (bitwise mask of EVENT_READ|EVENT_WRITE)
        data    -- attached data

        Returns:
        SelectorKey instance

        Raises:
        ValueError if events is invalid
        KeyError if fileobj is already registered
        OSError if fileobj is closed or otherwise is unacceptable to
                the underlying system call (if a system call is made)

        Note:
        OSError may or may not be raised
        """
        raise NotImplementedError

    @abstractmethod
    def unregister(self, fileobj):
        """Unregister a file object.

        Parameters:
        fileobj -- file object or file descriptor

        Returns:
        SelectorKey instance

        Raises:
        KeyError if fileobj is not registered

        Note:
        If fileobj is registered but has since been closed this does
        *not* raise OSError (even if the wrapped syscall does)
        """
        raise NotImplementedError

    def modify(self, fileobj, events, data=None):
        """Change a registered file object monitored events or attached data.

        Parameters:
        fileobj -- file object or file descriptor
        events  -- events to monitor (bitwise mask of EVENT_READ|EVENT_WRITE)
        data    -- attached data

        Returns:
        SelectorKey instance

        Raises:
        Anything that unregister() or register() raises
        """
        self.unregister(fileobj)
        return self.register(fileobj, events, data)

    @abstractmethod
    def select(self, timeout=None):
        """Perform the actual selection, until some monitored file objects are
        ready or a timeout expires.

        Parameters:
        timeout -- if timeout > 0, this specifies the maximum wait time, in
                   seconds
                   if timeout <= 0, the select() call won't block, and will
                   report the currently ready file objects
                   if timeout is None, select() will block until a monitored
                   file object becomes ready

        Returns:
        list of (key, events) for ready file objects
        `events` is a bitwise mask of EVENT_READ|EVENT_WRITE
        """
        raise NotImplementedError

    def close(self):
        """Close the selector.

        This must be called to make sure that any underlying resource is freed.
        """
        pass

    def get_key(self, fileobj):
        """Return the key associated to a registered file object.

        Returns:
        SelectorKey for this file object
        """
        mapping = self.get_map()
        if mapping is None:
            raise RuntimeError('Selector is closed')
        try:
            return mapping[fileobj]
        except KeyError:
            raise KeyError("{!r} is not registered".format(fileobj)) from None

    @abstractmethod
    def get_map(self):
        """Return a mapping of file objects to selector keys."""
        raise NotImplementedError

    def __enter__(self):
        return self

    def __exit__(self, *args):
        self.close()


class _BaseSelectorImpl(BaseSelector):
    """Base selector implementation."""

    def __init__(self):
        # this maps file descriptors to keys
        self._fd_to_key = {}
        # read-only mapping returned by get_map()
        self._map = _SelectorMapping(self)

    def _fileobj_lookup(self, fileobj):
        """Return a file descriptor from a file object.

        This wraps _fileobj_to_fd() to do an exhaustive search in case
        the object is invalid but we still have it in our map.  This
        is used by unregister() so we can unregister an object that
        was previously registered even if it is closed.  It is also
        used by _SelectorMapping.
        """
        try:
            return _fileobj_to_fd(fileobj)
        except ValueError:
            # Do an exhaustive search.
            for key in self._fd_to_key.values():
                if key.fileobj is fileobj:
                    return key.fd
            # Raise ValueError after all.
            raise

    def register(self, fileobj, events, data=None):
        if (not events) or (events & ~(EVENT_READ | EVENT_WRITE)):
            raise ValueError("Invalid events: {!r}".format(events))

        key = SelectorKey(fileobj, self._fileobj_lookup(fileobj), events, data)

        if key.fd in self._fd_to_key:
            raise KeyError("{!r} (FD {}) is already registered"
                           .format(fileobj, key.fd))

        self._fd_to_key[key.fd] = key
        return key

    def unregister(self, fileobj):
        try:
            key = self._fd_to_key.pop(self._fileobj_lookup(fileobj))
        except KeyError:
            raise KeyError("{!r} is not registered".format(fileobj)) from None
        return key

    def modify(self, fileobj, events, data=None):
        try:
            key = self._fd_to_key[self._fileobj_lookup(fileobj)]
        except KeyError:
            raise KeyError("{!r} is not registered".format(fileobj)) from None
        if events != key.events:
            self.unregister(fileobj)
            key = self.register(fileobj, events, data)
        elif data != key.data:
            # Use a shortcut to update the data.
            key = key._replace(data=data)
            self._fd_to_key[key.fd] = key
        return key

    def close(self):
        self._fd_to_key.clear()
        self._map = None

    def get_map(self):
        return self._map

    def _key_from_fd(self, fd):
        """Return the key associated to a given file descriptor.

        Parameters:
        fd -- file descriptor

        Returns:
        corresponding key, or None if not found
        """
        try:
            return self._fd_to_key[fd]
        except KeyError:
            return None


class SelectSelector(_BaseSelectorImpl):
    """Select-based selector."""

    def __init__(self):
        super().__init__()
        self._readers = set()
        self._writers = set()

    def register(self, fileobj, events, data=None):
        key = super().register(fileobj, events, data)
        if events & EVENT_READ:
            self._readers.add(key.fd)
        if events & EVENT_WRITE:
            self._writers.add(key.fd)
        return key

    def unregister(self, fileobj):
        key = super().unregister(fileobj)
        self._readers.discard(key.fd)
        self._writers.discard(key.fd)
        return key

    if sys.platform == 'win32':
        def _select(self, r, w, _, timeout=None):
            r, w, x = select.select(r, w, w, timeout)
            return r, w + x, []
    else:
        _select = select.select

    def select(self, timeout=None):
        timeout = None if timeout is None else max(timeout, 0)
        ready = []
        try:
            r, w, _ = self._select(self._readers, self._writers, [], timeout)
        except InterruptedError:
            return ready
        r = set(r)
        w = set(w)
        for fd in r | w:
            events = 0
            if fd in r:
                events |= EVENT_READ
            if fd in w:
                events |= EVENT_WRITE

            key = self._key_from_fd(fd)
            if key:
                ready.append((key, events & key.events))
        return ready


class _PollLikeSelector(_BaseSelectorImpl):
    """Base class shared between poll, epoll and devpoll selectors."""
    _selector_cls = None
    _EVENT_READ = None
    _EVENT_WRITE = None

    def __init__(self):
        super().__init__()
        self._selector = self._selector_cls()

    def register(self, fileobj, events, data=None):
        key = super().register(fileobj, events, data)
        poller_events = 0
        if events & EVENT_READ:
            poller_events |= self._EVENT_READ
        if events & EVENT_WRITE:
            poller_events |= self._EVENT_WRITE
        try:
            self._selector.register(key.fd, poller_events)
        except:
            super().unregister(fileobj)
            raise
        return key

    def unregister(self, fileobj):
        key = super().unregister(fileobj)
        try:
            self._selector.unregister(key.fd)
        except OSError:
            # This can happen if the FD was closed since it
            # was registered.
            pass
        return key

    def modify(self, fileobj, events, data=None):
        try:
            key = self._fd_to_key[self._fileobj_lookup(fileobj)]
        except KeyError:
            raise KeyError(f"{fileobj!r} is not registered") from None

        changed = False
        if events != key.events:
            selector_events = 0
            if events & EVENT_READ:
                selector_events |= self._EVENT_READ
            if events & EVENT_WRITE:
                selector_events |= self._EVENT_WRITE
            try:
                self._selector.modify(key.fd, selector_events)
            except:
                super().unregister(fileobj)
                raise
            changed = True
        if data != key.data:
            changed = True

        if changed:
            key = key._replace(events=events, data=data)
            self._fd_to_key[key.fd] = key
        return key

    def select(self, timeout=None):
        # This is shared between poll() and epoll().
        # epoll() has a different signature and handling of timeout parameter.
        if timeout is None:
            timeout = None
        elif timeout <= 0:
            timeout = 0
        else:
            # poll() has a resolution of 1 millisecond, round away from
            # zero to wait *at least* timeout seconds.
            timeout = math.ceil(timeout * 1e3)
        ready = []
        try:
            fd_event_list = self._selector.poll(timeout)
        except InterruptedError:
            return ready
        for fd, event in fd_event_list:
            events = 0
            if event & ~self._EVENT_READ:
                events |= EVENT_WRITE
            if event & ~self._EVENT_WRITE:
                events |= EVENT_READ

            key = self._key_from_fd(fd)
            if key:
                ready.append((key, events & key.events))
        return ready


if hasattr(select, 'poll'):

    class PollSelector(_PollLikeSelector):
        """Poll-based selector."""
        _selector_cls = select.poll
        _EVENT_READ = select.POLLIN
        _EVENT_WRITE = select.POLLOUT


if hasattr(select, 'epoll'):

    class EpollSelector(_PollLikeSelector):
        """Epoll-based selector."""
        _selector_cls = select.epoll
        _EVENT_READ = select.EPOLLIN
        _EVENT_WRITE = select.EPOLLOUT

        def fileno(self):
            return self._selector.fileno()

        def select(self, timeout=None):
            if timeout is None:
                timeout = -1
            elif timeout <= 0:
                timeout = 0
            else:
                # epoll_wait() has a resolution of 1 millisecond, round away
                # from zero to wait *at least* timeout seconds.
                timeout = math.ceil(timeout * 1e3) * 1e-3

            # epoll_wait() expects `maxevents` to be greater than zero;
            # we want to make sure that `select()` can be called when no
            # FD is registered.
            max_ev = max(len(self._fd_to_key), 1)

            ready = []
            try:
                fd_event_list = self._selector.poll(timeout, max_ev)
            except InterruptedError:
                return ready
            for fd, event in fd_event_list:
                events = 0
                if event & ~select.EPOLLIN:
                    events |= EVENT_WRITE
                if event & ~select.EPOLLOUT:
                    events |= EVENT_READ

                key = self._key_from_fd(fd)
                if key:
                    ready.append((key, events & key.events))
            return ready

        def close(self):
            self._selector.close()
            super().close()


if hasattr(select, 'devpoll'):

    class DevpollSelector(_PollLikeSelector):
        """Solaris /dev/poll selector."""
        _selector_cls = select.devpoll
        _EVENT_READ = select.POLLIN
        _EVENT_WRITE = select.POLLOUT

        def fileno(self):
            return self._selector.fileno()

        def close(self):
            self._selector.close()
            super().close()


if hasattr(select, 'kqueue'):

    class KqueueSelector(_BaseSelectorImpl):
        """Kqueue-based selector."""

        def __init__(self):
            super().__init__()
            self._selector = select.kqueue()

        def fileno(self):
            return self._selector.fileno()

        def register(self, fileobj, events, data=None):
            key = super().register(fileobj, events, data)
            try:
                if events & EVENT_READ:
                    kev = select.kevent(key.fd, select.KQ_FILTER_READ,
                                        select.KQ_EV_ADD)
                    self._selector.control([kev], 0, 0)
                if events & EVENT_WRITE:
                    kev = select.kevent(key.fd, select.KQ_FILTER_WRITE,
                                        select.KQ_EV_ADD)
                    self._selector.control([kev], 0, 0)
            except:
                super().unregister(fileobj)
                raise
            return key

        def unregister(self, fileobj):
            key = super().unregister(fileobj)
            if key.events & EVENT_READ:
                kev = select.kevent(key.fd, select.KQ_FILTER_READ,
                                    select.KQ_EV_DELETE)
                try:
                    self._selector.control([kev], 0, 0)
                except OSError:
                    # This can happen if the FD was closed since it
                    # was registered.
                    pass
            if key.events & EVENT_WRITE:
                kev = select.kevent(key.fd, select.KQ_FILTER_WRITE,
                                    select.KQ_EV_DELETE)
                try:
                    self._selector.control([kev], 0, 0)
                except OSError:
                    # See comment above.
                    pass
            return key

        def select(self, timeout=None):
            timeout = None if timeout is None else max(timeout, 0)
            max_ev = len(self._fd_to_key)
            ready = []
            try:
                kev_list = self._selector.control(None, max_ev, timeout)
            except InterruptedError:
                return ready
            for kev in kev_list:
                fd = kev.ident
                flag = kev.filter
                events = 0
                if flag == select.KQ_FILTER_READ:
                    events |= EVENT_READ
                if flag == select.KQ_FILTER_WRITE:
                    events |= EVENT_WRITE

                key = self._key_from_fd(fd)
                if key:
                    ready.append((key, events & key.events))
            return ready

        def close(self):
            self._selector.close()
            super().close()


# Choose the best implementation, roughly:
#    epoll|kqueue|devpoll > poll > select.
# select() also can't accept a FD > FD_SETSIZE (usually around 1024)
if 'KqueueSelector' in globals():
    DefaultSelector = KqueueSelector
elif 'EpollSelector' in globals():
    DefaultSelector = EpollSelector
elif 'DevpollSelector' in globals():
    DefaultSelector = DevpollSelector
elif 'PollSelector' in globals():
    DefaultSelector = PollSelector
else:
    DefaultSelector = SelectSelector

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
4 Mar 2026 4.04 PM
root / root
0555
__pycache__
--
21 Oct 2025 6.55 AM
root / root
0755
asyncio
--
21 Oct 2025 6.55 AM
root / root
0755
collections
--
21 Oct 2025 6.55 AM
root / root
0755
concurrent
--
21 Oct 2025 6.55 AM
root / root
0755
config-3.8-x86_64-linux-gnu
--
21 Oct 2025 6.55 AM
root / root
0755
ctypes
--
21 Oct 2025 6.55 AM
root / root
0755
curses
--
21 Oct 2025 6.55 AM
root / root
0755
dbm
--
21 Oct 2025 6.55 AM
root / root
0755
distutils
--
21 Oct 2025 6.55 AM
root / root
0755
email
--
21 Oct 2025 6.55 AM
root / root
0755
encodings
--
21 Oct 2025 6.55 AM
root / root
0755
ensurepip
--
21 Oct 2025 6.55 AM
root / root
0755
html
--
21 Oct 2025 6.55 AM
root / root
0755
http
--
21 Oct 2025 6.55 AM
root / root
0755
importlib
--
21 Oct 2025 6.55 AM
root / root
0755
json
--
21 Oct 2025 6.55 AM
root / root
0755
lib-dynload
--
21 Oct 2025 6.55 AM
root / root
0755
lib2to3
--
21 Oct 2025 6.55 AM
root / root
0755
logging
--
21 Oct 2025 6.55 AM
root / root
0755
multiprocessing
--
21 Oct 2025 6.55 AM
root / root
0755
pydoc_data
--
21 Oct 2025 6.55 AM
root / root
0755
site-packages
--
21 Oct 2025 6.55 AM
root / root
0755
sqlite3
--
21 Oct 2025 6.55 AM
root / root
0755
unittest
--
21 Oct 2025 6.55 AM
root / root
0755
urllib
--
21 Oct 2025 6.55 AM
root / root
0755
venv
--
21 Oct 2025 6.55 AM
root / root
0755
wsgiref
--
21 Oct 2025 6.55 AM
root / root
0755
xml
--
21 Oct 2025 6.55 AM
root / root
0755
xmlrpc
--
21 Oct 2025 6.55 AM
root / root
0755
LICENSE.txt
13.61 KB
6 Jun 2023 1.32 PM
root / root
0644
__future__.py
5.026 KB
6 Jun 2023 1.32 PM
root / root
0644
__phello__.foo.py
0.063 KB
6 Jun 2023 1.32 PM
root / root
0644
_bootlocale.py
1.759 KB
6 Jun 2023 1.32 PM
root / root
0644
_collections_abc.py
25.488 KB
6 Jun 2023 1.32 PM
root / root
0644
_compat_pickle.py
8.544 KB
6 Jun 2023 1.32 PM
root / root
0644
_compression.py
5.215 KB
6 Jun 2023 1.32 PM
root / root
0644
_dummy_thread.py
5.886 KB
6 Jun 2023 1.32 PM
root / root
0644
_markupbase.py
14.256 KB
6 Jun 2023 1.32 PM
root / root
0644
_osx_support.py
21.264 KB
6 Jun 2023 1.32 PM
root / root
0644
_py_abc.py
6.044 KB
6 Jun 2023 1.32 PM
root / root
0644
_pydecimal.py
223.307 KB
6 Jun 2023 1.32 PM
root / root
0644
_pyio.py
90.993 KB
6 Jun 2023 1.32 PM
root / root
0644
_sitebuiltins.py
3.042 KB
6 Jun 2023 1.32 PM
root / root
0644
_strptime.py
24.676 KB
6 Jun 2023 1.32 PM
root / root
0644
_sysconfigdata__linux_x86_64-linux-gnu.py
37.607 KB
17 Oct 2023 6.12 PM
root / root
0644
_sysconfigdata_d_linux_x86_64-linux-gnu.py
37.341 KB
17 Oct 2023 6.03 PM
root / root
0644
_threading_local.py
7.051 KB
6 Jun 2023 1.32 PM
root / root
0644
_weakrefset.py
5.601 KB
6 Jun 2023 1.32 PM
root / root
0644
abc.py
4.384 KB
6 Jun 2023 1.32 PM
root / root
0644
aifc.py
32.045 KB
6 Jun 2023 1.32 PM
root / root
0644
antigravity.py
0.466 KB
6 Jun 2023 1.32 PM
root / root
0644
argparse.py
93.765 KB
6 Jun 2023 1.32 PM
root / root
0644
ast.py
18.783 KB
6 Jun 2023 1.32 PM
root / root
0644
asynchat.py
11.063 KB
6 Jun 2023 1.32 PM
root / root
0644
asyncore.py
19.623 KB
6 Jun 2023 1.32 PM
root / root
0644
base64.py
19.904 KB
6 Jun 2023 1.32 PM
root / root
0755
bdb.py
31.305 KB
6 Jun 2023 1.32 PM
root / root
0644
binhex.py
13.627 KB
6 Jun 2023 1.32 PM
root / root
0644
bisect.py
2.162 KB
6 Jun 2023 1.32 PM
root / root
0644
bz2.py
12.264 KB
6 Jun 2023 1.32 PM
root / root
0644
cProfile.py
6.846 KB
6 Jun 2023 1.32 PM
root / root
0755
calendar.py
24.25 KB
6 Jun 2023 1.32 PM
root / root
0644
cgi.py
33.139 KB
17 Oct 2023 6.02 PM
root / root
0755
cgitb.py
11.813 KB
6 Jun 2023 1.32 PM
root / root
0644
chunk.py
5.308 KB
6 Jun 2023 1.32 PM
root / root
0644
cmd.py
14.512 KB
6 Jun 2023 1.32 PM
root / root
0644
code.py
10.373 KB
6 Jun 2023 1.32 PM
root / root
0644
codecs.py
35.808 KB
6 Jun 2023 1.32 PM
root / root
0644
codeop.py
6.182 KB
6 Jun 2023 1.32 PM
root / root
0644
colorsys.py
3.969 KB
6 Jun 2023 1.32 PM
root / root
0644
compileall.py
13.357 KB
6 Jun 2023 1.32 PM
root / root
0644
configparser.py
53.1 KB
6 Jun 2023 1.32 PM
root / root
0644
contextlib.py
24.409 KB
6 Jun 2023 1.32 PM
root / root
0644
contextvars.py
0.126 KB
6 Jun 2023 1.32 PM
root / root
0644
copy.py
8.458 KB
6 Jun 2023 1.32 PM
root / root
0644
copyreg.py
6.968 KB
6 Jun 2023 1.32 PM
root / root
0644
crypt.py
3.525 KB
6 Jun 2023 1.32 PM
root / root
0644
csv.py
15.766 KB
6 Jun 2023 1.32 PM
root / root
0644
dataclasses.py
48.802 KB
6 Jun 2023 1.32 PM
root / root
0644
datetime.py
86.218 KB
6 Jun 2023 1.32 PM
root / root
0644
decimal.py
0.313 KB
6 Jun 2023 1.32 PM
root / root
0644
difflib.py
82.088 KB
6 Jun 2023 1.32 PM
root / root
0644
dis.py
20.088 KB
6 Jun 2023 1.32 PM
root / root
0644
doctest.py
102.093 KB
6 Jun 2023 1.32 PM
root / root
0644
dummy_threading.py
2.749 KB
6 Jun 2023 1.32 PM
root / root
0644
enum.py
37.242 KB
6 Jun 2023 1.32 PM
root / root
0644
filecmp.py
9.6 KB
6 Jun 2023 1.32 PM
root / root
0644
fileinput.py
14.364 KB
6 Jun 2023 1.32 PM
root / root
0644
fnmatch.py
3.983 KB
6 Jun 2023 1.32 PM
root / root
0644
formatter.py
14.788 KB
6 Jun 2023 1.32 PM
root / root
0644
fractions.py
23.759 KB
6 Jun 2023 1.32 PM
root / root
0644
ftplib.py
34.306 KB
6 Jun 2023 1.32 PM
root / root
0644
functools.py
36.529 KB
6 Jun 2023 1.32 PM
root / root
0644
genericpath.py
4.858 KB
6 Jun 2023 1.32 PM
root / root
0644
getopt.py
7.313 KB
6 Jun 2023 1.32 PM
root / root
0644
getpass.py
5.854 KB
6 Jun 2023 1.32 PM
root / root
0644
gettext.py
26.502 KB
6 Jun 2023 1.32 PM
root / root
0644
glob.py
5.563 KB
6 Jun 2023 1.32 PM
root / root
0644
gzip.py
20.911 KB
6 Jun 2023 1.32 PM
root / root
0644
hashlib.py
8.138 KB
17 Oct 2023 6.02 PM
root / root
0644
heapq.py
22.341 KB
6 Jun 2023 1.32 PM
root / root
0644
hmac.py
7.666 KB
17 Oct 2023 6.02 PM
root / root
0644
imaplib.py
52.35 KB
6 Jun 2023 1.32 PM
root / root
0644
imghdr.py
3.719 KB
6 Jun 2023 1.32 PM
root / root
0644
imp.py
10.289 KB
6 Jun 2023 1.32 PM
root / root
0644
inspect.py
115.771 KB
6 Jun 2023 1.32 PM
root / root
0644
io.py
3.458 KB
6 Jun 2023 1.32 PM
root / root
0644
ipaddress.py
69.965 KB
6 Jun 2023 1.32 PM
root / root
0644
keyword.py
0.923 KB
6 Jun 2023 1.32 PM
root / root
0644
linecache.py
5.205 KB
6 Jun 2023 1.32 PM
root / root
0644
locale.py
76.358 KB
6 Jun 2023 1.32 PM
root / root
0644
lzma.py
12.679 KB
6 Jun 2023 1.32 PM
root / root
0644
mailbox.py
76.817 KB
6 Jun 2023 1.32 PM
root / root
0644
mailcap.py
8.854 KB
6 Jun 2023 1.32 PM
root / root
0644
mimetypes.py
21.156 KB
6 Jun 2023 1.32 PM
root / root
0644
modulefinder.py
23.857 KB
6 Jun 2023 1.32 PM
root / root
0644
netrc.py
5.436 KB
6 Jun 2023 1.32 PM
root / root
0644
nntplib.py
42.247 KB
6 Jun 2023 1.32 PM
root / root
0644
ntpath.py
27.084 KB
6 Jun 2023 1.32 PM
root / root
0644
nturl2path.py
2.819 KB
6 Jun 2023 1.32 PM
root / root
0644
numbers.py
10.004 KB
6 Jun 2023 1.32 PM
root / root
0644
opcode.py
5.672 KB
6 Jun 2023 1.32 PM
root / root
0644
operator.py
10.46 KB
6 Jun 2023 1.32 PM
root / root
0644
optparse.py
58.954 KB
6 Jun 2023 1.32 PM
root / root
0644
os.py
38.081 KB
6 Jun 2023 1.32 PM
root / root
0644
pathlib.py
51.377 KB
6 Jun 2023 1.32 PM
root / root
0644
pdb.py
61.268 KB
6 Jun 2023 1.32 PM
root / root
0755
pickle.py
62.956 KB
6 Jun 2023 1.32 PM
root / root
0644
pickletools.py
91.295 KB
6 Jun 2023 1.32 PM
root / root
0644
pipes.py
8.707 KB
6 Jun 2023 1.32 PM
root / root
0644
pkgutil.py
20.996 KB
6 Jun 2023 1.32 PM
root / root
0644
platform.py
39.478 KB
6 Jun 2023 1.32 PM
root / root
0755
plistlib.py
31.465 KB
6 Jun 2023 1.32 PM
root / root
0644
poplib.py
14.724 KB
6 Jun 2023 1.32 PM
root / root
0644
posixpath.py
15.261 KB
6 Jun 2023 1.32 PM
root / root
0644
pprint.py
20.98 KB
6 Jun 2023 1.32 PM
root / root
0644
profile.py
22.994 KB
6 Jun 2023 1.32 PM
root / root
0755
pstats.py
26.704 KB
6 Jun 2023 1.32 PM
root / root
0644
pty.py
4.694 KB
6 Jun 2023 1.32 PM
root / root
0644
py_compile.py
8.011 KB
17 Oct 2023 6.02 PM
root / root
0644
pyclbr.py
14.897 KB
6 Jun 2023 1.32 PM
root / root
0644
pydoc.py
104.199 KB
17 Oct 2023 6.12 PM
root / root
0644
queue.py
11.09 KB
6 Jun 2023 1.32 PM
root / root
0644
quopri.py
7.082 KB
6 Jun 2023 1.32 PM
root / root
0755
random.py
28.127 KB
6 Jun 2023 1.32 PM
root / root
0644
re.py
15.489 KB
6 Jun 2023 1.32 PM
root / root
0644
reprlib.py
5.144 KB
6 Jun 2023 1.32 PM
root / root
0644
rlcompleter.py
6.931 KB
6 Jun 2023 1.32 PM
root / root
0644
runpy.py
11.77 KB
6 Jun 2023 1.32 PM
root / root
0644
sched.py
6.291 KB
6 Jun 2023 1.32 PM
root / root
0644
secrets.py
1.99 KB
6 Jun 2023 1.32 PM
root / root
0644
selectors.py
18.126 KB
6 Jun 2023 1.32 PM
root / root
0644
shelve.py
8.327 KB
6 Jun 2023 1.32 PM
root / root
0644
shlex.py
13.013 KB
6 Jun 2023 1.32 PM
root / root
0644
shutil.py
50.548 KB
6 Jun 2023 1.32 PM
root / root
0644
signal.py
2.22 KB
6 Jun 2023 1.32 PM
root / root
0644
site.py
21.326 KB
17 Oct 2023 6.02 PM
root / root
0644
smtpd.py
33.896 KB
6 Jun 2023 1.32 PM
root / root
0755
smtplib.py
43.946 KB
6 Jun 2023 1.32 PM
root / root
0755
sndhdr.py
6.933 KB
6 Jun 2023 1.32 PM
root / root
0644
socket.py
34.417 KB
6 Jun 2023 1.32 PM
root / root
0644
socketserver.py
26.656 KB
6 Jun 2023 1.32 PM
root / root
0644
sre_compile.py
26.069 KB
6 Jun 2023 1.32 PM
root / root
0644
sre_constants.py
6.986 KB
6 Jun 2023 1.32 PM
root / root
0644
sre_parse.py
39.287 KB
6 Jun 2023 1.32 PM
root / root
0644
ssl.py
49.57 KB
6 Jun 2023 1.32 PM
root / root
0644
stat.py
5.356 KB
6 Jun 2023 1.32 PM
root / root
0644
statistics.py
38.76 KB
6 Jun 2023 1.32 PM
root / root
0644
string.py
10.288 KB
6 Jun 2023 1.32 PM
root / root
0644
stringprep.py
12.614 KB
6 Jun 2023 1.32 PM
root / root
0644
struct.py
0.251 KB
6 Jun 2023 1.32 PM
root / root
0644
subprocess.py
76.416 KB
6 Jun 2023 1.32 PM
root / root
0644
sunau.py
17.944 KB
6 Jun 2023 1.32 PM
root / root
0644
symbol.py
2.06 KB
17 Oct 2023 6.04 PM
root / root
0644
symtable.py
7.833 KB
6 Jun 2023 1.32 PM
root / root
0644
sysconfig.py
24.313 KB
17 Oct 2023 6.12 PM
root / root
0644
tabnanny.py
11.139 KB
6 Jun 2023 1.32 PM
root / root
0755
tarfile.py
103.978 KB
17 Oct 2023 6.02 PM
root / root
0755
telnetlib.py
22.709 KB
6 Jun 2023 1.32 PM
root / root
0644
tempfile.py
26.892 KB
6 Jun 2023 1.32 PM
root / root
0644
textwrap.py
18.952 KB
6 Jun 2023 1.32 PM
root / root
0644
this.py
0.979 KB
6 Jun 2023 1.32 PM
root / root
0644
threading.py
49.629 KB
6 Jun 2023 1.32 PM
root / root
0644
timeit.py
13.164 KB
6 Jun 2023 1.32 PM
root / root
0755
token.py
2.313 KB
6 Jun 2023 1.32 PM
root / root
0644
tokenize.py
25.235 KB
6 Jun 2023 1.32 PM
root / root
0644
trace.py
29.17 KB
6 Jun 2023 1.32 PM
root / root
0755
traceback.py
23.058 KB
6 Jun 2023 1.32 PM
root / root
0644
tracemalloc.py
16.676 KB
6 Jun 2023 1.32 PM
root / root
0644
tty.py
0.858 KB
6 Jun 2023 1.32 PM
root / root
0644
types.py
9.485 KB
6 Jun 2023 1.32 PM
root / root
0644
typing.py
67.346 KB
6 Jun 2023 1.32 PM
root / root
0644
uu.py
7.106 KB
17 Oct 2023 6.12 PM
root / root
0644
uuid.py
29.8 KB
17 Oct 2023 6.02 PM
root / root
0644
warnings.py
19.227 KB
6 Jun 2023 1.32 PM
root / root
0644
wave.py
17.803 KB
6 Jun 2023 1.32 PM
root / root
0644
weakref.py
20.886 KB
6 Jun 2023 1.32 PM
root / root
0644
webbrowser.py
23.519 KB
6 Jun 2023 1.32 PM
root / root
0755
xdrlib.py
5.774 KB
6 Jun 2023 1.32 PM
root / root
0644
zipapp.py
7.358 KB
6 Jun 2023 1.32 PM
root / root
0644
zipfile.py
85.672 KB
6 Jun 2023 1.32 PM
root / root
0644
zipimport.py
30.044 KB
6 Jun 2023 1.32 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF