v2.2.4.0
- Optimized the number of SteamCMD instances that would open for appinfo gathering processes - Optimized the install form update delays so they're now way faster and still don't glitch the log - Added a 10ms delay to DLC iterations to reduce control & window freezing - Select form cancelling now runs on the proper thread to reduce cancellation delay
This commit is contained in:
parent
9729e95e85
commit
ffbbeedeff
5 changed files with 25 additions and 25 deletions
|
@ -44,14 +44,12 @@ namespace CreamInstaller
|
||||||
StandardOutputEncoding = Encoding.UTF8,
|
StandardOutputEncoding = Encoding.UTF8,
|
||||||
StandardErrorEncoding = Encoding.UTF8
|
StandardErrorEncoding = Encoding.UTF8
|
||||||
};
|
};
|
||||||
using (Process process = Process.Start(processStartInfo))
|
using Process process = Process.Start(processStartInfo);
|
||||||
{
|
|
||||||
process.OutputDataReceived += (object sender, DataReceivedEventArgs e) => logs.Add(e.Data);
|
process.OutputDataReceived += (object sender, DataReceivedEventArgs e) => logs.Add(e.Data);
|
||||||
process.BeginOutputReadLine();
|
process.BeginOutputReadLine();
|
||||||
process.ErrorDataReceived += (object sender, DataReceivedEventArgs e) => logs.Add(e.Data);
|
process.ErrorDataReceived += (object sender, DataReceivedEventArgs e) => logs.Add(e.Data);
|
||||||
process.BeginErrorReadLine();
|
process.BeginErrorReadLine();
|
||||||
process.WaitForExit();
|
process.WaitForExit();
|
||||||
}
|
|
||||||
return string.Join("\r\n", logs);
|
return string.Join("\r\n", logs);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -91,8 +89,7 @@ namespace CreamInstaller
|
||||||
output = File.ReadAllText(appUpdateFile, Encoding.UTF8);
|
output = File.ReadAllText(appUpdateFile, Encoding.UTF8);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
await Run($@"+@ShutdownOnFailedCommand 0 +login anonymous +app_info_print {appId} +force_install_dir {appUpdatePath} +app_update 4 +quit");
|
output = await Run($@"+@ShutdownOnFailedCommand 0 +login anonymous +app_info_print {appId} +force_install_dir {appUpdatePath} +app_update 4 +quit");
|
||||||
output = await Run($@"+@ShutdownOnFailedCommand 0 +login anonymous +app_info_print {appId} +quit");
|
|
||||||
int openBracket = output.IndexOf("{");
|
int openBracket = output.IndexOf("{");
|
||||||
int closeBracket = output.LastIndexOf("}");
|
int closeBracket = output.LastIndexOf("}");
|
||||||
if (openBracket != -1 && closeBracket != -1)
|
if (openBracket != -1 && closeBracket != -1)
|
||||||
|
@ -112,7 +109,7 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (appInfo.Value is VValue) goto restart;
|
if (appInfo.Value is VValue) goto restart;
|
||||||
if (appInfo is null || (appInfo.Value is not VValue && appInfo.Value.Children().ToList().Count == 0))
|
if (appInfo is null || appInfo.Value is not VValue && appInfo.Value.Children().ToList().Count == 0)
|
||||||
return appInfo;
|
return appInfo;
|
||||||
VToken type = appInfo.Value is VValue ? null : appInfo.Value?["common"]?["type"];
|
VToken type = appInfo.Value is VValue ? null : appInfo.Value?["common"]?["type"];
|
||||||
if (type is null || type.ToString() == "Game")
|
if (type is null || type.ToString() == "Game")
|
||||||
|
@ -137,7 +134,7 @@ namespace CreamInstaller
|
||||||
internal static async Task<List<int>> ParseDlcAppIds(VProperty appInfo) => await Task.Run(() =>
|
internal static async Task<List<int>> ParseDlcAppIds(VProperty appInfo) => await Task.Run(() =>
|
||||||
{
|
{
|
||||||
List<int> dlcIds = new();
|
List<int> dlcIds = new();
|
||||||
if (appInfo is not VProperty) return dlcIds;
|
if (Program.Canceled || appInfo is not VProperty) return dlcIds;
|
||||||
if (appInfo.Value["extended"] is not null)
|
if (appInfo.Value["extended"] is not null)
|
||||||
foreach (VProperty property in appInfo.Value["extended"])
|
foreach (VProperty property in appInfo.Value["extended"])
|
||||||
if (property.Key.ToString() == "listofdlc")
|
if (property.Key.ToString() == "listofdlc")
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
<UseWindowsForms>true</UseWindowsForms>
|
<UseWindowsForms>true</UseWindowsForms>
|
||||||
<ApplicationIcon>Resources\ini.ico</ApplicationIcon>
|
<ApplicationIcon>Resources\ini.ico</ApplicationIcon>
|
||||||
<IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract>
|
<IncludeAllContentForSelfExtract>true</IncludeAllContentForSelfExtract>
|
||||||
<Version>2.2.3.0</Version>
|
<Version>2.2.4.0</Version>
|
||||||
<PackageIcon>Resources\ini.ico</PackageIcon>
|
<PackageIcon>Resources\ini.ico</PackageIcon>
|
||||||
<PackageIconUrl />
|
<PackageIconUrl />
|
||||||
<Description>Automatically generates and installs CreamAPI files for Steam games on the user's computer. It can also generate and install CreamAPI for the Paradox Launcher should the user select a Paradox Interactive game.</Description>
|
<Description>Automatically generates and installs CreamAPI files for Steam games on the user's computer. It can also generate and install CreamAPI for the Paradox Launcher should the user select a Paradox Interactive game.</Description>
|
||||||
|
|
|
@ -42,7 +42,7 @@ namespace CreamInstaller
|
||||||
if (logTextBox.Text.Length > 0) logTextBox.AppendText(Environment.NewLine, color);
|
if (logTextBox.Text.Length > 0) logTextBox.AppendText(Environment.NewLine, color);
|
||||||
logTextBox.AppendText(text, color);
|
logTextBox.AppendText(text, color);
|
||||||
}
|
}
|
||||||
await Task.Run(() => Thread.Sleep(1)); // to keep the text box control from glitching
|
await Task.Run(() => Thread.Sleep(0)); // to keep the text box control from glitching
|
||||||
}
|
}
|
||||||
|
|
||||||
internal async Task WriteConfiguration(StreamWriter writer, int steamAppId, string name, SortedList<int, string> steamDlcApps)
|
internal async Task WriteConfiguration(StreamWriter writer, int steamAppId, string name, SortedList<int, string> steamDlcApps)
|
||||||
|
@ -170,7 +170,7 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
++CompleteOperationsCount;
|
++CompleteOperationsCount;
|
||||||
}
|
}
|
||||||
await Program.Cleanup();
|
Program.Cleanup();
|
||||||
List<ProgramSelection> FailedSelections = ProgramSelection.AllUsableEnabled;
|
List<ProgramSelection> FailedSelections = ProgramSelection.AllUsableEnabled;
|
||||||
if (FailedSelections.Any())
|
if (FailedSelections.Any())
|
||||||
if (FailedSelections.Count == 1) throw new CustomMessageException($"Operation failed for {FailedSelections.First().Name}.");
|
if (FailedSelections.Count == 1) throw new CustomMessageException($"Operation failed for {FailedSelections.First().Name}.");
|
||||||
|
@ -221,21 +221,21 @@ namespace CreamInstaller
|
||||||
|
|
||||||
private void OnAccept(object sender, EventArgs e)
|
private void OnAccept(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
Program.Cleanup().Wait();
|
Program.Cleanup();
|
||||||
Close();
|
Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnRetry(object sender, EventArgs e)
|
private void OnRetry(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
Program.Cleanup().Wait();
|
Program.Cleanup();
|
||||||
Start();
|
Start();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnCancel(object sender, EventArgs e) => Program.Cleanup().Wait();
|
private void OnCancel(object sender, EventArgs e) => Program.Cleanup();
|
||||||
|
|
||||||
private void OnReselect(object sender, EventArgs e)
|
private void OnReselect(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
Program.Cleanup().Wait();
|
Program.Cleanup();
|
||||||
Reselecting = true;
|
Reselecting = true;
|
||||||
Close();
|
Close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ using System.Drawing;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
|
||||||
|
@ -190,8 +191,9 @@ namespace CreamInstaller
|
||||||
});
|
});
|
||||||
dlcTasks.Add(task);
|
dlcTasks.Add(task);
|
||||||
RunningTasks.Add(task);
|
RunningTasks.Add(task);
|
||||||
}
|
|
||||||
progress.Report(-RunningTasks.Count);
|
progress.Report(-RunningTasks.Count);
|
||||||
|
Thread.Sleep(10); // to reduce control & window freezing
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else if (appId > 0) return;
|
else if (appId > 0) return;
|
||||||
if (Program.Canceled) return;
|
if (Program.Canceled) return;
|
||||||
|
@ -250,11 +252,11 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
progress.Report(++cur);
|
progress.Report(++cur);
|
||||||
}));
|
}));
|
||||||
}
|
|
||||||
progress.Report(-RunningTasks.Count);
|
progress.Report(-RunningTasks.Count);
|
||||||
progress.Report(cur);
|
}
|
||||||
foreach (Task task in RunningTasks.ToList())
|
foreach (Task task in RunningTasks.ToList())
|
||||||
{
|
{
|
||||||
if (Program.Canceled) return;
|
if (Program.Canceled) return;
|
||||||
|
@ -290,6 +292,7 @@ namespace CreamInstaller
|
||||||
IProgress<int> iProgress = progress;
|
IProgress<int> iProgress = progress;
|
||||||
progress.ProgressChanged += (sender, _progress) =>
|
progress.ProgressChanged += (sender, _progress) =>
|
||||||
{
|
{
|
||||||
|
if (Program.Canceled) return;
|
||||||
if (_progress < 0) maxProgress = -_progress;
|
if (_progress < 0) maxProgress = -_progress;
|
||||||
else curProgress = _progress;
|
else curProgress = _progress;
|
||||||
int p = Math.Max(Math.Min((int)((float)(curProgress / (float)maxProgress) * 100), 100), 0);
|
int p = Math.Max(Math.Min((int)((float)(curProgress / (float)maxProgress) * 100), 100), 0);
|
||||||
|
@ -507,7 +510,7 @@ namespace CreamInstaller
|
||||||
private void OnCancel(object sender, EventArgs e)
|
private void OnCancel(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
progressLabel.Text = "Cancelling . . . ";
|
progressLabel.Text = "Cancelling . . . ";
|
||||||
Task.Run(async () => await Program.Cleanup());
|
Program.Cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnAllCheckBoxChanged(object sender, EventArgs e)
|
private void OnAllCheckBoxChanged(object sender, EventArgs e)
|
||||||
|
|
|
@ -116,13 +116,13 @@ namespace CreamInstaller
|
||||||
internal static List<ProgramSelection> ProgramSelections = new();
|
internal static List<ProgramSelection> ProgramSelections = new();
|
||||||
|
|
||||||
internal static bool Canceled = false;
|
internal static bool Canceled = false;
|
||||||
internal static async Task Cleanup(bool cancel = true)
|
internal static async void Cleanup(bool cancel = true)
|
||||||
{
|
{
|
||||||
Canceled = cancel;
|
Canceled = cancel;
|
||||||
await SteamCMD.Kill();
|
await SteamCMD.Kill();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void OnApplicationExit(object s, EventArgs e) => Cleanup().Wait();
|
private static void OnApplicationExit(object s, EventArgs e) => Cleanup();
|
||||||
|
|
||||||
internal static void InheritLocation(this Form form, Form fromForm)
|
internal static void InheritLocation(this Form form, Form fromForm)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue