2023-03-24 16:51:27 -03:00
|
|
|
import traceback
|
|
|
|
|
2023-03-15 15:11:16 -03:00
|
|
|
import gradio as gr
|
|
|
|
|
2023-02-23 12:05:25 -03:00
|
|
|
import extensions
|
2023-02-23 14:41:42 -03:00
|
|
|
import modules.shared as shared
|
2023-02-23 12:05:25 -03:00
|
|
|
|
2023-02-24 10:01:21 -03:00
|
|
|
state = {}
|
2023-02-23 12:05:25 -03:00
|
|
|
available_extensions = []
|
2023-03-28 23:27:02 -03:00
|
|
|
setup_called = set()
|
2023-02-23 12:05:25 -03:00
|
|
|
|
2023-04-07 00:15:45 -03:00
|
|
|
|
2023-02-23 14:49:02 -03:00
|
|
|
def load_extensions():
|
2023-04-07 12:20:57 -03:00
|
|
|
global state, setup_called
|
2023-02-24 10:01:21 -03:00
|
|
|
for i, name in enumerate(shared.args.extensions):
|
|
|
|
if name in available_extensions:
|
|
|
|
print(f'Loading the extension "{name}"... ', end='')
|
2023-03-15 23:29:56 -03:00
|
|
|
try:
|
|
|
|
exec(f"import extensions.{name}.script")
|
2023-04-07 12:20:57 -03:00
|
|
|
extension = eval(f"extensions.{name}.script")
|
|
|
|
if extension not in setup_called and hasattr(extension, "setup"):
|
|
|
|
setup_called.add(extension)
|
|
|
|
extension.setup()
|
2023-03-15 23:29:56 -03:00
|
|
|
state[name] = [True, i]
|
|
|
|
print('Ok.')
|
|
|
|
except:
|
|
|
|
print('Fail.')
|
2023-03-24 16:51:27 -03:00
|
|
|
traceback.print_exc()
|
2023-02-23 14:49:02 -03:00
|
|
|
|
2023-04-07 00:15:45 -03:00
|
|
|
|
2023-04-07 12:20:57 -03:00
|
|
|
# This iterator returns the extensions in the order specified in the command-line
|
2023-02-24 10:01:21 -03:00
|
|
|
def iterator():
|
2023-04-07 00:15:45 -03:00
|
|
|
for name in sorted(state, key=lambda x: state[x][1]):
|
2023-04-07 00:52:02 -03:00
|
|
|
if state[name][0]:
|
2023-02-24 10:01:21 -03:00
|
|
|
yield eval(f"extensions.{name}.script"), name
|
|
|
|
|
2023-04-07 00:15:45 -03:00
|
|
|
|
2023-04-07 12:20:57 -03:00
|
|
|
# Extension functions that map string -> string
|
2023-02-23 12:05:25 -03:00
|
|
|
def apply_extensions(text, typ):
|
2023-02-24 10:01:21 -03:00
|
|
|
for extension, _ in iterator():
|
|
|
|
if typ == "input" and hasattr(extension, "input_modifier"):
|
|
|
|
text = extension.input_modifier(text)
|
|
|
|
elif typ == "output" and hasattr(extension, "output_modifier"):
|
|
|
|
text = extension.output_modifier(text)
|
|
|
|
elif typ == "bot_prefix" and hasattr(extension, "bot_prefix_modifier"):
|
|
|
|
text = extension.bot_prefix_modifier(text)
|
2023-02-23 12:05:25 -03:00
|
|
|
return text
|
|
|
|
|
2023-04-07 00:15:45 -03:00
|
|
|
|
2023-02-23 14:55:21 -03:00
|
|
|
def create_extensions_block():
|
2023-03-19 13:25:49 +00:00
|
|
|
global setup_called
|
2023-03-24 16:51:27 -03:00
|
|
|
|
2023-02-24 19:00:11 -03:00
|
|
|
# Updating the default values
|
2023-02-24 10:01:21 -03:00
|
|
|
for extension, name in iterator():
|
2023-02-25 03:00:19 -03:00
|
|
|
if hasattr(extension, 'params'):
|
|
|
|
for param in extension.params:
|
|
|
|
_id = f"{name}-{param}"
|
|
|
|
if _id in shared.settings:
|
|
|
|
extension.params[param] = shared.settings[_id]
|
2023-02-23 14:55:21 -03:00
|
|
|
|
2023-03-19 13:31:21 +00:00
|
|
|
should_display_ui = False
|
2023-03-28 23:27:02 -03:00
|
|
|
for extension, name in iterator():
|
|
|
|
if hasattr(extension, "ui"):
|
|
|
|
should_display_ui = True
|
2023-03-19 13:22:24 +00:00
|
|
|
|
2023-02-24 19:00:11 -03:00
|
|
|
# Creating the extension ui elements
|
2023-03-19 13:31:21 +00:00
|
|
|
if should_display_ui:
|
2023-03-26 22:20:30 -03:00
|
|
|
with gr.Column(elem_id="extensions"):
|
2023-03-15 23:29:56 -03:00
|
|
|
for extension, name in iterator():
|
2023-03-26 22:20:30 -03:00
|
|
|
gr.Markdown(f"\n### {name}")
|
2023-03-15 23:29:56 -03:00
|
|
|
if hasattr(extension, "ui"):
|
|
|
|
extension.ui()
|