|
import traceback |
|
from functools import partial |
|
|
|
import gradio as gr |
|
|
|
import extensions |
|
import modules.shared as shared |
|
from modules.logging_colors import logger |
|
from inspect import signature |
|
|
|
|
|
state = {} |
|
available_extensions = [] |
|
setup_called = set() |
|
|
|
|
|
def apply_settings(extension, name): |
|
if not hasattr(extension, 'params'): |
|
return |
|
|
|
for param in extension.params: |
|
_id = f"{name}-{param}" |
|
if _id not in shared.settings: |
|
continue |
|
|
|
extension.params[param] = shared.settings[_id] |
|
|
|
|
|
def load_extensions(): |
|
global state, setup_called |
|
for i, name in enumerate(shared.args.extensions): |
|
if name in available_extensions: |
|
if name != 'api': |
|
logger.info(f'Loading the extension "{name}"...') |
|
try: |
|
exec(f"import extensions.{name}.script") |
|
extension = getattr(extensions, name).script |
|
apply_settings(extension, name) |
|
if extension not in setup_called and hasattr(extension, "setup"): |
|
setup_called.add(extension) |
|
extension.setup() |
|
|
|
state[name] = [True, i] |
|
except: |
|
logger.error(f'Failed to load the extension "{name}".') |
|
traceback.print_exc() |
|
|
|
|
|
|
|
def iterator(): |
|
for name in sorted(state, key=lambda x: state[x][1]): |
|
if state[name][0]: |
|
yield getattr(extensions, name).script, name |
|
|
|
|
|
|
|
def _apply_string_extensions(function_name, text, state): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, function_name): |
|
func = getattr(extension, function_name) |
|
if len(signature(func).parameters) == 2: |
|
text = func(text, state) |
|
else: |
|
text = func(text) |
|
|
|
return text |
|
|
|
|
|
|
|
def _apply_input_hijack(text, visible_text): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'input_hijack') and extension.input_hijack['state']: |
|
extension.input_hijack['state'] = False |
|
if callable(extension.input_hijack['value']): |
|
text, visible_text = extension.input_hijack['value'](text, visible_text) |
|
else: |
|
text, visible_text = extension.input_hijack['value'] |
|
|
|
return text, visible_text |
|
|
|
|
|
|
|
def _apply_custom_generate_chat_prompt(text, state, **kwargs): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'custom_generate_chat_prompt'): |
|
return extension.custom_generate_chat_prompt(text, state, **kwargs) |
|
|
|
return None |
|
|
|
|
|
|
|
def _apply_state_modifier_extensions(state): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, "state_modifier"): |
|
state = getattr(extension, "state_modifier")(state) |
|
|
|
return state |
|
|
|
|
|
|
|
def _apply_history_modifier_extensions(history): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, "history_modifier"): |
|
history = getattr(extension, "history_modifier")(history) |
|
|
|
return history |
|
|
|
|
|
|
|
def _apply_tokenizer_extensions(function_name, state, prompt, input_ids, input_embeds): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, function_name): |
|
prompt, input_ids, input_embeds = getattr(extension, function_name)(state, prompt, input_ids, input_embeds) |
|
|
|
return prompt, input_ids, input_embeds |
|
|
|
|
|
|
|
|
|
def _apply_logits_processor_extensions(function_name, processor_list, input_ids): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, function_name): |
|
getattr(extension, function_name)(processor_list, input_ids) |
|
|
|
|
|
|
|
|
|
def _apply_custom_tokenized_length(prompt): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'custom_tokenized_length'): |
|
return getattr(extension, 'custom_tokenized_length')(prompt) |
|
|
|
return None |
|
|
|
|
|
|
|
def _apply_custom_generate_reply(): |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'custom_generate_reply'): |
|
return getattr(extension, 'custom_generate_reply') |
|
|
|
return None |
|
|
|
|
|
def _apply_custom_css(): |
|
all_css = '' |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'custom_css'): |
|
all_css += getattr(extension, 'custom_css')() |
|
|
|
return all_css |
|
|
|
|
|
def _apply_custom_js(): |
|
all_js = '' |
|
for extension, _ in iterator(): |
|
if hasattr(extension, 'custom_js'): |
|
all_js += getattr(extension, 'custom_js')() |
|
|
|
return all_js |
|
|
|
|
|
def create_extensions_block(): |
|
to_display = [] |
|
for extension, name in iterator(): |
|
if hasattr(extension, "ui") and not (hasattr(extension, 'params') and extension.params.get('is_tab', False)): |
|
to_display.append((extension, name)) |
|
|
|
|
|
if len(to_display) > 0: |
|
with gr.Column(elem_id="extensions"): |
|
for row in to_display: |
|
extension, name = row |
|
display_name = getattr(extension, 'params', {}).get('display_name', name) |
|
gr.Markdown(f"\n### {display_name}") |
|
extension.ui() |
|
|
|
|
|
def create_extensions_tabs(): |
|
for extension, name in iterator(): |
|
if hasattr(extension, "ui") and (hasattr(extension, 'params') and extension.params.get('is_tab', False)): |
|
display_name = getattr(extension, 'params', {}).get('display_name', name) |
|
with gr.Tab(display_name, elem_classes="extension-tab"): |
|
extension.ui() |
|
|
|
|
|
EXTENSION_MAP = { |
|
"input": partial(_apply_string_extensions, "input_modifier"), |
|
"output": partial(_apply_string_extensions, "output_modifier"), |
|
"state": _apply_state_modifier_extensions, |
|
"history": _apply_history_modifier_extensions, |
|
"bot_prefix": partial(_apply_string_extensions, "bot_prefix_modifier"), |
|
"tokenizer": partial(_apply_tokenizer_extensions, "tokenizer_modifier"), |
|
'logits_processor': partial(_apply_logits_processor_extensions, 'logits_processor_modifier'), |
|
"input_hijack": _apply_input_hijack, |
|
"custom_generate_chat_prompt": _apply_custom_generate_chat_prompt, |
|
"custom_generate_reply": _apply_custom_generate_reply, |
|
"tokenized_length": _apply_custom_tokenized_length, |
|
"css": _apply_custom_css, |
|
"js": _apply_custom_js |
|
} |
|
|
|
|
|
def apply_extensions(typ, *args, **kwargs): |
|
if typ not in EXTENSION_MAP: |
|
raise ValueError(f"Invalid extension type {typ}") |
|
|
|
return EXTENSION_MAP[typ](*args, **kwargs) |
|
|