- Paradox Launcher repair is now also done automatically during installation
This commit is contained in:
pointfeev 2022-03-21 13:31:12 -04:00
parent 8ae84415fe
commit f7b484f1f3
4 changed files with 64 additions and 32 deletions

View file

@ -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>3.4.0.2</Version> <Version>3.4.0.3</Version>
<PackageIcon>Resources\ini.ico</PackageIcon> <PackageIcon>Resources\ini.ico</PackageIcon>
<PackageLicenseFile>LICENSE</PackageLicenseFile> <PackageLicenseFile>LICENSE</PackageLicenseFile>
<Copyright>2021, pointfeev (https://github.com/pointfeev)</Copyright> <Copyright>2021, pointfeev (https://github.com/pointfeev)</Copyright>

View file

@ -8,6 +8,7 @@ using System.Threading.Tasks;
using System.Windows.Forms; using System.Windows.Forms;
using CreamInstaller.Components; using CreamInstaller.Components;
using CreamInstaller.Paradox;
using CreamInstaller.Resources; using CreamInstaller.Resources;
using CreamInstaller.Utility; using CreamInstaller.Utility;
@ -61,14 +62,14 @@ internal partial class InstallForm : CustomForm
writer.WriteLine(); writer.WriteLine();
writer.WriteLine("[dlc]"); writer.WriteLine("[dlc]");
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Added game to cream_api.ini with appid {appId} ({name})", InstallationLog.Resource, info: false); installForm.UpdateUser($"Added game to cream_api.ini with appid {appId} ({name})", InstallationLog.Action, info: false);
foreach (KeyValuePair<string, (DlcType type, string name, string icon)> pair in dlc) foreach (KeyValuePair<string, (DlcType type, string name, string icon)> pair in dlc)
{ {
string dlcId = pair.Key; string dlcId = pair.Key;
(_, string dlcName, _) = pair.Value; (_, string dlcName, _) = pair.Value;
writer.WriteLine($"{dlcId} = {dlcName}"); writer.WriteLine($"{dlcId} = {dlcName}");
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Added DLC to cream_api.ini with appid {dlcId} ({dlcName})", InstallationLog.Resource, info: false); installForm.UpdateUser($"Added DLC to cream_api.ini with appid {dlcId} ({dlcName})", InstallationLog.Action, info: false);
} }
} }
@ -81,11 +82,11 @@ internal partial class InstallForm : CustomForm
{ {
File.Delete(sdk32); File.Delete(sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
File.Move(sdk32_o, sdk32); File.Move(sdk32_o, sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32_o)} -> {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32_o)} -> {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64_o)) if (File.Exists(sdk64_o))
{ {
@ -93,17 +94,17 @@ internal partial class InstallForm : CustomForm
{ {
File.Delete(sdk64); File.Delete(sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
File.Move(sdk64_o, sdk64); File.Move(sdk64_o, sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
if (File.Exists(config)) if (File.Exists(config))
{ {
File.Delete(config); File.Delete(config);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(config)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
} }
}); });
@ -114,25 +115,25 @@ internal partial class InstallForm : CustomForm
{ {
File.Move(sdk32, sdk32_o); File.Move(sdk32, sdk32_o);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32)} -> {Path.GetFileName(sdk32_o)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32)} -> {Path.GetFileName(sdk32_o)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk32_o)) if (File.Exists(sdk32_o))
{ {
Properties.Resources.Steamworks32.Write(sdk32); Properties.Resources.Steamworks32.Write(sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64) && !File.Exists(sdk64_o)) if (File.Exists(sdk64) && !File.Exists(sdk64_o))
{ {
File.Move(sdk64, sdk64_o); File.Move(sdk64, sdk64_o);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64)} -> {Path.GetFileName(sdk64_o)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64)} -> {Path.GetFileName(sdk64_o)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64_o)) if (File.Exists(sdk64_o))
{ {
Properties.Resources.Steamworks64.Write(sdk64); Properties.Resources.Steamworks64.Write(sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser("Generating CreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation); installForm.UpdateUser("Generating CreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
@ -166,7 +167,7 @@ internal partial class InstallForm : CustomForm
(_, string name, _) = pair.Value; (_, string name, _) = pair.Value;
writer.WriteLine($" \"{id}\"{(pair.Equals(lastCatalogItem) ? "" : ",")}"); writer.WriteLine($" \"{id}\"{(pair.Equals(lastCatalogItem) ? "" : ",")}");
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Added catalog item to ScreamAPI.json with id {id} ({name})", InstallationLog.Resource, info: false); installForm.UpdateUser($"Added catalog item to ScreamAPI.json with id {id} ({name})", InstallationLog.Action, info: false);
} }
writer.WriteLine(" ]"); writer.WriteLine(" ]");
} }
@ -190,7 +191,7 @@ internal partial class InstallForm : CustomForm
(_, string name, _) = pair.Value; (_, string name, _) = pair.Value;
writer.WriteLine($" \"{id}\"{(pair.Equals(lastEntitlement) ? "" : ",")}"); writer.WriteLine($" \"{id}\"{(pair.Equals(lastEntitlement) ? "" : ",")}");
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Added entitlement to ScreamAPI.json with id {id} ({name})", InstallationLog.Resource, info: false); installForm.UpdateUser($"Added entitlement to ScreamAPI.json with id {id} ({name})", InstallationLog.Action, info: false);
} }
writer.WriteLine(" ]"); writer.WriteLine(" ]");
} }
@ -213,11 +214,11 @@ internal partial class InstallForm : CustomForm
{ {
File.Delete(sdk32); File.Delete(sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
File.Move(sdk32_o, sdk32); File.Move(sdk32_o, sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32_o)} -> {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32_o)} -> {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64_o)) if (File.Exists(sdk64_o))
{ {
@ -225,17 +226,17 @@ internal partial class InstallForm : CustomForm
{ {
File.Delete(sdk64); File.Delete(sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
File.Move(sdk64_o, sdk64); File.Move(sdk64_o, sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
if (File.Exists(config)) if (File.Exists(config))
{ {
File.Delete(config); File.Delete(config);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Deleted file: {Path.GetFileName(config)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Deleted file: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
} }
}); });
@ -246,25 +247,25 @@ internal partial class InstallForm : CustomForm
{ {
File.Move(sdk32, sdk32_o); File.Move(sdk32, sdk32_o);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32)} -> {Path.GetFileName(sdk32_o)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk32)} -> {Path.GetFileName(sdk32_o)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk32_o)) if (File.Exists(sdk32_o))
{ {
Properties.Resources.EpicOnlineServices32.Write(sdk32); Properties.Resources.EpicOnlineServices32.Write(sdk32);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk32)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk32)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64) && !File.Exists(sdk64_o)) if (File.Exists(sdk64) && !File.Exists(sdk64_o))
{ {
File.Move(sdk64, sdk64_o); File.Move(sdk64, sdk64_o);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64)} -> {Path.GetFileName(sdk64_o)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Renamed file: {Path.GetFileName(sdk64)} -> {Path.GetFileName(sdk64_o)}", InstallationLog.Action, info: false);
} }
if (File.Exists(sdk64_o)) if (File.Exists(sdk64_o))
{ {
Properties.Resources.EpicOnlineServices64.Write(sdk64); Properties.Resources.EpicOnlineServices64.Write(sdk64);
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk64)}", InstallationLog.Resource, info: false); installForm.UpdateUser($"Wrote resource to file: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
} }
if (installForm is not null) if (installForm is not null)
installForm.UpdateUser("Generating ScreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation); installForm.UpdateUser("Generating ScreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
@ -283,11 +284,33 @@ internal partial class InstallForm : CustomForm
UpdateProgress(0); UpdateProgress(0);
int count = selection.DllDirectories.Count; int count = selection.DllDirectories.Count;
int cur = 0; int cur = 0;
int code = 0;
if (selection.Id == "ParadoxLauncher")
{
UpdateUser($"Repairing Paradox Launcher . . . ", InstallationLog.Operation);
code = await ParadoxLauncher.Repair(this, selection);
switch (code)
{
case -2:
throw new CustomMessageException("Repair failed! The Paradox Launcher is currently running!");
case -1:
throw new CustomMessageException("Repair failed! " +
"An original Steamworks/Epic Online Services SDK file could not be found. " +
"You must reinstall Paradox Launcher to fix this issue.");
case 0:
UpdateUser("Paradox Launcher does not need to be repaired.", InstallationLog.Action);
break;
case 1:
UpdateUser("Paradox Launcher successfully repaired!", InstallationLog.Success);
break;
}
}
if (code < 0) throw new CustomMessageException("Repair failed!");
string platform = selection.Platform == Platform.Steam ? "CreamAPI"
: selection.Platform == Platform.Epic ? "ScreamAPI"
: throw new InvalidPlatformException(selection.Platform);
foreach (string directory in selection.DllDirectories) foreach (string directory in selection.DllDirectories)
{ {
string platform = selection.Platform == Platform.Steam ? "CreamAPI"
: selection.Platform == Platform.Epic ? "ScreamAPI"
: throw new InvalidPlatformException(selection.Platform);
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} {platform}" + UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} {platform}" +
$" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation); $" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
if (Program.Canceled || !Program.IsProgramRunningDialog(this, selection)) throw new CustomMessageException("The operation was canceled."); if (Program.Canceled || !Program.IsProgramRunningDialog(this, selection)) throw new CustomMessageException("The operation was canceled.");

View file

@ -61,9 +61,9 @@ internal static class ParadoxLauncher
return false; return false;
} }
internal static async Task Repair(Form form, ProgramSelection selection) internal static async Task<int> Repair(Form form, ProgramSelection selection)
{ {
if (!Program.IsProgramRunningDialog(form, selection)) return; if (!Program.IsProgramRunningDialog(form, selection)) return -2;
byte[] creamConfig = null; byte[] creamConfig = null;
byte[] steamOriginalSdk32 = null; byte[] steamOriginalSdk32 = null;
byte[] steamOriginalSdk64 = null; byte[] steamOriginalSdk64 = null;
@ -130,13 +130,22 @@ internal static class ParadoxLauncher
} }
} }
if (neededRepair) if (neededRepair)
dialogForm.Show(form.Icon, "Paradox Launcher successfully repaired!", "OK"); {
if (form is not InstallForm) dialogForm.Show(form.Icon, "Paradox Launcher successfully repaired!", "OK");
return 1;
}
else else
dialogForm.Show(SystemIcons.Information, "Paradox Launcher does not need to be repaired.", "OK"); {
if (form is not InstallForm) dialogForm.Show(SystemIcons.Information, "Paradox Launcher does not need to be repaired.", "OK");
return 0;
}
} }
else else
dialogForm.Show(SystemIcons.Error, "Paradox Launcher repair failed!" {
if (form is not InstallForm) dialogForm.Show(SystemIcons.Error, "Paradox Launcher repair failed!"
+ "\n\nAn original Steamworks/Epic Online Services SDK file could not be found." + "\n\nAn original Steamworks/Epic Online Services SDK file could not be found."
+ "\nYou must reinstall Paradox Launcher to fix this issue.", "OK"); + "\nYou must reinstall Paradox Launcher to fix this issue.", "OK");
return -1;
}
} }
} }

View file

@ -7,7 +7,7 @@ internal static class InstallationLog
{ {
internal static readonly Color Background = Color.DarkSlateGray; internal static readonly Color Background = Color.DarkSlateGray;
internal static readonly Color Operation = Color.LightGray; internal static readonly Color Operation = Color.LightGray;
internal static readonly Color Resource = Color.LightBlue; internal static readonly Color Action = Color.LightBlue;
internal static readonly Color Success = Color.LightGreen; internal static readonly Color Success = Color.LightGreen;
internal static readonly Color Cleanup = Color.YellowGreen; internal static readonly Color Cleanup = Color.YellowGreen;
internal static readonly Color Warning = Color.Yellow; internal static readonly Color Warning = Color.Yellow;