diff options
author | AUTOMATIC1111 <16777216c@gmail.com> | 2023-04-29 14:04:37 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-29 14:04:37 +0000 |
commit | ce64cab39761a593f15b30cf75eabb9432f16fc0 (patch) | |
tree | b4c6bbfa455c5700b4edf886272341ac05634490 /modules/ui_extensions.py | |
parent | d537a1f1b62de7795a77feb71b4c990389c30087 (diff) | |
parent | c89cad2b9ac1ed1ec378a559ce5adda82fadc38b (diff) | |
download | stable-diffusion-webui-gfx803-ce64cab39761a593f15b30cf75eabb9432f16fc0.tar.gz stable-diffusion-webui-gfx803-ce64cab39761a593f15b30cf75eabb9432f16fc0.tar.bz2 stable-diffusion-webui-gfx803-ce64cab39761a593f15b30cf75eabb9432f16fc0.zip |
Merge branch 'dev' into patch-1
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],
)
|