mirror of
https://github.com/AUTOMATIC1111/stable-diffusion-webui.git
synced 2024-06-07 21:20:49 +00:00
Merge pull request #4179 from AUTOMATIC1111/callback-structure
Convert callbacks into a private map, add utility functions
This commit is contained in:
commit
8eb0a97278
@ -46,25 +46,23 @@ class CFGDenoiserParams:
|
|||||||
|
|
||||||
|
|
||||||
ScriptCallback = namedtuple("ScriptCallback", ["script", "callback"])
|
ScriptCallback = namedtuple("ScriptCallback", ["script", "callback"])
|
||||||
callbacks_app_started = []
|
callback_map = dict(
|
||||||
callbacks_model_loaded = []
|
callbacks_app_started=[],
|
||||||
callbacks_ui_tabs = []
|
callbacks_model_loaded=[],
|
||||||
callbacks_ui_settings = []
|
callbacks_ui_tabs=[],
|
||||||
callbacks_before_image_saved = []
|
callbacks_ui_settings=[],
|
||||||
callbacks_image_saved = []
|
callbacks_before_image_saved=[],
|
||||||
|
callbacks_image_saved=[],
|
||||||
callbacks_cfg_denoiser=[]
|
callbacks_cfg_denoiser=[]
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
def clear_callbacks():
|
def clear_callbacks():
|
||||||
callbacks_model_loaded.clear()
|
for callback_list in callback_map.values():
|
||||||
callbacks_ui_tabs.clear()
|
callback_list.clear()
|
||||||
callbacks_ui_settings.clear()
|
|
||||||
callbacks_before_image_saved.clear()
|
|
||||||
callbacks_image_saved.clear()
|
|
||||||
callbacks_cfg_denoiser.clear()
|
|
||||||
|
|
||||||
def app_started_callback(demo: Optional[Blocks], app: FastAPI):
|
def app_started_callback(demo: Optional[Blocks], app: FastAPI):
|
||||||
for c in callbacks_app_started:
|
for c in callback_map['callbacks_app_started']:
|
||||||
try:
|
try:
|
||||||
c.callback(demo, app)
|
c.callback(demo, app)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -72,7 +70,7 @@ def app_started_callback(demo: Optional[Blocks], app: FastAPI):
|
|||||||
|
|
||||||
|
|
||||||
def model_loaded_callback(sd_model):
|
def model_loaded_callback(sd_model):
|
||||||
for c in callbacks_model_loaded:
|
for c in callback_map['callbacks_model_loaded']:
|
||||||
try:
|
try:
|
||||||
c.callback(sd_model)
|
c.callback(sd_model)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -82,7 +80,7 @@ def model_loaded_callback(sd_model):
|
|||||||
def ui_tabs_callback():
|
def ui_tabs_callback():
|
||||||
res = []
|
res = []
|
||||||
|
|
||||||
for c in callbacks_ui_tabs:
|
for c in callback_map['callbacks_ui_tabs']:
|
||||||
try:
|
try:
|
||||||
res += c.callback() or []
|
res += c.callback() or []
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -92,7 +90,7 @@ def ui_tabs_callback():
|
|||||||
|
|
||||||
|
|
||||||
def ui_settings_callback():
|
def ui_settings_callback():
|
||||||
for c in callbacks_ui_settings:
|
for c in callback_map['callbacks_ui_settings']:
|
||||||
try:
|
try:
|
||||||
c.callback()
|
c.callback()
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -100,7 +98,7 @@ def ui_settings_callback():
|
|||||||
|
|
||||||
|
|
||||||
def before_image_saved_callback(params: ImageSaveParams):
|
def before_image_saved_callback(params: ImageSaveParams):
|
||||||
for c in callbacks_before_image_saved:
|
for c in callback_map['callbacks_before_image_saved']:
|
||||||
try:
|
try:
|
||||||
c.callback(params)
|
c.callback(params)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -108,7 +106,7 @@ def before_image_saved_callback(params: ImageSaveParams):
|
|||||||
|
|
||||||
|
|
||||||
def image_saved_callback(params: ImageSaveParams):
|
def image_saved_callback(params: ImageSaveParams):
|
||||||
for c in callbacks_image_saved:
|
for c in callback_map['callbacks_image_saved']:
|
||||||
try:
|
try:
|
||||||
c.callback(params)
|
c.callback(params)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -116,7 +114,7 @@ def image_saved_callback(params: ImageSaveParams):
|
|||||||
|
|
||||||
|
|
||||||
def cfg_denoiser_callback(params: CFGDenoiserParams):
|
def cfg_denoiser_callback(params: CFGDenoiserParams):
|
||||||
for c in callbacks_cfg_denoiser:
|
for c in callback_map['callbacks_cfg_denoiser']:
|
||||||
try:
|
try:
|
||||||
c.callback(params)
|
c.callback(params)
|
||||||
except Exception:
|
except Exception:
|
||||||
@ -130,16 +128,32 @@ def add_callback(callbacks, fun):
|
|||||||
callbacks.append(ScriptCallback(filename, fun))
|
callbacks.append(ScriptCallback(filename, fun))
|
||||||
|
|
||||||
|
|
||||||
|
def remove_current_script_callbacks():
|
||||||
|
stack = [x for x in inspect.stack() if x.filename != __file__]
|
||||||
|
filename = stack[0].filename if len(stack) > 0 else 'unknown file'
|
||||||
|
if filename == 'unknown file':
|
||||||
|
return
|
||||||
|
for callback_list in callback_map.values():
|
||||||
|
for callback_to_remove in [cb for cb in callback_list if cb.script == filename]:
|
||||||
|
callback_list.remove(callback_to_remove)
|
||||||
|
|
||||||
|
|
||||||
|
def remove_callbacks_for_function(callback_func):
|
||||||
|
for callback_list in callback_map.values():
|
||||||
|
for callback_to_remove in [cb for cb in callback_list if cb.callback == callback_func]:
|
||||||
|
callback_list.remove(callback_to_remove)
|
||||||
|
|
||||||
|
|
||||||
def on_app_started(callback):
|
def on_app_started(callback):
|
||||||
"""register a function to be called when the webui started, the gradio `Block` component and
|
"""register a function to be called when the webui started, the gradio `Block` component and
|
||||||
fastapi `FastAPI` object are passed as the arguments"""
|
fastapi `FastAPI` object are passed as the arguments"""
|
||||||
add_callback(callbacks_app_started, callback)
|
add_callback(callback_map['callbacks_app_started'], 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
|
||||||
passed as an argument"""
|
passed as an argument"""
|
||||||
add_callback(callbacks_model_loaded, callback)
|
add_callback(callback_map['callbacks_model_loaded'], callback)
|
||||||
|
|
||||||
|
|
||||||
def on_ui_tabs(callback):
|
def on_ui_tabs(callback):
|
||||||
@ -152,13 +166,13 @@ def on_ui_tabs(callback):
|
|||||||
title is tab text displayed to user in the UI
|
title is tab text displayed to user in the UI
|
||||||
elem_id is HTML id for the tab
|
elem_id is HTML id for the tab
|
||||||
"""
|
"""
|
||||||
add_callback(callbacks_ui_tabs, callback)
|
add_callback(callback_map['callbacks_ui_tabs'], callback)
|
||||||
|
|
||||||
|
|
||||||
def on_ui_settings(callback):
|
def on_ui_settings(callback):
|
||||||
"""register a function to be called before UI settings are populated; add your settings
|
"""register a function to be called before UI settings are populated; add your settings
|
||||||
by using shared.opts.add_option(shared.OptionInfo(...)) """
|
by using shared.opts.add_option(shared.OptionInfo(...)) """
|
||||||
add_callback(callbacks_ui_settings, callback)
|
add_callback(callback_map['callbacks_ui_settings'], callback)
|
||||||
|
|
||||||
|
|
||||||
def on_before_image_saved(callback):
|
def on_before_image_saved(callback):
|
||||||
@ -166,7 +180,7 @@ def on_before_image_saved(callback):
|
|||||||
The callback is called with one argument:
|
The callback is called with one argument:
|
||||||
- params: ImageSaveParams - parameters the image is to be saved with. You can change fields in this object.
|
- params: ImageSaveParams - parameters the image is to be saved with. You can change fields in this object.
|
||||||
"""
|
"""
|
||||||
add_callback(callbacks_before_image_saved, callback)
|
add_callback(callback_map['callbacks_before_image_saved'], callback)
|
||||||
|
|
||||||
|
|
||||||
def on_image_saved(callback):
|
def on_image_saved(callback):
|
||||||
@ -174,7 +188,7 @@ def on_image_saved(callback):
|
|||||||
The callback is called with one argument:
|
The callback is called with one argument:
|
||||||
- params: ImageSaveParams - parameters the image was saved with. Changing fields in this object does nothing.
|
- params: ImageSaveParams - parameters the image was saved with. Changing fields in this object does nothing.
|
||||||
"""
|
"""
|
||||||
add_callback(callbacks_image_saved, callback)
|
add_callback(callback_map['callbacks_image_saved'], callback)
|
||||||
|
|
||||||
|
|
||||||
def on_cfg_denoiser(callback):
|
def on_cfg_denoiser(callback):
|
||||||
@ -182,5 +196,4 @@ def on_cfg_denoiser(callback):
|
|||||||
The callback is called with one argument:
|
The callback is called with one argument:
|
||||||
- params: CFGDenoiserParams - parameters to be passed to the inner model and sampling state details.
|
- params: CFGDenoiserParams - parameters to be passed to the inner model and sampling state details.
|
||||||
"""
|
"""
|
||||||
add_callback(callbacks_cfg_denoiser, callback)
|
add_callback(callback_map['callbacks_cfg_denoiser'], callback)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user