diff --git a/BizHawk.Client.Common/PathManager.cs b/BizHawk.Client.Common/PathManager.cs index 9bfedbaac2..8d9c1050e6 100644 --- a/BizHawk.Client.Common/PathManager.cs +++ b/BizHawk.Client.Common/PathManager.cs @@ -11,11 +11,12 @@ namespace BizHawk.Client.Common { public static string GetExeDirectoryAbsolute() { - string path = Path.GetDirectoryName(Assembly.GetEntryAssembly().Location); + var path = Path.GetDirectoryName(Assembly.GetEntryAssembly().Location); if (path.EndsWith(Path.DirectorySeparatorChar.ToString())) { path = path.Remove(path.Length - 1, 1); } + return path; } @@ -41,35 +42,41 @@ namespace BizHawk.Client.Common /// public static string GetBasePathAbsolute() { - if (Global.Config.PathEntries.GlobalBaseFragment.Length < 1) //If empty, then EXE path + if (Global.Config.PathEntries.GlobalBaseFragment.Length < 1) // If empty, then EXE path + { return GetExeDirectoryAbsolute(); + } - if (Global.Config.PathEntries.GlobalBaseFragment.Length >= 5 && - Global.Config.PathEntries.GlobalBaseFragment.Substring(0, 5) == "%exe%") + if (Global.Config.PathEntries.GlobalBaseFragment.Length >= 5 + && Global.Config.PathEntries.GlobalBaseFragment.Substring(0, 5) == "%exe%") + { return GetExeDirectoryAbsolute(); + } + if (Global.Config.PathEntries.GlobalBaseFragment[0] == '.') { if (Global.Config.PathEntries.GlobalBaseFragment.Length == 1) - return GetExeDirectoryAbsolute(); - else { - if (Global.Config.PathEntries.GlobalBaseFragment.Length == 2 && - Global.Config.PathEntries.GlobalBaseFragment == ".\\") - return GetExeDirectoryAbsolute(); - else - { - string tmp = Global.Config.PathEntries.GlobalBaseFragment; - tmp = tmp.Remove(0, 1); - tmp = tmp.Insert(0, GetExeDirectoryAbsolute()); - return tmp; - } + return GetExeDirectoryAbsolute(); } + + if (Global.Config.PathEntries.GlobalBaseFragment.Length == 2 && + Global.Config.PathEntries.GlobalBaseFragment == ".\\") + { + return GetExeDirectoryAbsolute(); + } + + var tmp = Global.Config.PathEntries.GlobalBaseFragment.Remove(0, 1); + tmp = tmp.Insert(0, GetExeDirectoryAbsolute()); + return tmp; } if (Global.Config.PathEntries.GlobalBaseFragment.Substring(0, 2) == "..") + { return RemoveParents(Global.Config.PathEntries.GlobalBaseFragment, GetExeDirectoryAbsolute()); + } - //In case of error, return EXE path + // In case of error, return EXE path return GetExeDirectoryAbsolute(); } @@ -85,16 +92,18 @@ namespace BizHawk.Client.Common public static string MakeAbsolutePath(string path, string system) { - //Hack + // Hack if (system == "Global") { system = null; } - //This function translates relative path and special identifiers in absolute paths + // This function translates relative path and special identifiers in absolute paths if (path.Length < 1) + { return GetBasePathAbsolute(); + } if (path == "%recent%") { @@ -104,62 +113,63 @@ namespace BizHawk.Client.Common if (path.Length >= 5 && path.Substring(0, 5) == "%exe%") { if (path.Length == 5) - return GetExeDirectoryAbsolute(); - else { - string tmp = path.Remove(0, 5); - tmp = tmp.Insert(0, GetExeDirectoryAbsolute()); - return tmp; + return GetExeDirectoryAbsolute(); } + + var tmp = path.Remove(0, 5); + tmp = tmp.Insert(0, GetExeDirectoryAbsolute()); + return tmp; } if (path[0] == '.') { - if (!String.IsNullOrWhiteSpace(system)) + if (!string.IsNullOrWhiteSpace(system)) { - path = path.Remove(0, 1); path = path.Insert(0, GetPlatformBase(system)); } - if (path.Length == 1) - return GetBasePathAbsolute(); - else - { - if (path[0] == '.') - { - path = path.Remove(0, 1); - path = path.Insert(0, GetBasePathAbsolute()); - } - return path; + if (path.Length == 1) + { + return GetBasePathAbsolute(); } + + if (path[0] == '.') + { + path = path.Remove(0, 1); + path = path.Insert(0, GetBasePathAbsolute()); + } + + return path; } - //If begins wtih .. do alorithm to determine how many ..\.. combos and deal with accordingly, return drive letter only if too many .. - + // If begins wtih .. do alorithm to determine how many ..\.. combos and deal with accordingly, return drive letter only if too many .. if ((path[0] > 'A' && path[0] < 'Z') || (path[0] > 'a' && path[0] < 'z')) { - //C:\ + // C:\ if (path.Length > 2 && path[1] == ':' && path[2] == '\\') - return path; - else { - //file:\ is an acceptable path as well, and what FileBrowserDialog returns - if (path.Length >= 6 && path.Substring(0, 6) == "file:\\") - return path; - else - return GetExeDirectoryAbsolute(); //bad path + return path; } + + // file:\ is an acceptable path as well, and what FileBrowserDialog returns + if (path.Length >= 6 && path.Substring(0, 6) == "file:\\") + { + return path; + } + + return GetExeDirectoryAbsolute(); // bad path } - //all pad paths default to EXE + // all pad paths default to EXE return GetExeDirectoryAbsolute(); } public static string RemoveParents(string path, string workingpath) { - //determines number of parents, then removes directories from working path, return absolute path result - //Ex: "..\..\Bob\", "C:\Projects\Emulators\Bizhawk" will return "C:\Projects\Bob\" + // determines number of parents, then removes directories from working path, return absolute path result + // Ex: "..\..\Bob\", "C:\Projects\Emulators\Bizhawk" will return "C:\Projects\Bob\" int x = NumParentDirectories(path); if (x > 0) { @@ -169,19 +179,22 @@ namespace BizHawk.Client.Common { //Return drive letter only, working path must be absolute? } - return ""; + + return string.Empty; } - else return path; + + return path; } public static int NumParentDirectories(string path) { - //determine the number of parent directories in path and return result + // determine the number of parent directories in path and return result int x = StringHelpers.HowMany(path, '\\'); if (x > 0) { return StringHelpers.HowMany(path, "..\\"); } + return 0; } @@ -202,79 +215,80 @@ namespace BizHawk.Client.Common return Environment.SpecialFolder.Recent.ToString(); } - PathEntry path = Global.Config.PathEntries[sysID, "ROM"] ?? Global.Config.PathEntries[sysID, "Base"]; + var path = Global.Config.PathEntries[sysID, "ROM"] ?? Global.Config.PathEntries[sysID, "Base"]; return MakeAbsolutePath(path.Path, sysID); } public static string RemoveInvalidFileSystemChars(string name) { - string newStr = name; - char[] chars = Path.GetInvalidFileNameChars(); - return chars.Aggregate(newStr, (current, c) => current.Replace(c.ToString(), "")); + var newStr = name; + var chars = Path.GetInvalidFileNameChars(); + return chars.Aggregate(newStr, (current, c) => current.Replace(c.ToString(), string.Empty)); } public static string FilesystemSafeName(GameInfo game) { - string filesystemSafeName = game.Name.Replace("|", "+"); + var filesystemSafeName = game.Name.Replace("|", "+"); filesystemSafeName = RemoveInvalidFileSystemChars(filesystemSafeName); - //zero 22-jul-2012 - i dont think this is used the same way it used to. game.Name shouldnt be a path, so this stuff is illogical. - //if game.Name is a path, then someone shouldve made it not-a-path already. - //return Path.Combine(Path.GetDirectoryName(filesystemSafeName), Path.GetFileNameWithoutExtension(filesystemSafeName)); + + // zero 22-jul-2012 - i dont think this is used the same way it used to. game.Name shouldnt be a path, so this stuff is illogical. + // if game.Name is a path, then someone shouldve made it not-a-path already. + // return Path.Combine(Path.GetDirectoryName(filesystemSafeName), Path.GetFileNameWithoutExtension(filesystemSafeName)); return filesystemSafeName; } public static string SaveRamPath(GameInfo game) { - string name = FilesystemSafeName(game); + var name = FilesystemSafeName(game); if (Global.MovieSession.Movie.IsActive) { name += "." + Path.GetFileNameWithoutExtension(Global.MovieSession.Movie.Filename); } - PathEntry pathEntry = Global.Config.PathEntries[game.System, "Save RAM"] ?? - Global.Config.PathEntries[game.System, "Base"]; + var pathEntry = Global.Config.PathEntries[game.System, "Save RAM"] ?? + Global.Config.PathEntries[game.System, "Base"]; return Path.Combine(MakeAbsolutePath(pathEntry.Path, game.System), name) + ".SaveRAM"; } public static string GetSaveStatePath(GameInfo game) { - PathEntry pathEntry = Global.Config.PathEntries[game.System, "Savestates"] ?? - Global.Config.PathEntries[game.System, "Base"]; + var pathEntry = Global.Config.PathEntries[game.System, "Savestates"] ?? + Global.Config.PathEntries[game.System, "Base"]; return MakeAbsolutePath(pathEntry.Path, game.System); } public static string SaveStatePrefix(GameInfo game) { - string name = FilesystemSafeName(game); + var name = FilesystemSafeName(game); if (Global.MovieSession.Movie.IsActive) { name += "." + Path.GetFileNameWithoutExtension(Global.MovieSession.Movie.Filename); } - PathEntry pathEntry = Global.Config.PathEntries[game.System, "Savestates"] ?? - Global.Config.PathEntries[game.System, "Base"]; + var pathEntry = Global.Config.PathEntries[game.System, "Savestates"] ?? + Global.Config.PathEntries[game.System, "Base"]; return Path.Combine(MakeAbsolutePath(pathEntry.Path, game.System), name); } public static string GetCheatsPath(GameInfo game) { - PathEntry pathEntry = Global.Config.PathEntries[game.System, "Cheats"] ?? - Global.Config.PathEntries[game.System, "Base"]; + var pathEntry = Global.Config.PathEntries[game.System, "Cheats"] ?? + Global.Config.PathEntries[game.System, "Base"]; return MakeAbsolutePath(pathEntry.Path, game.System); } public static string ScreenshotPrefix(GameInfo game) { - string name = FilesystemSafeName(game); + var name = FilesystemSafeName(game); - PathEntry pathEntry = Global.Config.PathEntries[game.System, "Screenshots"] ?? - Global.Config.PathEntries[game.System, "Base"]; + var pathEntry = Global.Config.PathEntries[game.System, "Screenshots"] ?? + Global.Config.PathEntries[game.System, "Base"]; return Path.Combine(MakeAbsolutePath(pathEntry.Path, game.System), name); } @@ -283,29 +297,21 @@ namespace BizHawk.Client.Common /// Takes an absolute path and attempts to convert it to a relative, based on the system, /// or global base if no system is supplied, if it is not a subfolder of the base, it will return the path unaltered /// - /// + /// /// /// - public static string TryMakeRelative(string absolute_path, string system = null) + public static string TryMakeRelative(string absolutePath, string system = null) { - string parent_path; - if (String.IsNullOrWhiteSpace(system)) - { - parent_path = GetBasePathAbsolute(); - } - else - { - parent_path = MakeAbsolutePath(GetPlatformBase(system), system); - } + var parentPath = string.IsNullOrWhiteSpace(system) ? + GetBasePathAbsolute() : + MakeAbsolutePath(GetPlatformBase(system), system); - if (IsSubfolder(parent_path, absolute_path)) + if (IsSubfolder(parentPath, absolutePath)) { - return absolute_path.Replace(parent_path, "."); - } - else - { - return absolute_path; + return absolutePath.Replace(parentPath, "."); } + + return absolutePath; } //http://stackoverflow.com/questions/3525775/how-to-check-if-directory-1-is-a-subdirectory-of-dir2-and-vice-versa