do not stop execution when script's callback misbehaves and report which script it was
This commit is contained in:
parent
b383702752
commit
77a320f406
1 changed files with 36 additions and 9 deletions
|
@ -1,4 +1,15 @@
|
||||||
|
import sys
|
||||||
|
import traceback
|
||||||
|
from collections import namedtuple
|
||||||
|
import inspect
|
||||||
|
|
||||||
|
|
||||||
|
def report_exception(c, job):
|
||||||
|
print(f"Error executing callback {job} for {c.script}", file=sys.stderr)
|
||||||
|
print(traceback.format_exc(), file=sys.stderr)
|
||||||
|
|
||||||
|
|
||||||
|
ScriptCallback = namedtuple("ScriptCallback", ["script", "callback"])
|
||||||
callbacks_model_loaded = []
|
callbacks_model_loaded = []
|
||||||
callbacks_ui_tabs = []
|
callbacks_ui_tabs = []
|
||||||
callbacks_ui_settings = []
|
callbacks_ui_settings = []
|
||||||
|
@ -10,28 +21,44 @@ def clear_callbacks():
|
||||||
|
|
||||||
|
|
||||||
def model_loaded_callback(sd_model):
|
def model_loaded_callback(sd_model):
|
||||||
for callback in callbacks_model_loaded:
|
for c in callbacks_model_loaded:
|
||||||
callback(sd_model)
|
try:
|
||||||
|
c.callback(sd_model)
|
||||||
|
except Exception:
|
||||||
|
report_exception(c, 'model_loaded_callback')
|
||||||
|
|
||||||
|
|
||||||
def ui_tabs_callback():
|
def ui_tabs_callback():
|
||||||
res = []
|
res = []
|
||||||
|
|
||||||
for callback in callbacks_ui_tabs:
|
for c in callbacks_ui_tabs:
|
||||||
res += callback() or []
|
try:
|
||||||
|
res += c.callback() or []
|
||||||
|
except Exception:
|
||||||
|
report_exception(c, 'ui_tabs_callback')
|
||||||
|
|
||||||
return res
|
return res
|
||||||
|
|
||||||
|
|
||||||
def ui_settings_callback():
|
def ui_settings_callback():
|
||||||
for callback in callbacks_ui_settings:
|
for c in callbacks_ui_settings:
|
||||||
callback()
|
try:
|
||||||
|
c.callback()
|
||||||
|
except Exception:
|
||||||
|
report_exception(c, 'ui_settings_callback')
|
||||||
|
|
||||||
|
|
||||||
|
def add_callback(callbacks, fun):
|
||||||
|
stack = [x for x in inspect.stack() if x.filename != __file__]
|
||||||
|
filename = stack[0].filename if len(stack) > 0 else 'unknown file'
|
||||||
|
|
||||||
|
callbacks.append(ScriptCallback(filename, fun))
|
||||||
|
|
||||||
|
|
||||||
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"""
|
||||||
callbacks_model_loaded.append(callback)
|
add_callback(callbacks_model_loaded, callback)
|
||||||
|
|
||||||
|
|
||||||
def on_ui_tabs(callback):
|
def on_ui_tabs(callback):
|
||||||
|
@ -44,10 +71,10 @@ 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
|
||||||
"""
|
"""
|
||||||
callbacks_ui_tabs.append(callback)
|
add_callback(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(...)) """
|
||||||
callbacks_ui_settings.append(callback)
|
add_callback(callbacks_ui_settings, callback)
|
||||||
|
|
Loading…
Reference in a new issue