diff options
author | AUTOMATIC1111 <16777216c@gmail.com> | 2023-04-29 13:10:16 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-29 13:10:16 +0000 |
commit | 725a3849d2761d40808899e9b1bcf594dd33109d (patch) | |
tree | 657962e52bbc50e3bd51ea292e616c2372501d58 /modules/ui_extensions.py | |
parent | c84118d70d7c3dd2f741f9e89b9a8a4643f27f98 (diff) | |
parent | 8863b31d83b527d041ca45e23b9af99e2346081a (diff) | |
download | stable-diffusion-webui-gfx803-725a3849d2761d40808899e9b1bcf594dd33109d.tar.gz stable-diffusion-webui-gfx803-725a3849d2761d40808899e9b1bcf594dd33109d.tar.bz2 stable-diffusion-webui-gfx803-725a3849d2761d40808899e9b1bcf594dd33109d.zip |
Merge branch 'dev' into pr/xyz-sort-001
Diffstat (limited to 'modules/ui_extensions.py')
-rw-r--r-- | modules/ui_extensions.py | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/modules/ui_extensions.py b/modules/ui_extensions.py index efd6cda2..e90bedc8 100644 --- a/modules/ui_extensions.py +++ b/modules/ui_extensions.py @@ -129,7 +129,7 @@ def normalize_git_url(url): return url
-def install_extension_from_url(dirname, url):
+def install_extension_from_url(dirname, url, branch_name=None):
check_access()
assert url, 'No URL specified'
@@ -150,10 +150,17 @@ def install_extension_from_url(dirname, url): try:
shutil.rmtree(tmpdir, True)
- with git.Repo.clone_from(url, tmpdir) as repo:
- repo.remote().fetch()
- for submodule in repo.submodules:
- submodule.update()
+ if not branch_name:
+ # if no branch is specified, use the default branch
+ with git.Repo.clone_from(url, tmpdir) as repo:
+ repo.remote().fetch()
+ for submodule in repo.submodules:
+ submodule.update()
+ else:
+ with git.Repo.clone_from(url, tmpdir, branch=branch_name) as repo:
+ repo.remote().fetch()
+ for submodule in repo.submodules:
+ submodule.update()
try:
os.rename(tmpdir, target_dir)
except OSError as err:
@@ -376,13 +383,14 @@ def create_ui(): with gr.TabItem("Install from URL"):
install_url = gr.Text(label="URL for extension's git repository")
+ install_branch = gr.Text(label="Specific branch name", placeholder="Leave empty for default main branch")
install_dirname = gr.Text(label="Local directory name", placeholder="Leave empty for auto")
install_button = gr.Button(value="Install", variant="primary")
install_result = gr.HTML(elem_id="extension_install_result")
install_button.click(
fn=modules.ui.wrap_gradio_call(install_extension_from_url, extra_outputs=[gr.update()]),
- inputs=[install_dirname, install_url],
+ inputs=[install_dirname, install_url, install_branch],
outputs=[extensions_table, install_result],
)
|