diff --git a/StabilityMatrix.Core/Models/Packages/FluxGym.cs b/StabilityMatrix.Core/Models/Packages/FluxGym.cs index aa1771f1..59bc34cf 100644 --- a/StabilityMatrix.Core/Models/Packages/FluxGym.cs +++ b/StabilityMatrix.Core/Models/Packages/FluxGym.cs @@ -85,14 +85,24 @@ public override async Task InstallPackage( CancellationToken cancellationToken = default ) { - progress?.Report(new ProgressReport(-1f, "Cloning sd-scripts", isIndeterminate: true)); - await prerequisiteHelper - .RunGit( - ["clone", "-b", "sd3", "https://github.com/kohya-ss/sd-scripts"], - onConsoleOutput, - installLocation - ) - .ConfigureAwait(false); + progress?.Report(new ProgressReport(-1f, "Cloning / updating sd-scripts", isIndeterminate: true)); + // check if sd-scripts is already installed - if so: pull, else: clone + if (Directory.Exists(Path.Combine(installLocation, "sd-scripts"))) + { + await prerequisiteHelper + .RunGit(["pull"], onConsoleOutput, Path.Combine(installLocation, "sd-scripts")) + .ConfigureAwait(false); + } + else + { + await prerequisiteHelper + .RunGit( + ["clone", "-b", "sd3", "https://github.com/kohya-ss/sd-scripts"], + onConsoleOutput, + installLocation + ) + .ConfigureAwait(false); + } progress?.Report(new ProgressReport(-1f, "Setting up venv", isIndeterminate: true)); await using var venvRunner = await SetupVenvPure(installLocation).ConfigureAwait(false);