Unverified Commit a3fdef4e authored by AUTOMATIC1111's avatar AUTOMATIC1111 Committed by GitHub
Browse files

Merge pull request #12707 from AnyISalIn/dev

feat: replace threading.Lock() to FIFOLock
parents dfd6ea3f 71a0f6ef
Loading
Loading
Loading
Loading
+2 −3
Original line number Diff line number Diff line
from functools import wraps
import html
import threading
import time

from modules import shared, progress, errors, devices
from modules import shared, progress, errors, devices, fifo_lock

queue_lock = threading.Lock()
queue_lock = fifo_lock.FIFOLock()


def wrap_queued_call(func):

modules/fifo_lock.py

0 → 100644
+37 −0
Original line number Diff line number Diff line
import threading
import collections


# reference: https://gist.github.com/vitaliyp/6d54dd76ca2c3cdfc1149d33007dc34a
class FIFOLock(object):
    def __init__(self):
        self._lock = threading.Lock()
        self._inner_lock = threading.Lock()
        self._pending_threads = collections.deque()

    def acquire(self, blocking=True):
        with self._inner_lock:
            lock_acquired = self._lock.acquire(False)
            if lock_acquired:
                return True
            elif not blocking:
                return False

            release_event = threading.Event()
            self._pending_threads.append(release_event)

        release_event.wait()
        return self._lock.acquire()

    def release(self):
        with self._inner_lock:
            if self._pending_threads:
                release_event = self._pending_threads.popleft()
                release_event.set()

            self._lock.release()

    __enter__ = acquire

    def __exit__(self, t, v, tb):
        self.release()
+6 −1
Original line number Diff line number Diff line
@@ -72,7 +72,12 @@ def progressapi(req: ProgressRequest):
    completed = req.id_task in finished_tasks

    if not active:
        return ProgressResponse(active=active, queued=queued, completed=completed, id_live_preview=-1, textinfo="In queue..." if queued else "Waiting...")
        textinfo = "Waiting..."
        if queued:
            sorted_queued = sorted(pending_tasks.keys(), key=lambda x: pending_tasks[x])
            queue_index = sorted_queued.index(req.id_task)
            textinfo = "In queue: {}/{}".format(queue_index + 1, len(sorted_queued))
        return ProgressResponse(active=active, queued=queued, completed=completed, id_live_preview=-1, textinfo=textinfo)

    progress = 0