From 6a461554637f908522052c4af0c218046358060d Mon Sep 17 00:00:00 2001
From: Brett Hewitson
+ BUGFIX
+
CHANGE
diff --git a/src/ARKServerManager/VersionFeedBeta.xml b/src/ARKServerManager/VersionFeedBeta.xml
index 9a228082..afa85e96 100644
--- a/src/ARKServerManager/VersionFeedBeta.xml
+++ b/src/ARKServerManager/VersionFeedBeta.xml
@@ -7,6 +7,29 @@
+
+
+
+
CHANGE
diff --git a/src/ConanServerManager/App.xaml.cs b/src/ConanServerManager/App.xaml.cs
index 800b5408..495ec5b6 100644
--- a/src/ConanServerManager/App.xaml.cs
+++ b/src/ConanServerManager/App.xaml.cs
@@ -48,7 +48,45 @@ namespace ServerManagerTool
public App()
{
if (string.IsNullOrWhiteSpace(Config.Default.ServerManagerUniqueKey))
+ {
Config.Default.ServerManagerUniqueKey = Guid.NewGuid().ToString();
+ }
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.DataPath))
+ {
+ var root = Path.GetPathRoot(Config.Default.DataPath);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.DataPath = Config.Default.DataPath.Replace(root, root + "\\");
+ }
+ }
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.ConfigPath))
+ {
+ var root = Path.GetPathRoot(Config.Default.ConfigPath);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.ConfigPath = Config.Default.ConfigPath.Replace(root, root + "\\");
+ }
+ }
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.BackupPath))
+ {
+ var root = Path.GetPathRoot(Config.Default.BackupPath);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.BackupPath = Config.Default.BackupPath.Replace(root, root + "\\");
+ }
+ }
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.AutoUpdate_CacheDir))
+ {
+ var root = Path.GetPathRoot(Config.Default.AutoUpdate_CacheDir);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.AutoUpdate_CacheDir = Config.Default.AutoUpdate_CacheDir.Replace(root, root + "\\");
+ }
+ }
App.Instance = this;
ApplicationStarted = false;
diff --git a/src/ConanServerManager/UserControls/GlobalSettingsControl.xaml.cs b/src/ConanServerManager/UserControls/GlobalSettingsControl.xaml.cs
index dd9587f4..19119725 100644
--- a/src/ConanServerManager/UserControls/GlobalSettingsControl.xaml.cs
+++ b/src/ConanServerManager/UserControls/GlobalSettingsControl.xaml.cs
@@ -158,14 +158,24 @@ namespace ServerManagerTool
if (result == CommonFileDialogResult.Ok)
{
- if (!String.Equals(dialog.FileName, Config.Default.DataPath))
+ if (!string.Equals(dialog.FileName, Config.Default.DataPath))
{
try
{
+ var newDataDirectory = dialog.FileName;
+ if (!string.IsNullOrWhiteSpace(newDataDirectory))
+ {
+ var root = Path.GetPathRoot(newDataDirectory);
+ if (!root.EndsWith("\\"))
+ {
+ newDataDirectory = newDataDirectory.Replace(root, root + "\\");
+ }
+ }
+
// Set up the destination directories
- string newConfigDirectory = Path.Combine(dialog.FileName, Config.Default.ProfilesRelativePath);
+ string newConfigDirectory = Path.Combine(newDataDirectory, Config.Default.ProfilesRelativePath);
string oldSteamDirectory = Path.Combine(Config.Default.DataPath, CommonConfig.Default.SteamCmdRelativePath);
- string newSteamDirectory = Path.Combine(dialog.FileName, CommonConfig.Default.SteamCmdRelativePath);
+ string newSteamDirectory = Path.Combine(newDataDirectory, CommonConfig.Default.SteamCmdRelativePath);
Directory.CreateDirectory(newConfigDirectory);
Directory.CreateDirectory(newSteamDirectory);
@@ -199,7 +209,7 @@ namespace ServerManagerTool
Directory.Delete(oldSteamDirectory, true);
// Update the config
- Config.Default.DataPath = dialog.FileName;
+ Config.Default.DataPath = newDataDirectory;
Config.Default.ConfigPath = newConfigDirectory;
App.ReconfigureLogging();
}
@@ -238,9 +248,18 @@ namespace ServerManagerTool
if (result == CommonFileDialogResult.Ok)
{
- if (!String.Equals(dialog.FileName, Config.Default.BackupPath))
+ if (!string.Equals(dialog.FileName, Config.Default.BackupPath))
{
Config.Default.BackupPath = dialog.FileName;
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.BackupPath))
+ {
+ var root = Path.GetPathRoot(Config.Default.BackupPath);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.BackupPath = Config.Default.BackupPath.Replace(root, root + "\\");
+ }
+ }
}
}
}
@@ -260,9 +279,18 @@ namespace ServerManagerTool
if (result == CommonFileDialogResult.Ok)
{
- if (!String.Equals(dialog.FileName, Config.Default.AutoUpdate_CacheDir))
+ if (!string.Equals(dialog.FileName, Config.Default.AutoUpdate_CacheDir))
{
Config.Default.AutoUpdate_CacheDir = dialog.FileName;
+
+ if (!string.IsNullOrWhiteSpace(Config.Default.AutoUpdate_CacheDir))
+ {
+ var root = Path.GetPathRoot(Config.Default.AutoUpdate_CacheDir);
+ if (!root.EndsWith("\\"))
+ {
+ Config.Default.AutoUpdate_CacheDir = Config.Default.AutoUpdate_CacheDir.Replace(root, root + "\\");
+ }
+ }
}
}
}
diff --git a/src/ConanServerManager/VersionFeed.xml b/src/ConanServerManager/VersionFeed.xml
index 148a9292..748d1233 100644
--- a/src/ConanServerManager/VersionFeed.xml
+++ b/src/ConanServerManager/VersionFeed.xml
@@ -9,8 +9,8 @@
+ BUGFIX
+
+