Commit eb5eb8aa authored by rucadi's avatar rucadi

Add a callback called before reloading the server

parent 3662a274
...@@ -75,6 +75,7 @@ callback_map = dict( ...@@ -75,6 +75,7 @@ callback_map = dict(
callbacks_script_unloaded=[], callbacks_script_unloaded=[],
callbacks_before_ui=[], callbacks_before_ui=[],
callbacks_on_polling=[], callbacks_on_polling=[],
callbacks_on_reload=[],
) )
...@@ -82,7 +83,6 @@ def clear_callbacks(): ...@@ -82,7 +83,6 @@ def clear_callbacks():
for callback_list in callback_map.values(): for callback_list in callback_map.values():
callback_list.clear() callback_list.clear()
def app_started_callback(demo: Optional[Blocks], app: FastAPI): def app_started_callback(demo: Optional[Blocks], app: FastAPI):
for c in callback_map['callbacks_app_started']: for c in callback_map['callbacks_app_started']:
try: try:
...@@ -97,6 +97,14 @@ def app_polling_callback(demo: Optional[Blocks], app: FastAPI): ...@@ -97,6 +97,14 @@ def app_polling_callback(demo: Optional[Blocks], app: FastAPI):
except Exception: except Exception:
report_exception(c, 'callbacks_on_polling') report_exception(c, 'callbacks_on_polling')
def app_reload_callback(demo: Optional[Blocks], app: FastAPI):
for c in callback_map['callbacks_on_reload']:
try:
c.callback()
except Exception:
report_exception(c, 'callbacks_on_reload')
def model_loaded_callback(sd_model): def model_loaded_callback(sd_model):
for c in callback_map['callbacks_model_loaded']: for c in callback_map['callbacks_model_loaded']:
try: try:
...@@ -238,6 +246,9 @@ def on_polling(callback): ...@@ -238,6 +246,9 @@ def on_polling(callback):
"""register a function to be called on each polling of the server.""" """register a function to be called on each polling of the server."""
add_callback(callback_map['callbacks_on_polling'], callback) add_callback(callback_map['callbacks_on_polling'], callback)
def on_before_reload(callback):
"""register a function to be called just before the server reloads."""
add_callback(callback_map['callbacks_on_reload'], callback)
def on_model_loaded(callback): def on_model_loaded(callback):
"""register a function to be called when the stable diffusion model is created; the model is """register a function to be called when the stable diffusion model is created; the model is
......
...@@ -173,6 +173,7 @@ def wait_on_server(demo=None): ...@@ -173,6 +173,7 @@ def wait_on_server(demo=None):
time.sleep(0.5) time.sleep(0.5)
modules.script_callbacks.app_polling_callback(None, demo) modules.script_callbacks.app_polling_callback(None, demo)
if shared.state.need_restart: if shared.state.need_restart:
modules.script_callbacks.app_reload_callback(None, demo)
shared.state.need_restart = False shared.state.need_restart = False
time.sleep(0.5) time.sleep(0.5)
demo.close() demo.close()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment