v3.5.4.2
- Minor refactoring - Paradox Launcher repair operation now ignores configs altogether instead of needing to cache and restore - Paradox Launcher repair operation now shows which files are corrected when performed automatically during installation - Uninstallation now also deletes the cache json file
This commit is contained in:
parent
5ab9113c54
commit
d95598fa38
8 changed files with 167 additions and 134 deletions
|
@ -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.5.4.1</Version>
|
<Version>3.5.4.2</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>
|
||||||
|
|
|
@ -53,12 +53,13 @@ internal static class EpicLibrary
|
||||||
{
|
{
|
||||||
List<string> dllDirectories = new();
|
List<string> dllDirectories = new();
|
||||||
if (Program.Canceled || !Directory.Exists(gameDirectory)) return null;
|
if (Program.Canceled || !Directory.Exists(gameDirectory)) return null;
|
||||||
gameDirectory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
gameDirectory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32)
|
if (File.Exists(sdk32)
|
||||||
|| File.Exists(sdk32_o)
|
|| File.Exists(sdk32_o)
|
||||||
|| File.Exists(sdk64)
|
|| File.Exists(sdk64)
|
||||||
|| File.Exists(sdk64_o)
|
|| File.Exists(sdk64_o)
|
||||||
|| File.Exists(config))
|
|| File.Exists(config)
|
||||||
|
|| File.Exists(cache))
|
||||||
dllDirectories.Add(gameDirectory);
|
dllDirectories.Add(gameDirectory);
|
||||||
string[] directories = Directory.GetDirectories(gameDirectory);
|
string[] directories = Directory.GetDirectories(gameDirectory);
|
||||||
foreach (string _directory in directories)
|
foreach (string _directory in directories)
|
||||||
|
|
|
@ -9,10 +9,11 @@ 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;
|
||||||
|
|
||||||
|
using static CreamInstaller.Paradox.ParadoxLauncher;
|
||||||
|
|
||||||
namespace CreamInstaller;
|
namespace CreamInstaller;
|
||||||
|
|
||||||
internal partial class InstallForm : CustomForm
|
internal partial class InstallForm : CustomForm
|
||||||
|
@ -103,9 +104,9 @@ internal partial class InstallForm : CustomForm
|
||||||
writer.WriteLine("}");
|
writer.WriteLine("}");
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task UninstallSmokeAPI(string directory, InstallForm installForm = null) => await Task.Run(() =>
|
internal static async Task UninstallSmokeAPI(string directory, InstallForm installForm = null, bool deleteConfig = true) => await Task.Run(() =>
|
||||||
{
|
{
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32_o))
|
if (File.Exists(sdk32_o))
|
||||||
{
|
{
|
||||||
if (File.Exists(sdk32))
|
if (File.Exists(sdk32))
|
||||||
|
@ -130,15 +131,21 @@ internal partial class InstallForm : CustomForm
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Restored Steamworks: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Restored Steamworks: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
if (File.Exists(config))
|
if (deleteConfig && File.Exists(config))
|
||||||
{
|
{
|
||||||
File.Delete(config);
|
File.Delete(config);
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Deleted configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Deleted configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
|
if (deleteConfig && File.Exists(cache))
|
||||||
|
{
|
||||||
|
File.Delete(cache);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser($"Deleted cache: {Path.GetFileName(cache)}", InstallationLog.Action, info: false);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
internal static async Task InstallSmokeAPI(string directory, ProgramSelection selection, InstallForm installForm = null) => await Task.Run(() =>
|
internal static async Task InstallSmokeAPI(string directory, ProgramSelection selection, InstallForm installForm = null, bool generateConfig = true) => await Task.Run(() =>
|
||||||
{
|
{
|
||||||
directory.GetCreamApiComponents(out _, out _, out _, out _, out string oldConfig);
|
directory.GetCreamApiComponents(out _, out _, out _, out _, out string oldConfig);
|
||||||
if (File.Exists(oldConfig))
|
if (File.Exists(oldConfig))
|
||||||
|
@ -147,7 +154,7 @@ internal partial class InstallForm : CustomForm
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Deleted old CreamAPI configuration: {Path.GetFileName(oldConfig)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Deleted old CreamAPI configuration: {Path.GetFileName(oldConfig)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out _);
|
||||||
if (File.Exists(sdk32) && !File.Exists(sdk32_o))
|
if (File.Exists(sdk32) && !File.Exists(sdk32_o))
|
||||||
{
|
{
|
||||||
File.Move(sdk32, sdk32_o);
|
File.Move(sdk32, sdk32_o);
|
||||||
|
@ -172,35 +179,38 @@ internal partial class InstallForm : CustomForm
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Wrote SmokeAPI: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Wrote SmokeAPI: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> overrideDlc = selection.AllDlc.Except(selection.SelectedDlc);
|
if (generateConfig)
|
||||||
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
|
||||||
overrideDlc = overrideDlc.Except(extraDlc);
|
|
||||||
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> injectDlc = new List<KeyValuePair<string, (DlcType type, string name, string icon)>>();
|
|
||||||
if (selection.AllDlc.Count > 64 || selection.ExtraDlc.Any(e => e.dlc.Count > 64))
|
|
||||||
{
|
{
|
||||||
injectDlc = injectDlc.Concat(selection.SelectedDlc.Where(pair => pair.Value.type is DlcType.SteamHidden));
|
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> overrideDlc = selection.AllDlc.Except(selection.SelectedDlc);
|
||||||
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
||||||
if (selection.ExtraDlc.Where(e => e.id == id).Single().dlc.Count > 64)
|
overrideDlc = overrideDlc.Except(extraDlc);
|
||||||
injectDlc = injectDlc.Concat(extraDlc.Where(pair => pair.Value.type is DlcType.SteamHidden));
|
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> injectDlc = new List<KeyValuePair<string, (DlcType type, string name, string icon)>>();
|
||||||
}
|
if (selection.AllDlc.Count > 64 || selection.ExtraDlc.Any(e => e.dlc.Count > 64))
|
||||||
if (overrideDlc.Any() || injectDlc.Any())
|
{
|
||||||
{
|
injectDlc = injectDlc.Concat(selection.SelectedDlc.Where(pair => pair.Value.type is DlcType.SteamHidden));
|
||||||
if (installForm is not null)
|
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
||||||
installForm.UpdateUser("Generating SmokeAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
if (selection.ExtraDlc.Where(e => e.id == id).Single().dlc.Count > 64)
|
||||||
File.Create(config).Close();
|
injectDlc = injectDlc.Concat(extraDlc.Where(pair => pair.Value.type is DlcType.SteamHidden));
|
||||||
StreamWriter writer = new(config, true, Encoding.UTF8);
|
}
|
||||||
WriteSmokeConfiguration(writer,
|
if (overrideDlc.Any() || injectDlc.Any())
|
||||||
new(overrideDlc.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
{
|
||||||
new(injectDlc.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
if (installForm is not null)
|
||||||
installForm);
|
installForm.UpdateUser("Generating SmokeAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
writer.Flush();
|
File.Create(config).Close();
|
||||||
writer.Close();
|
StreamWriter writer = new(config, true, Encoding.UTF8);
|
||||||
}
|
WriteSmokeConfiguration(writer,
|
||||||
else if (File.Exists(config))
|
new(overrideDlc.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
||||||
{
|
new(injectDlc.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
||||||
File.Delete(config);
|
installForm);
|
||||||
if (installForm is not null)
|
writer.Flush();
|
||||||
installForm.UpdateUser($"Deleted unnecessary configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
writer.Close();
|
||||||
|
}
|
||||||
|
else if (File.Exists(config))
|
||||||
|
{
|
||||||
|
File.Delete(config);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser($"Deleted unnecessary configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -256,9 +266,9 @@ internal partial class InstallForm : CustomForm
|
||||||
writer.WriteLine("}");
|
writer.WriteLine("}");
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task UninstallScreamAPI(string directory, InstallForm installForm = null) => await Task.Run(() =>
|
internal static async Task UninstallScreamAPI(string directory, InstallForm installForm = null, bool deleteConfig = true) => await Task.Run(() =>
|
||||||
{
|
{
|
||||||
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32_o))
|
if (File.Exists(sdk32_o))
|
||||||
{
|
{
|
||||||
if (File.Exists(sdk32))
|
if (File.Exists(sdk32))
|
||||||
|
@ -283,17 +293,23 @@ internal partial class InstallForm : CustomForm
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Restored Epic Online Services: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Restored Epic Online Services: {Path.GetFileName(sdk64_o)} -> {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
if (File.Exists(config))
|
if (deleteConfig && File.Exists(config))
|
||||||
{
|
{
|
||||||
File.Delete(config);
|
File.Delete(config);
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Deleted configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Deleted configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
|
if (deleteConfig && File.Exists(cache))
|
||||||
|
{
|
||||||
|
File.Delete(cache);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser($"Deleted cache: {Path.GetFileName(cache)}", InstallationLog.Action, info: false);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
internal static async Task InstallScreamAPI(string directory, ProgramSelection selection, InstallForm installForm = null) => await Task.Run(() =>
|
internal static async Task InstallScreamAPI(string directory, ProgramSelection selection, InstallForm installForm = null, bool generateConfig = true) => await Task.Run(() =>
|
||||||
{
|
{
|
||||||
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out _);
|
||||||
if (File.Exists(sdk32) && !File.Exists(sdk32_o))
|
if (File.Exists(sdk32) && !File.Exists(sdk32_o))
|
||||||
{
|
{
|
||||||
File.Move(sdk32, sdk32_o);
|
File.Move(sdk32, sdk32_o);
|
||||||
|
@ -318,30 +334,33 @@ internal partial class InstallForm : CustomForm
|
||||||
if (installForm is not null)
|
if (installForm is not null)
|
||||||
installForm.UpdateUser($"Wrote ScreamAPI: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
installForm.UpdateUser($"Wrote ScreamAPI: {Path.GetFileName(sdk64)}", InstallationLog.Action, info: false);
|
||||||
}
|
}
|
||||||
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> overrideCatalogItems = selection.AllDlc.Where(pair => pair.Value.type is DlcType.EpicCatalogItem).Except(selection.SelectedDlc);
|
if (generateConfig)
|
||||||
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
|
||||||
overrideCatalogItems = overrideCatalogItems.Except(extraDlc);
|
|
||||||
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> entitlements = selection.SelectedDlc.Where(pair => pair.Value.type == DlcType.EpicEntitlement);
|
|
||||||
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> _dlc) in selection.ExtraSelectedDlc)
|
|
||||||
entitlements = entitlements.Concat(_dlc.Where(pair => pair.Value.type == DlcType.EpicEntitlement));
|
|
||||||
if (overrideCatalogItems.Any() || entitlements.Any())
|
|
||||||
{
|
{
|
||||||
if (installForm is not null)
|
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> overrideCatalogItems = selection.AllDlc.Where(pair => pair.Value.type is DlcType.EpicCatalogItem).Except(selection.SelectedDlc);
|
||||||
installForm.UpdateUser("Generating ScreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> extraDlc) in selection.ExtraSelectedDlc)
|
||||||
File.Create(config).Close();
|
overrideCatalogItems = overrideCatalogItems.Except(extraDlc);
|
||||||
StreamWriter writer = new(config, true, Encoding.UTF8);
|
IEnumerable<KeyValuePair<string, (DlcType type, string name, string icon)>> entitlements = selection.SelectedDlc.Where(pair => pair.Value.type == DlcType.EpicEntitlement);
|
||||||
WriteScreamConfiguration(writer,
|
foreach ((string id, string name, SortedList<string, (DlcType type, string name, string icon)> _dlc) in selection.ExtraSelectedDlc)
|
||||||
new(overrideCatalogItems.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
entitlements = entitlements.Concat(_dlc.Where(pair => pair.Value.type == DlcType.EpicEntitlement));
|
||||||
new(entitlements.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
if (overrideCatalogItems.Any() || entitlements.Any())
|
||||||
installForm);
|
{
|
||||||
writer.Flush();
|
if (installForm is not null)
|
||||||
writer.Close();
|
installForm.UpdateUser("Generating ScreamAPI configuration for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
}
|
File.Create(config).Close();
|
||||||
else if (File.Exists(config))
|
StreamWriter writer = new(config, true, Encoding.UTF8);
|
||||||
{
|
WriteScreamConfiguration(writer,
|
||||||
File.Delete(config);
|
new(overrideCatalogItems.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
||||||
if (installForm is not null)
|
new(entitlements.ToDictionary(pair => pair.Key, pair => pair.Value), AppIdComparer.Comparer),
|
||||||
installForm.UpdateUser($"Deleted unnecessary configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
installForm);
|
||||||
|
writer.Flush();
|
||||||
|
writer.Close();
|
||||||
|
}
|
||||||
|
else if (File.Exists(config))
|
||||||
|
{
|
||||||
|
File.Delete(config);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser($"Deleted unnecessary configuration: {Path.GetFileName(config)}", InstallationLog.Action, info: false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -350,36 +369,19 @@ 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")
|
if (selection.Id == "ParadoxLauncher")
|
||||||
{
|
{
|
||||||
UpdateUser($"Repairing Paradox Launcher . . . ", InstallationLog.Operation);
|
UpdateUser($"Repairing Paradox Launcher . . . ", InstallationLog.Operation);
|
||||||
code = await ParadoxLauncher.Repair(this, selection);
|
await 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!");
|
|
||||||
foreach (string directory in selection.DllDirectories)
|
foreach (string directory in selection.DllDirectories)
|
||||||
{
|
{
|
||||||
Thread.Sleep(0);
|
Thread.Sleep(0);
|
||||||
if (selection.IsSteam && selection.SelectedDlc.Any(d => d.Value.type is DlcType.Steam or DlcType.SteamHidden)
|
if (selection.IsSteam && selection.SelectedDlc.Any(d => d.Value.type is DlcType.Steam or DlcType.SteamHidden)
|
||||||
|| selection.ExtraSelectedDlc.Any(item => item.dlc.Any(dlc => dlc.Value.type is DlcType.Steam or DlcType.SteamHidden)))
|
|| selection.ExtraSelectedDlc.Any(item => item.dlc.Any(dlc => dlc.Value.type is DlcType.Steam or DlcType.SteamHidden)))
|
||||||
{
|
{
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config))
|
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config) || File.Exists(cache))
|
||||||
{
|
{
|
||||||
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} SmokeAPI" +
|
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} SmokeAPI" +
|
||||||
$" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
$" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
|
@ -392,8 +394,8 @@ internal partial class InstallForm : CustomForm
|
||||||
if (selection.IsEpic && selection.SelectedDlc.Any(d => d.Value.type is DlcType.EpicCatalogItem or DlcType.EpicEntitlement)
|
if (selection.IsEpic && selection.SelectedDlc.Any(d => d.Value.type is DlcType.EpicCatalogItem or DlcType.EpicEntitlement)
|
||||||
|| selection.ExtraSelectedDlc.Any(item => item.dlc.Any(dlc => dlc.Value.type is DlcType.EpicCatalogItem or DlcType.EpicEntitlement)))
|
|| selection.ExtraSelectedDlc.Any(item => item.dlc.Any(dlc => dlc.Value.type is DlcType.EpicCatalogItem or DlcType.EpicEntitlement)))
|
||||||
{
|
{
|
||||||
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config))
|
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config) || File.Exists(cache))
|
||||||
{
|
{
|
||||||
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} ScreamAPI" +
|
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} ScreamAPI" +
|
||||||
$" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
$" {(Uninstalling ? "from" : "for")} " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
|
|
|
@ -672,8 +672,8 @@ internal partial class SelectForm : CustomForm
|
||||||
for (int i = 0; i < directories.Count; i++)
|
for (int i = 0; i < directories.Count; i++)
|
||||||
{
|
{
|
||||||
string directory = directories[i];
|
string directory = directories[i];
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config))
|
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config) || File.Exists(cache))
|
||||||
{
|
{
|
||||||
contextMenuStrip.Items.Add(new ContextMenuItem($"Open Steamworks SDK Directory #{i + 1}", "File Explorer",
|
contextMenuStrip.Items.Add(new ContextMenuItem($"Open Steamworks SDK Directory #{i + 1}", "File Explorer",
|
||||||
new EventHandler((sender, e) => Diagnostics.OpenDirectoryInFileExplorer(directory))));
|
new EventHandler((sender, e) => Diagnostics.OpenDirectoryInFileExplorer(directory))));
|
||||||
|
@ -683,8 +683,8 @@ internal partial class SelectForm : CustomForm
|
||||||
for (int i = 0; i < directories.Count; i++)
|
for (int i = 0; i < directories.Count; i++)
|
||||||
{
|
{
|
||||||
string directory = directories[i];
|
string directory = directories[i];
|
||||||
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetScreamApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config))
|
if (File.Exists(sdk32) || File.Exists(sdk32_o) || File.Exists(sdk64) || File.Exists(sdk64_o) || File.Exists(config) || File.Exists(cache))
|
||||||
{
|
{
|
||||||
contextMenuStrip.Items.Add(new ContextMenuItem($"Open Epic Online Services SDK Directory #{i + 1}", "File Explorer",
|
contextMenuStrip.Items.Add(new ContextMenuItem($"Open Epic Online Services SDK Directory #{i + 1}", "File Explorer",
|
||||||
new EventHandler((sender, e) => Diagnostics.OpenDirectoryInFileExplorer(directory))));
|
new EventHandler((sender, e) => Diagnostics.OpenDirectoryInFileExplorer(directory))));
|
||||||
|
|
|
@ -5,6 +5,7 @@ using System.Threading.Tasks;
|
||||||
using System.Windows.Forms;
|
using System.Windows.Forms;
|
||||||
|
|
||||||
using CreamInstaller.Resources;
|
using CreamInstaller.Resources;
|
||||||
|
using CreamInstaller.Utility;
|
||||||
|
|
||||||
using Microsoft.Win32;
|
using Microsoft.Win32;
|
||||||
|
|
||||||
|
@ -66,29 +67,39 @@ internal static class ParadoxLauncher
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static async Task<int> Repair(Form form, ProgramSelection selection)
|
public enum RepairResult
|
||||||
{
|
{
|
||||||
if (!Program.IsProgramRunningDialog(form, selection)) return -2;
|
ProgramRunning = -2,
|
||||||
byte[] smokeConfig = null;
|
Failure,
|
||||||
|
Unnecessary = 0,
|
||||||
|
Success
|
||||||
|
}
|
||||||
|
|
||||||
|
internal static async Task<RepairResult> Repair(Form form, ProgramSelection selection)
|
||||||
|
{
|
||||||
|
InstallForm installForm = form as InstallForm;
|
||||||
|
if (!Program.IsProgramRunningDialog(form, selection))
|
||||||
|
return form is InstallForm ? throw new CustomMessageException("Repair failed! The launcher is currently running!")
|
||||||
|
: RepairResult.ProgramRunning;
|
||||||
|
bool smokeConfig = false;
|
||||||
byte[] steamOriginalSdk32 = null;
|
byte[] steamOriginalSdk32 = null;
|
||||||
byte[] steamOriginalSdk64 = null;
|
byte[] steamOriginalSdk64 = null;
|
||||||
byte[] screamConfig = null;
|
bool screamConfig = false;
|
||||||
byte[] epicOriginalSdk32 = null;
|
byte[] epicOriginalSdk32 = null;
|
||||||
byte[] epicOriginalSdk64 = null;
|
byte[] epicOriginalSdk64 = null;
|
||||||
foreach (string directory in selection.DllDirectories)
|
foreach (string directory in selection.DllDirectories)
|
||||||
{
|
{
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string _, out string sdk64, out string _, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out _, out string sdk64, out _, out string config, out _);
|
||||||
if (smokeConfig is null && File.Exists(config))
|
smokeConfig = smokeConfig || File.Exists(config);
|
||||||
smokeConfig = File.ReadAllBytes(config);
|
await InstallForm.UninstallSmokeAPI(directory, deleteConfig: false);
|
||||||
await InstallForm.UninstallSmokeAPI(directory);
|
|
||||||
if (steamOriginalSdk32 is null && File.Exists(sdk32) && !sdk32.IsResourceFile(ResourceIdentifier.Steamworks32))
|
if (steamOriginalSdk32 is null && File.Exists(sdk32) && !sdk32.IsResourceFile(ResourceIdentifier.Steamworks32))
|
||||||
steamOriginalSdk32 = File.ReadAllBytes(sdk32);
|
steamOriginalSdk32 = File.ReadAllBytes(sdk32);
|
||||||
if (steamOriginalSdk64 is null && File.Exists(sdk64) && !sdk64.IsResourceFile(ResourceIdentifier.Steamworks64))
|
if (steamOriginalSdk64 is null && File.Exists(sdk64) && !sdk64.IsResourceFile(ResourceIdentifier.Steamworks64))
|
||||||
steamOriginalSdk64 = File.ReadAllBytes(sdk64);
|
steamOriginalSdk64 = File.ReadAllBytes(sdk64);
|
||||||
directory.GetScreamApiComponents(out sdk32, out string _, out sdk64, out string _, out config);
|
|
||||||
if (screamConfig is null && File.Exists(config))
|
directory.GetScreamApiComponents(out sdk32, out _, out sdk64, out _, out config, out _);
|
||||||
screamConfig = File.ReadAllBytes(config);
|
screamConfig = screamConfig || File.Exists(config);
|
||||||
await InstallForm.UninstallScreamAPI(directory);
|
await InstallForm.UninstallScreamAPI(directory, deleteConfig: false);
|
||||||
if (epicOriginalSdk32 is null && File.Exists(sdk32) && !sdk32.IsResourceFile(ResourceIdentifier.EpicOnlineServices32))
|
if (epicOriginalSdk32 is null && File.Exists(sdk32) && !sdk32.IsResourceFile(ResourceIdentifier.EpicOnlineServices32))
|
||||||
epicOriginalSdk32 = File.ReadAllBytes(sdk32);
|
epicOriginalSdk32 = File.ReadAllBytes(sdk32);
|
||||||
if (epicOriginalSdk64 is null && File.Exists(sdk64) && !sdk64.IsResourceFile(ResourceIdentifier.EpicOnlineServices64))
|
if (epicOriginalSdk64 is null && File.Exists(sdk64) && !sdk64.IsResourceFile(ResourceIdentifier.EpicOnlineServices64))
|
||||||
|
@ -100,57 +111,70 @@ internal static class ParadoxLauncher
|
||||||
bool neededRepair = false;
|
bool neededRepair = false;
|
||||||
foreach (string directory in selection.DllDirectories)
|
foreach (string directory in selection.DllDirectories)
|
||||||
{
|
{
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string _, out string sdk64, out string _, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out _, out string sdk64, out _, out _, out _);
|
||||||
if (steamOriginalSdk32 is not null && sdk32.IsResourceFile(ResourceIdentifier.Steamworks32))
|
if (steamOriginalSdk32 is not null && sdk32.IsResourceFile(ResourceIdentifier.Steamworks32))
|
||||||
{
|
{
|
||||||
steamOriginalSdk32.Write(sdk32);
|
steamOriginalSdk32.Write(sdk32);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser("Corrected Steamworks: " + sdk32, InstallationLog.Action);
|
||||||
neededRepair = true;
|
neededRepair = true;
|
||||||
}
|
}
|
||||||
if (steamOriginalSdk64 is not null && sdk64.IsResourceFile(ResourceIdentifier.Steamworks64))
|
if (steamOriginalSdk64 is not null && sdk64.IsResourceFile(ResourceIdentifier.Steamworks64))
|
||||||
{
|
{
|
||||||
steamOriginalSdk64.Write(sdk64);
|
steamOriginalSdk64.Write(sdk64);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser("Corrected Steamworks: " + sdk64, InstallationLog.Action);
|
||||||
neededRepair = true;
|
neededRepair = true;
|
||||||
}
|
}
|
||||||
if (smokeConfig is not null)
|
if (smokeConfig)
|
||||||
{
|
await InstallForm.InstallSmokeAPI(directory, selection, generateConfig: false);
|
||||||
await InstallForm.InstallSmokeAPI(directory, selection);
|
|
||||||
smokeConfig.Write(config);
|
|
||||||
}
|
|
||||||
|
|
||||||
directory.GetScreamApiComponents(out sdk32, out string _, out sdk64, out string _, out config);
|
directory.GetScreamApiComponents(out sdk32, out _, out sdk64, out _, out _, out _);
|
||||||
if (epicOriginalSdk32 is not null && sdk32.IsResourceFile(ResourceIdentifier.EpicOnlineServices32))
|
if (epicOriginalSdk32 is not null && sdk32.IsResourceFile(ResourceIdentifier.EpicOnlineServices32))
|
||||||
{
|
{
|
||||||
epicOriginalSdk32.Write(sdk32);
|
epicOriginalSdk32.Write(sdk32);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser("Corrected Epic Online Services: " + sdk32, InstallationLog.Action);
|
||||||
neededRepair = true;
|
neededRepair = true;
|
||||||
}
|
}
|
||||||
if (epicOriginalSdk64 is not null && sdk64.IsResourceFile(ResourceIdentifier.EpicOnlineServices64))
|
if (epicOriginalSdk64 is not null && sdk64.IsResourceFile(ResourceIdentifier.EpicOnlineServices64))
|
||||||
{
|
{
|
||||||
epicOriginalSdk64.Write(sdk64);
|
epicOriginalSdk64.Write(sdk64);
|
||||||
|
if (installForm is not null)
|
||||||
|
installForm.UpdateUser("Corrected Epic Online Services: " + sdk64, InstallationLog.Action);
|
||||||
neededRepair = true;
|
neededRepair = true;
|
||||||
}
|
}
|
||||||
if (screamConfig is not null)
|
if (screamConfig)
|
||||||
{
|
await InstallForm.InstallScreamAPI(directory, selection, generateConfig: false);
|
||||||
await InstallForm.InstallScreamAPI(directory, selection);
|
|
||||||
screamConfig.Write(config);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (neededRepair)
|
if (neededRepair)
|
||||||
{
|
{
|
||||||
if (form is not InstallForm) dialogForm.Show(form.Icon, "Paradox Launcher successfully repaired!", "OK", customFormText: "Paradox Launcher");
|
if (installForm is not null)
|
||||||
return 1;
|
installForm.UpdateUser("Paradox Launcher successfully repaired!", InstallationLog.Success);
|
||||||
|
else
|
||||||
|
dialogForm.Show(form.Icon, "Paradox Launcher successfully repaired!", "OK", customFormText: "Paradox Launcher");
|
||||||
|
return RepairResult.Success;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (form is not InstallForm) dialogForm.Show(SystemIcons.Information, "Paradox Launcher does not need to be repaired.", "OK", customFormText: "Paradox Launcher");
|
if (installForm is not null)
|
||||||
return 0;
|
installForm.UpdateUser("Paradox Launcher did not need to be repaired.", InstallationLog.Success);
|
||||||
|
else
|
||||||
|
dialogForm.Show(SystemIcons.Information, "Paradox Launcher does not need to be repaired.", "OK", customFormText: "Paradox Launcher");
|
||||||
|
return RepairResult.Unnecessary;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (form is not InstallForm) dialogForm.Show(SystemIcons.Error, "Paradox Launcher repair failed!"
|
if (form is InstallForm)
|
||||||
+ "\n\nAn original Steamworks/Epic Online Services SDK file could not be found."
|
throw new CustomMessageException("Repair failed! " +
|
||||||
+ "\nYou must reinstall Paradox Launcher to fix this issue.", "OK", customFormText: "Paradox Launcher");
|
"An original Steamworks/Epic Online Services SDK file could not be found. " +
|
||||||
return -1;
|
"You will likely have to reinstall Paradox Launcher to fix this issue.");
|
||||||
|
else
|
||||||
|
dialogForm.Show(SystemIcons.Error, "Paradox Launcher repair failed!"
|
||||||
|
+ "\n\nAn original Steamworks/Epic Online Services SDK file could not be found."
|
||||||
|
+ "\nYou will likely have to reinstall Paradox Launcher to fix this issue.", "OK", customFormText: "Paradox Launcher");
|
||||||
|
return RepairResult.Failure;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,10 +9,10 @@ namespace CreamInstaller;
|
||||||
|
|
||||||
public enum DlcType
|
public enum DlcType
|
||||||
{
|
{
|
||||||
Steam = 0,
|
Steam,
|
||||||
SteamHidden = 1,
|
SteamHidden,
|
||||||
EpicCatalogItem = 2,
|
EpicCatalogItem,
|
||||||
EpicEntitlement = 3
|
EpicEntitlement
|
||||||
}
|
}
|
||||||
|
|
||||||
internal class ProgramSelection
|
internal class ProgramSelection
|
||||||
|
@ -48,19 +48,21 @@ internal class ProgramSelection
|
||||||
{
|
{
|
||||||
foreach (string directory in DllDirectories)
|
foreach (string directory in DllDirectories)
|
||||||
{
|
{
|
||||||
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config);
|
directory.GetSmokeApiComponents(out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache);
|
||||||
if (sdk32.IsFilePathLocked()
|
if (sdk32.IsFilePathLocked()
|
||||||
|| sdk32_o.IsFilePathLocked()
|
|| sdk32_o.IsFilePathLocked()
|
||||||
|| sdk64.IsFilePathLocked()
|
|| sdk64.IsFilePathLocked()
|
||||||
|| sdk64_o.IsFilePathLocked()
|
|| sdk64_o.IsFilePathLocked()
|
||||||
|| config.IsFilePathLocked())
|
|| config.IsFilePathLocked()
|
||||||
|
|| cache.IsFilePathLocked())
|
||||||
return true;
|
return true;
|
||||||
directory.GetScreamApiComponents(out sdk32, out sdk32_o, out sdk64, out sdk64_o, out config);
|
directory.GetScreamApiComponents(out sdk32, out sdk32_o, out sdk64, out sdk64_o, out config, out cache);
|
||||||
if (sdk32.IsFilePathLocked()
|
if (sdk32.IsFilePathLocked()
|
||||||
|| sdk32_o.IsFilePathLocked()
|
|| sdk32_o.IsFilePathLocked()
|
||||||
|| sdk64.IsFilePathLocked()
|
|| sdk64.IsFilePathLocked()
|
||||||
|| sdk64_o.IsFilePathLocked()
|
|| sdk64_o.IsFilePathLocked()
|
||||||
|| config.IsFilePathLocked())
|
|| config.IsFilePathLocked()
|
||||||
|
|| cache.IsFilePathLocked())
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -40,22 +40,24 @@ internal static class Resources
|
||||||
config = directory + @"\cream_api.ini";
|
config = directory + @"\cream_api.ini";
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static void GetSmokeApiComponents(this string directory, out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config)
|
internal static void GetSmokeApiComponents(this string directory, out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache)
|
||||||
{
|
{
|
||||||
sdk32 = directory + @"\steam_api.dll";
|
sdk32 = directory + @"\steam_api.dll";
|
||||||
sdk32_o = directory + @"\steam_api_o.dll";
|
sdk32_o = directory + @"\steam_api_o.dll";
|
||||||
sdk64 = directory + @"\steam_api64.dll";
|
sdk64 = directory + @"\steam_api64.dll";
|
||||||
sdk64_o = directory + @"\steam_api64_o.dll";
|
sdk64_o = directory + @"\steam_api64_o.dll";
|
||||||
config = directory + @"\SmokeAPI.json";
|
config = directory + @"\SmokeAPI.json";
|
||||||
|
cache = directory + @"\SmokeAPI.cache.json";
|
||||||
}
|
}
|
||||||
|
|
||||||
internal static void GetScreamApiComponents(this string directory, out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config)
|
internal static void GetScreamApiComponents(this string directory, out string sdk32, out string sdk32_o, out string sdk64, out string sdk64_o, out string config, out string cache)
|
||||||
{
|
{
|
||||||
sdk32 = directory + @"\EOSSDK-Win32-Shipping.dll";
|
sdk32 = directory + @"\EOSSDK-Win32-Shipping.dll";
|
||||||
sdk32_o = directory + @"\EOSSDK-Win32-Shipping_o.dll";
|
sdk32_o = directory + @"\EOSSDK-Win32-Shipping_o.dll";
|
||||||
sdk64 = directory + @"\EOSSDK-Win64-Shipping.dll";
|
sdk64 = directory + @"\EOSSDK-Win64-Shipping.dll";
|
||||||
sdk64_o = directory + @"\EOSSDK-Win64-Shipping_o.dll";
|
sdk64_o = directory + @"\EOSSDK-Win64-Shipping_o.dll";
|
||||||
config = directory + @"\ScreamAPI.json";
|
config = directory + @"\ScreamAPI.json";
|
||||||
|
cache = directory + @"\ScreamAPI.cache.json";
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ResourceIdentifier
|
public enum ResourceIdentifier
|
||||||
|
@ -110,6 +112,7 @@ internal static class Resources
|
||||||
|
|
||||||
internal static string ComputeMD5(this string filePath)
|
internal static string ComputeMD5(this string filePath)
|
||||||
{
|
{
|
||||||
|
if (!File.Exists(filePath)) return null;
|
||||||
#pragma warning disable CA5351 // Do Not Use Broken Cryptographic Algorithms
|
#pragma warning disable CA5351 // Do Not Use Broken Cryptographic Algorithms
|
||||||
using MD5 md5 = MD5.Create();
|
using MD5 md5 = MD5.Create();
|
||||||
#pragma warning restore CA5351 // Do Not Use Broken Cryptographic Algorithms
|
#pragma warning restore CA5351 // Do Not Use Broken Cryptographic Algorithms
|
||||||
|
|
|
@ -47,12 +47,13 @@ internal static class SteamLibrary
|
||||||
{
|
{
|
||||||
List<string> dllDirectories = new();
|
List<string> dllDirectories = new();
|
||||||
if (Program.Canceled || !Directory.Exists(gameDirectory)) return null;
|
if (Program.Canceled || !Directory.Exists(gameDirectory)) return null;
|
||||||
gameDirectory.GetSmokeApiComponents(out string api, out string api_o, out string api64, out string api64_o, out string cApi);
|
gameDirectory.GetSmokeApiComponents(out string api, out string api_o, out string api64, out string api64_o, out string config, out string cache);
|
||||||
if (File.Exists(api)
|
if (File.Exists(api)
|
||||||
|| File.Exists(api_o)
|
|| File.Exists(api_o)
|
||||||
|| File.Exists(api64)
|
|| File.Exists(api64)
|
||||||
|| File.Exists(api64_o)
|
|| File.Exists(api64_o)
|
||||||
|| File.Exists(cApi))
|
|| File.Exists(config)
|
||||||
|
|| File.Exists(cache))
|
||||||
dllDirectories.Add(gameDirectory);
|
dllDirectories.Add(gameDirectory);
|
||||||
string[] directories = Directory.GetDirectories(gameDirectory);
|
string[] directories = Directory.GetDirectories(gameDirectory);
|
||||||
foreach (string _directory in directories)
|
foreach (string _directory in directories)
|
||||||
|
|
Loading…
Reference in a new issue