404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.144.100.31: ~ $
'''A multi-producer, multi-consumer queue.'''

try:
    import threading
except ImportError:
    import dummy_threading as threading
from collections import deque
from heapq import heappush, heappop
from time import monotonic as time

__all__ = ['Empty', 'Full', 'Queue', 'PriorityQueue', 'LifoQueue']

class Empty(Exception):
    'Exception raised by Queue.get(block=0)/get_nowait().'
    pass

class Full(Exception):
    'Exception raised by Queue.put(block=0)/put_nowait().'
    pass

class Queue:
    '''Create a queue object with a given maximum size.

    If maxsize is <= 0, the queue size is infinite.
    '''

    def __init__(self, maxsize=0):
        self.maxsize = maxsize
        self._init(maxsize)

        # mutex must be held whenever the queue is mutating.  All methods
        # that acquire mutex must release it before returning.  mutex
        # is shared between the three conditions, so acquiring and
        # releasing the conditions also acquires and releases mutex.
        self.mutex = threading.Lock()

        # Notify not_empty whenever an item is added to the queue; a
        # thread waiting to get is notified then.
        self.not_empty = threading.Condition(self.mutex)

        # Notify not_full whenever an item is removed from the queue;
        # a thread waiting to put is notified then.
        self.not_full = threading.Condition(self.mutex)

        # Notify all_tasks_done whenever the number of unfinished tasks
        # drops to zero; thread waiting to join() is notified to resume
        self.all_tasks_done = threading.Condition(self.mutex)
        self.unfinished_tasks = 0

    def task_done(self):
        '''Indicate that a formerly enqueued task is complete.

        Used by Queue consumer threads.  For each get() used to fetch a task,
        a subsequent call to task_done() tells the queue that the processing
        on the task is complete.

        If a join() is currently blocking, it will resume when all items
        have been processed (meaning that a task_done() call was received
        for every item that had been put() into the queue).

        Raises a ValueError if called more times than there were items
        placed in the queue.
        '''
        with self.all_tasks_done:
            unfinished = self.unfinished_tasks - 1
            if unfinished <= 0:
                if unfinished < 0:
                    raise ValueError('task_done() called too many times')
                self.all_tasks_done.notify_all()
            self.unfinished_tasks = unfinished

    def join(self):
        '''Blocks until all items in the Queue have been gotten and processed.

        The count of unfinished tasks goes up whenever an item is added to the
        queue. The count goes down whenever a consumer thread calls task_done()
        to indicate the item was retrieved and all work on it is complete.

        When the count of unfinished tasks drops to zero, join() unblocks.
        '''
        with self.all_tasks_done:
            while self.unfinished_tasks:
                self.all_tasks_done.wait()

    def qsize(self):
        '''Return the approximate size of the queue (not reliable!).'''
        with self.mutex:
            return self._qsize()

    def empty(self):
        '''Return True if the queue is empty, False otherwise (not reliable!).

        This method is likely to be removed at some point.  Use qsize() == 0
        as a direct substitute, but be aware that either approach risks a race
        condition where a queue can grow before the result of empty() or
        qsize() can be used.

        To create code that needs to wait for all queued tasks to be
        completed, the preferred technique is to use the join() method.
        '''
        with self.mutex:
            return not self._qsize()

    def full(self):
        '''Return True if the queue is full, False otherwise (not reliable!).

        This method is likely to be removed at some point.  Use qsize() >= n
        as a direct substitute, but be aware that either approach risks a race
        condition where a queue can shrink before the result of full() or
        qsize() can be used.
        '''
        with self.mutex:
            return 0 < self.maxsize <= self._qsize()

    def put(self, item, block=True, timeout=None):
        '''Put an item into the queue.

        If optional args 'block' is true and 'timeout' is None (the default),
        block if necessary until a free slot is available. If 'timeout' is
        a non-negative number, it blocks at most 'timeout' seconds and raises
        the Full exception if no free slot was available within that time.
        Otherwise ('block' is false), put an item on the queue if a free slot
        is immediately available, else raise the Full exception ('timeout'
        is ignored in that case).
        '''
        with self.not_full:
            if self.maxsize > 0:
                if not block:
                    if self._qsize() >= self.maxsize:
                        raise Full
                elif timeout is None:
                    while self._qsize() >= self.maxsize:
                        self.not_full.wait()
                elif timeout < 0:
                    raise ValueError("'timeout' must be a non-negative number")
                else:
                    endtime = time() + timeout
                    while self._qsize() >= self.maxsize:
                        remaining = endtime - time()
                        if remaining <= 0.0:
                            raise Full
                        self.not_full.wait(remaining)
            self._put(item)
            self.unfinished_tasks += 1
            self.not_empty.notify()

    def get(self, block=True, timeout=None):
        '''Remove and return an item from the queue.

        If optional args 'block' is true and 'timeout' is None (the default),
        block if necessary until an item is available. If 'timeout' is
        a non-negative number, it blocks at most 'timeout' seconds and raises
        the Empty exception if no item was available within that time.
        Otherwise ('block' is false), return an item if one is immediately
        available, else raise the Empty exception ('timeout' is ignored
        in that case).
        '''
        with self.not_empty:
            if not block:
                if not self._qsize():
                    raise Empty
            elif timeout is None:
                while not self._qsize():
                    self.not_empty.wait()
            elif timeout < 0:
                raise ValueError("'timeout' must be a non-negative number")
            else:
                endtime = time() + timeout
                while not self._qsize():
                    remaining = endtime - time()
                    if remaining <= 0.0:
                        raise Empty
                    self.not_empty.wait(remaining)
            item = self._get()
            self.not_full.notify()
            return item

    def put_nowait(self, item):
        '''Put an item into the queue without blocking.

        Only enqueue the item if a free slot is immediately available.
        Otherwise raise the Full exception.
        '''
        return self.put(item, block=False)

    def get_nowait(self):
        '''Remove and return an item from the queue without blocking.

        Only get an item if one is immediately available. Otherwise
        raise the Empty exception.
        '''
        return self.get(block=False)

    # Override these methods to implement other queue organizations
    # (e.g. stack or priority queue).
    # These will only be called with appropriate locks held

    # Initialize the queue representation
    def _init(self, maxsize):
        self.queue = deque()

    def _qsize(self):
        return len(self.queue)

    # Put a new item in the queue
    def _put(self, item):
        self.queue.append(item)

    # Get an item from the queue
    def _get(self):
        return self.queue.popleft()


