From 10bf901fd4f727587b097a412e3b55a206236ce7 Mon Sep 17 00:00:00 2001 From: pointfeev Date: Tue, 30 Nov 2021 12:08:59 -0500 Subject: [PATCH] improve validation --- CreamInstaller/Forms/SelectForm.cs | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/CreamInstaller/Forms/SelectForm.cs b/CreamInstaller/Forms/SelectForm.cs index 689da1a..699d5a8 100644 --- a/CreamInstaller/Forms/SelectForm.cs +++ b/CreamInstaller/Forms/SelectForm.cs @@ -235,7 +235,7 @@ namespace CreamInstaller progress.Report(RunningTasks.Count); } - private async void OnLoad() + private async void OnLoad(bool validating = false) { Program.Canceled = false; cancelButton.Enabled = true; @@ -260,7 +260,8 @@ namespace CreamInstaller if (_progress < 0) maxProgress = -_progress; else curProgress = _progress; int p = Math.Max(Math.Min((int)((float)(curProgress / (float)maxProgress) * 100), 100), 0); - if (setup) label2.Text = $"Setting up SteamCMD . . . {p}% ({curProgress}/{maxProgress})"; + if (validating) label2.Text = $"Validating . . . {p}% ({curProgress}/{maxProgress})"; + else if (setup) label2.Text = $"Setting up SteamCMD . . . {p}% ({curProgress}/{maxProgress})"; else label2.Text = $"Gathering and caching your applicable games and their DLCs . . . {p}% ({curProgress}/{maxProgress})"; progressBar1.Value = p; }; @@ -268,7 +269,7 @@ namespace CreamInstaller iProgress.Report(-1660); // not exact, number varies int cur = 0; iProgress.Report(cur); - label2.Text = "Setting up SteamCMD . . . "; + if (!validating) label2.Text = "Setting up SteamCMD . . . "; if (!Directory.Exists(SteamCMD.DirectoryPath)) Directory.CreateDirectory(SteamCMD.DirectoryPath); FileSystemWatcher watcher = new(SteamCMD.DirectoryPath); watcher.Changed += (sender, e) => iProgress.Report(++cur); @@ -279,7 +280,7 @@ namespace CreamInstaller watcher.Dispose(); setup = false; - label2.Text = "Gathering and caching your applicable games and their DLCs . . . "; + if (!validating) label2.Text = "Gathering and caching your applicable games and their DLCs . . . "; await Task.Run(() => GetCreamApiApplicablePrograms(iProgress)); ProgramSelection.All.ForEach(selection => selection.SteamApiDllDirectories.RemoveAll(directory => !Directory.Exists(directory))); ProgramSelection.All.RemoveAll(selection => !Directory.Exists(selection.RootDirectory) || !selection.SteamApiDllDirectories.Any()); @@ -300,6 +301,9 @@ namespace CreamInstaller acceptButton.Enabled = ProgramSelection.AllSafeEnabled.Any(); cancelButton.Enabled = false; scanButton.Enabled = true; + + label2.Text = "Validating . . . "; + if (!validating && !Program.Canceled) OnLoad(true); } /*private const int GWL_STYLE = -16;