aboutsummaryrefslogtreecommitdiffstats
path: root/modules/shared.py
diff options
context:
space:
mode:
authorAarni Koskela <akx@iki.fi>2023-05-11 20:46:45 +0000
committerAarni Koskela <akx@iki.fi>2023-05-17 07:15:03 +0000
commit85b4f89926f7c3aaa7846dcbb47df3fd3b483b6b (patch)
tree716f033e712fe3eb7fa14bdfb6f8fe51836ae58c /modules/shared.py
parent4b07f2f584596604c4499efb0b0295e96985080f (diff)
downloadstable-diffusion-webui-gfx803-85b4f89926f7c3aaa7846dcbb47df3fd3b483b6b.tar.gz
stable-diffusion-webui-gfx803-85b4f89926f7c3aaa7846dcbb47df3fd3b483b6b.tar.bz2
stable-diffusion-webui-gfx803-85b4f89926f7c3aaa7846dcbb47df3fd3b483b6b.zip
Replace state.need_restart with state.server_command + replace poll loop with signal
Diffstat (limited to 'modules/shared.py')
-rw-r--r--modules/shared.py42
1 files changed, 41 insertions, 1 deletions
diff --git a/modules/shared.py b/modules/shared.py
index 3abf71c0..648a2a19 100644
--- a/modules/shared.py
+++ b/modules/shared.py
@@ -2,6 +2,7 @@ import datetime
import json
import os
import sys
+import threading
import time
import gradio as gr
@@ -110,8 +111,47 @@ class State:
id_live_preview = 0
textinfo = None
time_start = None
- need_restart = False
server_start = None
+ _server_command_signal = threading.Event()
+ _server_command: str | None = None
+
+ @property
+ def need_restart(self) -> bool:
+ # Compatibility getter for need_restart.
+ return self.server_command == "restart"
+
+ @need_restart.setter
+ def need_restart(self, value: bool) -> None:
+ # Compatibility setter for need_restart.
+ if value:
+ self.server_command = "restart"
+
+ @property
+ def server_command(self):
+ return self._server_command
+
+ @server_command.setter
+ def server_command(self, value: str | None) -> None:
+ """
+ Set the server command to `value` and signal that it's been set.
+ """
+ self._server_command = value
+ self._server_command_signal.set()
+
+ def wait_for_server_command(self, timeout: float | None = None) -> str | None:
+ """
+ Wait for server command to get set; return and clear the value and signal.
+ """
+ if self._server_command_signal.wait(timeout):
+ self._server_command_signal.clear()
+ req = self._server_command
+ self._server_command = None
+ return req
+ return None
+
+ def request_restart(self) -> None:
+ self.interrupt()
+ self.server_command = True
def skip(self):
self.skipped = True