class PriorityQueue(Queue):
    '''Variant of Queue that retrieves open entries in priority order (lowest first).

    Entries are typically tuples of the form:  (priority number, data).
    '''

    def _init(self, maxsize):
        self.queue = []

    def _qsize(self):
        return len(self.queue)

    def _put(self, item):
        heappush(self.queue, item)

    def _get(self):
        return heappop(self.queue)


class LifoQueue(Queue):
    '''Variant of Queue that retrieves most recently added entries first.'''

    def _init(self, maxsize):
        self.queue = []

    def _qsize(self):
        return len(self.queue)

    def _put(self, item):
        self.queue.append(item)

    def _get(self):
        return self.queue.pop()

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
asyncio Folder 0755
collections Folder 0755
concurrent Folder 0755
config-3.6m 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
idlelib 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
site-packages Folder 0755
sqlite3 Folder 0755
test Folder 0755
unittest Folder 0755
urllib Folder 0755
venv Folder 0755
wsgiref Folder 0755
xml Folder 0755
xmlrpc Folder 0755
__future__.py File 4.73 KB 0644
__phello__.foo.py File 64 B 0644
_bootlocale.py File 1.27 KB 0644
_collections_abc.py File 25.77 KB 0644
_compat_pickle.py File 8.54 KB 0644
_compression.py File 5.21 KB 0644
_dummy_thread.py File 5 KB 0644
_markupbase.py File 14.26 KB 0644
_osx_support.py File 18.69 KB 0644
_pydecimal.py File 224.83 KB 0644
_pyio.py File 86.03 KB 0644
_sitebuiltins.py File 3.04 KB 0644
_strptime.py File 24.17 KB 0644
_sysconfigdata_dm_linux_x86_64-linux-gnu.py File 27.17 KB 0644
_sysconfigdata_m_linux_x86_64-linux-gnu.py File 25.67 KB 0644
_threading_local.py File 7.04 KB 0644
_weakrefset.py File 5.57 KB 0644
abc.py File 8.52 KB 0644
aifc.py File 31.69 KB 0644
antigravity.py File 477 B 0644
argparse.py File 88.25 KB 0644
ast.py File 11.88 KB 0644
asynchat.py File 11.06 KB 0644
asyncore.py File 19.69 KB 0644
base64.py File 19.91 KB 0755
bdb.py File 23 KB 0644
binhex.py File 13.63 KB 0644
bisect.py File 2.53 KB 0644
bz2.py File 12.19 KB 0644
cProfile.py File 5.26 KB 0755
calendar.py File 22.67 KB 0644
cgi.py File 36.21 KB 0755
cgitb.py File 11.74 KB 0644
chunk.py File 5.3 KB 0644
cmd.py File 14.51 KB 0644
code.py File 10.37 KB 0644
codecs.py File 35.43 KB 0644
codeop.py File 5.85 KB 0644
colorsys.py File 3.97 KB 0644
compileall.py File 11.84 KB 0644
configparser.py File 52.34 KB 0644
contextlib.py File 12.85 KB 0644
copy.py File 8.61 KB 0644
copyreg.py File 6.84 KB 0644
crypt.py File 1.82 KB 0644
csv.py File 15.8 KB 0644
datetime.py File 80.11 KB 0644
decimal.py File 320 B 0644
difflib.py File 82.4 KB 0644
dis.py File 17.71 KB 0644
doctest.py File 101.94 KB 0644
dummy_threading.py File 2.75 KB 0644
enum.py File 32.82 KB 0644
filecmp.py File 9.6 KB 0644
fileinput.py File 14.13 KB 0644
fnmatch.py File 3.09 KB 0644
formatter.py File 14.79 KB 0644
fractions.py File 23.08 KB 0644
ftplib.py File 34.78 KB 0644
functools.py File 30.61 KB 0644
genericpath.py File 4.64 KB 0644
getopt.py File 7.31 KB 0644
getpass.py File 5.85 KB 0644
gettext.py File 21.03 KB 0644
glob.py File 5.51 KB 0644
gzip.py File 19.86 KB 0644
hashlib.py File 9.31 KB 0644
heapq.py File 22.39 KB 0644
hmac.py File 4.94 KB 0644
imaplib.py File 52.05 KB 0644
imghdr.py File 3.71 KB 0644
imp.py File 10.42 KB 0644
inspect.py File 114.22 KB 0644
io.py File 3.43 KB 0644
ipaddress.py File 72.82 KB 0644
keyword.py File 2.17 KB 0755
linecache.py File 5.19 KB 0644
locale.py File 75.49 KB 0644
lzma.py File 12.68 KB 0644
macpath.py File 5.83 KB 0644
macurl2path.py File 2.67 KB 0644
mailbox.py File 76.78 KB 0644
mailcap.py File 7.91 KB 0644
mimetypes.py File 20.55 KB 0644
modulefinder.py File 22.49 KB 0644
netrc.py File 5.55 KB 0644
nntplib.py File 42.07 KB 0644
ntpath.py File 22.55 KB 0644
nturl2path.py File 2.39 KB 0644
numbers.py File 10 KB 0644
opcode.py File 5.69 KB 0644
operator.py File 10.61 KB 0644
optparse.py File 58.96 KB 0644
os.py File 36.65 KB 0644
pathlib.py File 47.83 KB 0644
pdb.py File 59.89 KB 0755
pickle.py File 54.39 KB 0644
pickletools.py File 89.62 KB 0644
pipes.py File 8.71 KB 0644
pkgutil.py File 20.82 KB 0644
platform.py File 46.1 KB 0755
plistlib.py File 32.02 KB 0644
poplib.py File 14.61 KB 0644
posixpath.py File 15.4 KB 0644
pprint.py File 20.37 KB 0644
profile.py File 21.52 KB 0755
pstats.py File 25.94 KB 0644
pty.py File 4.65 KB 0644
py_compile.py File 7.01 KB 0644
pyclbr.py File 13.24 KB 0644
pydoc.py File 101.08 KB 0644
queue.py File 8.57 KB 0644
quopri.py File 7.09 KB 0755
random.py File 26.8 KB 0644
re.py File 15.19 KB 0644
reprlib.py File 5.21 KB 0644
rlcompleter.py File 6.93 KB 0644
runpy.py File 11.68 KB 0644
sched.py File 6.36 KB 0644
secrets.py File 1.99 KB 0644
selectors.py File 18.98 KB 0644
shelve.py File 8.32 KB 0644
shlex.py File 12.65 KB 0644
shutil.py File 39.59 KB 0644
signal.py File 2.07 KB 0644
site.py File 20.53 KB 0644
smtpd.py File 33.91 KB 0755
smtplib.py File 43.38 KB 0755
sndhdr.py File 6.92 KB 0644
socket.py File 26.8 KB 0644
socketserver.py File 26.38 KB 0644
sre_compile.py File 18.88 KB 0644
sre_constants.py File 6.66 KB 0644
sre_parse.py File 35.68 KB 0644
ssl.py File 43.74 KB 0644
stat.py File 4.92 KB 0644
statistics.py File 20.19 KB 0644
string.py File 11.52 KB 0644
stringprep.py File 12.61 KB 0644
struct.py File 257 B 0644
subprocess.py File 60.88 KB 0644
sunau.py File 17.67 KB 0644
symbol.py File 2.07 KB 0755
symtable.py File 7.11 KB 0644
sysconfig.py File 24.4 KB 0644
tabnanny.py File 11.15 KB 0755
tarfile.py File 91.13 KB 0755
telnetlib.py File 22.59 KB 0644
tempfile.py File 26.15 KB 0644
textwrap.py File 19.1 KB 0644
this.py File 1003 B 0644
threading.py File 47.88 KB 0644
timeit.py File 13.03 KB 0755
token.py File 3 KB 0644
tokenize.py File 28.8 KB 0644
trace.py File 28.06 KB 0755
traceback.py File 22.91 KB 0644
tracemalloc.py File 16.27 KB 0644
tty.py File 879 B 0644
types.py File 8.66 KB 0644
typing.py File 78.39 KB 0644
uu.py File 6.75 KB 0755
uuid.py File 23.41 KB 0644
warnings.py File 18.05 KB 0644
wave.py File 17.29 KB 0644
weakref.py File 19.99 KB 0644
webbrowser.py File 21.26 KB 0755
xdrlib.py File 5.77 KB 0644
zipapp.py File 6.99 KB 0644
zipfile.py File 74.49 KB 0644