v2.1.0.0
- Added an uninstall feature - Made the install form more readable
This commit is contained in:
parent
93713a0f6a
commit
4e0eaba531
4 changed files with 130 additions and 70 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>2.0.5.0</Version>
|
<Version>2.1.0.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>
|
||||||
|
|
|
@ -13,8 +13,9 @@ namespace CreamInstaller
|
||||||
public partial class InstallForm : Form
|
public partial class InstallForm : Form
|
||||||
{
|
{
|
||||||
public bool Reselecting = false;
|
public bool Reselecting = false;
|
||||||
|
public bool Uninstalling = false;
|
||||||
|
|
||||||
public InstallForm(IWin32Window owner)
|
public InstallForm(IWin32Window owner, bool uninstall = false)
|
||||||
{
|
{
|
||||||
Owner = owner as Form;
|
Owner = owner as Form;
|
||||||
InitializeComponent();
|
InitializeComponent();
|
||||||
|
@ -22,6 +23,7 @@ namespace CreamInstaller
|
||||||
Text = Program.ApplicationName;
|
Text = Program.ApplicationName;
|
||||||
Icon = Properties.Resources.Icon;
|
Icon = Properties.Resources.Icon;
|
||||||
logTextBox.BackColor = InstallationLog.Background;
|
logTextBox.BackColor = InstallationLog.Background;
|
||||||
|
Uninstalling = uninstall;
|
||||||
}
|
}
|
||||||
|
|
||||||
private int OperationsCount;
|
private int OperationsCount;
|
||||||
|
@ -58,38 +60,67 @@ namespace CreamInstaller
|
||||||
int cur = 0;
|
int cur = 0;
|
||||||
foreach (string directory in selection.SteamApiDllDirectories)
|
foreach (string directory in selection.SteamApiDllDirectories)
|
||||||
{
|
{
|
||||||
UpdateUser("Installing CreamAPI for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
UpdateUser($"{(Uninstalling ? "Uninstalling" : "Installing")} CreamAPI for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
if (!Program.IsProgramRunningDialog(this, selection))
|
if (!Program.IsProgramRunningDialog(this, selection))
|
||||||
{
|
{
|
||||||
throw new OperationCanceledException();
|
throw new OperationCanceledException();
|
||||||
}
|
}
|
||||||
|
|
||||||
string api = directory + @"\steam_api.dll";
|
string api = directory + @"\steam_api.dll";
|
||||||
string api_o = directory + @"\steam_api_o.dll";
|
string api_o = directory + @"\steam_api_o.dll";
|
||||||
|
string api64 = directory + @"\steam_api64.dll";
|
||||||
|
string api64_o = directory + @"\steam_api64_o.dll";
|
||||||
|
string cApi = directory + @"\cream_api.ini";
|
||||||
|
if (Uninstalling)
|
||||||
|
{
|
||||||
|
if (File.Exists(api_o))
|
||||||
|
{
|
||||||
|
if (File.Exists(api))
|
||||||
|
{
|
||||||
|
File.Delete(api);
|
||||||
|
UpdateUser($"Deleted file: {Path.GetFileName(api)}", InstallationLog.Resource);
|
||||||
|
}
|
||||||
|
File.Move(api_o, api);
|
||||||
|
UpdateUser($"Renamed file: {Path.GetFileName(api_o)} -> {Path.GetFileName(api)}", InstallationLog.Resource);
|
||||||
|
}
|
||||||
|
if (File.Exists(api64_o))
|
||||||
|
{
|
||||||
|
if (File.Exists(api64))
|
||||||
|
{
|
||||||
|
File.Delete(api64);
|
||||||
|
UpdateUser($"Deleted file: {Path.GetFileName(api64)}", InstallationLog.Resource);
|
||||||
|
}
|
||||||
|
File.Move(api64_o, api64);
|
||||||
|
UpdateUser($"Renamed file: {Path.GetFileName(api64_o)} -> {Path.GetFileName(api64)}", InstallationLog.Resource);
|
||||||
|
}
|
||||||
|
if (File.Exists(cApi))
|
||||||
|
{
|
||||||
|
File.Delete(cApi);
|
||||||
|
UpdateUser($"Deleted file: {Path.GetFileName(cApi)}", InstallationLog.Resource);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
if (File.Exists(api) && !File.Exists(api_o))
|
if (File.Exists(api) && !File.Exists(api_o))
|
||||||
{
|
{
|
||||||
File.Move(api, api_o);
|
File.Move(api, api_o);
|
||||||
UpdateUser($"Renamed file: {api} -> steam_api_o.dll", InstallationLog.Resource);
|
UpdateUser($"Renamed file: {Path.GetFileName(api)} -> {Path.GetFileName(api_o)}", InstallationLog.Resource);
|
||||||
}
|
}
|
||||||
if (File.Exists(api_o))
|
if (File.Exists(api_o))
|
||||||
{
|
{
|
||||||
Properties.Resources.API.Write(api);
|
Properties.Resources.API.Write(api);
|
||||||
UpdateUser($"Wrote resource to file: {api}", InstallationLog.Resource);
|
UpdateUser($"Wrote resource to file: {Path.GetFileName(api)}", InstallationLog.Resource);
|
||||||
}
|
}
|
||||||
string api64 = directory + @"\steam_api64.dll";
|
|
||||||
string api64_o = directory + @"\steam_api64_o.dll";
|
|
||||||
if (File.Exists(api64) && !File.Exists(api64_o))
|
if (File.Exists(api64) && !File.Exists(api64_o))
|
||||||
{
|
{
|
||||||
File.Move(api64, api64_o);
|
File.Move(api64, api64_o);
|
||||||
UpdateUser($"Renamed file: {api64} -> steam_api64_o.dll", InstallationLog.Resource);
|
UpdateUser($"Renamed file: {Path.GetFileName(api64)} -> {Path.GetFileName(api64_o)}", InstallationLog.Resource);
|
||||||
}
|
}
|
||||||
if (File.Exists(api64_o))
|
if (File.Exists(api64_o))
|
||||||
{
|
{
|
||||||
Properties.Resources.API64.Write(api64);
|
Properties.Resources.API64.Write(api64);
|
||||||
UpdateUser($"Wrote resource to file: {api64}", InstallationLog.Resource);
|
UpdateUser($"Wrote resource to file: {Path.GetFileName(api64)}", InstallationLog.Resource);
|
||||||
}
|
}
|
||||||
UpdateUser("Generating CreamAPI for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
UpdateUser("Generating CreamAPI for " + selection.Name + $" in directory \"{directory}\" . . . ", InstallationLog.Operation);
|
||||||
string cApi = directory + @"\cream_api.ini";
|
|
||||||
File.Create(cApi).Close();
|
File.Create(cApi).Close();
|
||||||
StreamWriter writer = new(cApi, true, Encoding.UTF8);
|
StreamWriter writer = new(cApi, true, Encoding.UTF8);
|
||||||
writer.WriteLine("; " + Application.CompanyName + " v" + Application.ProductVersion);
|
writer.WriteLine("; " + Application.CompanyName + " v" + Application.ProductVersion);
|
||||||
|
@ -124,6 +155,7 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
writer.Flush();
|
writer.Flush();
|
||||||
writer.Close();
|
writer.Close();
|
||||||
|
}
|
||||||
await Task.Run(() => Thread.Sleep(10)); // to keep the text box control from glitching
|
await Task.Run(() => Thread.Sleep(10)); // to keep the text box control from glitching
|
||||||
UpdateProgress(++cur / count * 100);
|
UpdateProgress(++cur / count * 100);
|
||||||
}
|
}
|
||||||
|
|
43
CreamInstaller/Forms/SelectForm.Designer.cs
generated
43
CreamInstaller/Forms/SelectForm.Designer.cs
generated
|
@ -31,7 +31,7 @@ namespace CreamInstaller
|
||||||
/// </summary>
|
/// </summary>
|
||||||
private void InitializeComponent()
|
private void InitializeComponent()
|
||||||
{
|
{
|
||||||
this.acceptButton = new System.Windows.Forms.Button();
|
this.installButton = new System.Windows.Forms.Button();
|
||||||
this.cancelButton = new System.Windows.Forms.Button();
|
this.cancelButton = new System.Windows.Forms.Button();
|
||||||
this.label1 = new System.Windows.Forms.Label();
|
this.label1 = new System.Windows.Forms.Label();
|
||||||
this.groupBox1 = new System.Windows.Forms.GroupBox();
|
this.groupBox1 = new System.Windows.Forms.GroupBox();
|
||||||
|
@ -45,22 +45,23 @@ namespace CreamInstaller
|
||||||
this.scanButton = new System.Windows.Forms.Button();
|
this.scanButton = new System.Windows.Forms.Button();
|
||||||
this.flowLayoutPanel1 = new System.Windows.Forms.FlowLayoutPanel();
|
this.flowLayoutPanel1 = new System.Windows.Forms.FlowLayoutPanel();
|
||||||
this.flowLayoutPanel2 = new System.Windows.Forms.FlowLayoutPanel();
|
this.flowLayoutPanel2 = new System.Windows.Forms.FlowLayoutPanel();
|
||||||
|
this.uninstallButton = new System.Windows.Forms.Button();
|
||||||
this.groupBox1.SuspendLayout();
|
this.groupBox1.SuspendLayout();
|
||||||
this.flowLayoutPanel1.SuspendLayout();
|
this.flowLayoutPanel1.SuspendLayout();
|
||||||
this.flowLayoutPanel2.SuspendLayout();
|
this.flowLayoutPanel2.SuspendLayout();
|
||||||
this.SuspendLayout();
|
this.SuspendLayout();
|
||||||
//
|
//
|
||||||
// acceptButton
|
// installButton
|
||||||
//
|
//
|
||||||
this.acceptButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
this.installButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.acceptButton.Enabled = false;
|
this.installButton.Enabled = false;
|
||||||
this.acceptButton.Location = new System.Drawing.Point(422, 326);
|
this.installButton.Location = new System.Drawing.Point(422, 326);
|
||||||
this.acceptButton.Name = "acceptButton";
|
this.installButton.Name = "installButton";
|
||||||
this.acceptButton.Size = new System.Drawing.Size(150, 23);
|
this.installButton.Size = new System.Drawing.Size(150, 23);
|
||||||
this.acceptButton.TabIndex = 10002;
|
this.installButton.TabIndex = 10003;
|
||||||
this.acceptButton.Text = "Generate and Install";
|
this.installButton.Text = "Generate and Install";
|
||||||
this.acceptButton.UseVisualStyleBackColor = true;
|
this.installButton.UseVisualStyleBackColor = true;
|
||||||
this.acceptButton.Click += new System.EventHandler(this.OnAccept);
|
this.installButton.Click += new System.EventHandler(this.OnInstall);
|
||||||
//
|
//
|
||||||
// cancelButton
|
// cancelButton
|
||||||
//
|
//
|
||||||
|
@ -189,7 +190,7 @@ namespace CreamInstaller
|
||||||
//
|
//
|
||||||
this.scanButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
this.scanButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
this.scanButton.Enabled = false;
|
this.scanButton.Enabled = false;
|
||||||
this.scanButton.Location = new System.Drawing.Point(236, 326);
|
this.scanButton.Location = new System.Drawing.Point(155, 326);
|
||||||
this.scanButton.Name = "scanButton";
|
this.scanButton.Name = "scanButton";
|
||||||
this.scanButton.Size = new System.Drawing.Size(180, 23);
|
this.scanButton.Size = new System.Drawing.Size(180, 23);
|
||||||
this.scanButton.TabIndex = 10001;
|
this.scanButton.TabIndex = 10001;
|
||||||
|
@ -220,11 +221,24 @@ namespace CreamInstaller
|
||||||
this.flowLayoutPanel2.Size = new System.Drawing.Size(43, 25);
|
this.flowLayoutPanel2.Size = new System.Drawing.Size(43, 25);
|
||||||
this.flowLayoutPanel2.TabIndex = 1006;
|
this.flowLayoutPanel2.TabIndex = 1006;
|
||||||
//
|
//
|
||||||
|
// uninstallButton
|
||||||
|
//
|
||||||
|
this.uninstallButton.Anchor = ((System.Windows.Forms.AnchorStyles)((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Right)));
|
||||||
|
this.uninstallButton.Enabled = false;
|
||||||
|
this.uninstallButton.Location = new System.Drawing.Point(341, 326);
|
||||||
|
this.uninstallButton.Name = "uninstallButton";
|
||||||
|
this.uninstallButton.Size = new System.Drawing.Size(75, 23);
|
||||||
|
this.uninstallButton.TabIndex = 10002;
|
||||||
|
this.uninstallButton.Text = "Uninstall";
|
||||||
|
this.uninstallButton.UseVisualStyleBackColor = true;
|
||||||
|
this.uninstallButton.Click += new System.EventHandler(this.OnUninstall);
|
||||||
|
//
|
||||||
// SelectForm
|
// SelectForm
|
||||||
//
|
//
|
||||||
this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
this.AutoScaleDimensions = new System.Drawing.SizeF(7F, 15F);
|
||||||
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
|
||||||
this.ClientSize = new System.Drawing.Size(584, 361);
|
this.ClientSize = new System.Drawing.Size(584, 361);
|
||||||
|
this.Controls.Add(this.uninstallButton);
|
||||||
this.Controls.Add(this.flowLayoutPanel1);
|
this.Controls.Add(this.flowLayoutPanel1);
|
||||||
this.Controls.Add(this.scanButton);
|
this.Controls.Add(this.scanButton);
|
||||||
this.Controls.Add(this.flowLayoutPanel2);
|
this.Controls.Add(this.flowLayoutPanel2);
|
||||||
|
@ -232,7 +246,7 @@ namespace CreamInstaller
|
||||||
this.Controls.Add(this.progressBar1);
|
this.Controls.Add(this.progressBar1);
|
||||||
this.Controls.Add(this.label1);
|
this.Controls.Add(this.label1);
|
||||||
this.Controls.Add(this.cancelButton);
|
this.Controls.Add(this.cancelButton);
|
||||||
this.Controls.Add(this.acceptButton);
|
this.Controls.Add(this.installButton);
|
||||||
this.Controls.Add(this.label2);
|
this.Controls.Add(this.label2);
|
||||||
this.DoubleBuffered = true;
|
this.DoubleBuffered = true;
|
||||||
this.MaximizeBox = false;
|
this.MaximizeBox = false;
|
||||||
|
@ -256,7 +270,7 @@ namespace CreamInstaller
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
private System.Windows.Forms.Button acceptButton;
|
private System.Windows.Forms.Button installButton;
|
||||||
private System.Windows.Forms.Button cancelButton;
|
private System.Windows.Forms.Button cancelButton;
|
||||||
private System.Windows.Forms.Label label1;
|
private System.Windows.Forms.Label label1;
|
||||||
private System.Windows.Forms.GroupBox groupBox1;
|
private System.Windows.Forms.GroupBox groupBox1;
|
||||||
|
@ -270,6 +284,7 @@ namespace CreamInstaller
|
||||||
private Button blockProtectedHelpButton;
|
private Button blockProtectedHelpButton;
|
||||||
private FlowLayoutPanel flowLayoutPanel1;
|
private FlowLayoutPanel flowLayoutPanel1;
|
||||||
private FlowLayoutPanel flowLayoutPanel2;
|
private FlowLayoutPanel flowLayoutPanel2;
|
||||||
|
private Button uninstallButton;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -412,7 +412,8 @@ namespace CreamInstaller
|
||||||
scanButton.Enabled = false;
|
scanButton.Enabled = false;
|
||||||
noneFoundLabel.Visible = false;
|
noneFoundLabel.Visible = false;
|
||||||
allCheckBox.Enabled = false;
|
allCheckBox.Enabled = false;
|
||||||
acceptButton.Enabled = false;
|
installButton.Enabled = false;
|
||||||
|
uninstallButton.Enabled = installButton.Enabled;
|
||||||
selectionTreeView.Enabled = false;
|
selectionTreeView.Enabled = false;
|
||||||
|
|
||||||
label2.Visible = true;
|
label2.Visible = true;
|
||||||
|
@ -503,7 +504,8 @@ namespace CreamInstaller
|
||||||
allCheckBox.Enabled = selectionTreeView.Enabled;
|
allCheckBox.Enabled = selectionTreeView.Enabled;
|
||||||
noneFoundLabel.Visible = !selectionTreeView.Enabled;
|
noneFoundLabel.Visible = !selectionTreeView.Enabled;
|
||||||
|
|
||||||
acceptButton.Enabled = ProgramSelection.AllSafeEnabled.Any();
|
installButton.Enabled = ProgramSelection.AllSafeEnabled.Any();
|
||||||
|
uninstallButton.Enabled = installButton.Enabled;
|
||||||
cancelButton.Enabled = false;
|
cancelButton.Enabled = false;
|
||||||
scanButton.Enabled = true;
|
scanButton.Enabled = true;
|
||||||
|
|
||||||
|
@ -575,7 +577,8 @@ namespace CreamInstaller
|
||||||
allCheckBox.Checked = treeNodes.TrueForAll(treeNode => treeNode.Checked);
|
allCheckBox.Checked = treeNodes.TrueForAll(treeNode => treeNode.Checked);
|
||||||
allCheckBox.CheckedChanged += OnAllCheckBoxChanged;
|
allCheckBox.CheckedChanged += OnAllCheckBoxChanged;
|
||||||
}
|
}
|
||||||
acceptButton.Enabled = ProgramSelection.AllSafeEnabled.Any();
|
installButton.Enabled = ProgramSelection.AllSafeEnabled.Any();
|
||||||
|
uninstallButton.Enabled = installButton.Enabled;
|
||||||
}
|
}
|
||||||
|
|
||||||
private class TreeNodeSorter : IComparer
|
private class TreeNodeSorter : IComparer
|
||||||
|
@ -686,7 +689,7 @@ namespace CreamInstaller
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnAccept(object sender, EventArgs e)
|
private void OnAccept(bool uninstall = false)
|
||||||
{
|
{
|
||||||
if (ProgramSelection.All.Count > 0)
|
if (ProgramSelection.All.Count > 0)
|
||||||
{
|
{
|
||||||
|
@ -704,7 +707,7 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
|
|
||||||
Hide();
|
Hide();
|
||||||
InstallForm installForm = new(this);
|
InstallForm installForm = new(this, uninstall);
|
||||||
installForm.ShowDialog();
|
installForm.ShowDialog();
|
||||||
if (installForm.Reselecting)
|
if (installForm.Reselecting)
|
||||||
{
|
{
|
||||||
|
@ -719,6 +722,16 @@ namespace CreamInstaller
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void OnInstall(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
OnAccept(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void OnUninstall(object sender, EventArgs e)
|
||||||
|
{
|
||||||
|
OnAccept(true);
|
||||||
|
}
|
||||||
|
|
||||||
private void OnScan(object sender, EventArgs e)
|
private void OnScan(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
OnLoad();
|
OnLoad();
|
||||||
|
|
Loading…
Reference in a new issue