remove vestigial crap from FileSystem
This commit is contained in:
@@ -9,38 +9,10 @@ namespace OpenRa.FileFormats
|
||||
public static class FileSystem
|
||||
{
|
||||
static List<IFolder> mountedFolders = new List<IFolder>();
|
||||
static List<IFolder> temporaryMounts = new List<IFolder>();
|
||||
|
||||
static Cache<uint, List<IFolder>> allFiles = new Cache<uint, List<IFolder>>( _ => new List<IFolder>() );
|
||||
static Cache<uint, List<IFolder>> allTemporaryFiles = new Cache<uint, List<IFolder>>( _ => new List<IFolder>() );
|
||||
|
||||
public static void MountDefaultPackages()
|
||||
{
|
||||
FileSystem.Mount(new Folder("./"));
|
||||
if( FileSystem.Exists( "main.mix" ) )
|
||||
FileSystem.Mount( new Package( "main.mix" ) );
|
||||
FileSystem.Mount( new Package( "redalert.mix" ) );
|
||||
FileSystem.Mount( new Package( "conquer.mix" ) );
|
||||
FileSystem.Mount( new Package( "hires.mix" ) );
|
||||
FileSystem.Mount( new Package( "general.mix" ) );
|
||||
FileSystem.Mount( new Package( "local.mix" ) );
|
||||
FileSystem.Mount( new Package( "sounds.mix" ) );
|
||||
FileSystem.Mount( new Package( "speech.mix" ) );
|
||||
FileSystem.Mount( new Package( "allies.mix" ) );
|
||||
FileSystem.Mount( new Package( "russian.mix" ) );
|
||||
|
||||
FileSystem.Mount( new Package( "temperat.mix" ) );
|
||||
FileSystem.Mount( new Package( "snow.mix" ) );
|
||||
FileSystem.Mount( new Package( "interior.mix" ) );
|
||||
}
|
||||
|
||||
public static void MountAftermathPackages()
|
||||
{
|
||||
FileSystem.Mount( new Package( "expand2.mix" ) );
|
||||
FileSystem.Mount( new Package( "hires1.mix" ) );
|
||||
}
|
||||
|
||||
public static void Mount(IFolder folder)
|
||||
static void MountInner(IFolder folder)
|
||||
{
|
||||
mountedFolders.Add(folder);
|
||||
|
||||
@@ -52,28 +24,15 @@ namespace OpenRa.FileFormats
|
||||
}
|
||||
}
|
||||
|
||||
public static void MountTemporary(IFolder folder)
|
||||
{
|
||||
mountedFolders.Add(folder);
|
||||
temporaryMounts.Add(folder);
|
||||
|
||||
foreach( var hash in folder.AllFileHashes() )
|
||||
{
|
||||
var l = allTemporaryFiles[hash];
|
||||
if( !l.Contains( folder ) )
|
||||
l.Add( folder );
|
||||
}
|
||||
}
|
||||
|
||||
public static void MountTemporaryEx(string name)
|
||||
public static void Mount(string name)
|
||||
{
|
||||
name = name.ToLowerInvariant();
|
||||
var optional = name.StartsWith("~");
|
||||
if (optional) name = name.Substring(1);
|
||||
|
||||
var a = name.EndsWith(".mix")
|
||||
? (Action)(() => FileSystem.MountTemporary(new Package(name)))
|
||||
: () => FileSystem.MountTemporary(new Folder(name));
|
||||
? (Action)(() => FileSystem.MountInner(new Package(name)))
|
||||
: () => FileSystem.MountInner(new Folder(name));
|
||||
|
||||
if (optional)
|
||||
try { a(); }
|
||||
@@ -82,12 +41,10 @@ namespace OpenRa.FileFormats
|
||||
a();
|
||||
}
|
||||
|
||||
public static void UnmountTemporaryPackages()
|
||||
public static void UnmountAll()
|
||||
{
|
||||
mountedFolders.RemoveAll(f => temporaryMounts.Contains(f));
|
||||
temporaryMounts.Clear();
|
||||
|
||||
allTemporaryFiles = new Cache<uint, List<IFolder>>( _ => new List<IFolder>() );
|
||||
mountedFolders.Clear();
|
||||
allFiles = new Cache<uint, List<IFolder>>( _ => new List<IFolder>() );
|
||||
}
|
||||
|
||||
static Stream GetFromCache( Cache<uint, List<IFolder>> index, string filename )
|
||||
@@ -105,8 +62,7 @@ namespace OpenRa.FileFormats
|
||||
{
|
||||
if( filename.IndexOfAny( new char[] { '/', '\\' } ) == -1 )
|
||||
{
|
||||
var ret = GetFromCache( allFiles, filename )
|
||||
?? GetFromCache( allTemporaryFiles, filename );
|
||||
var ret = GetFromCache( allFiles, filename );
|
||||
if( ret != null )
|
||||
return ret;
|
||||
}
|
||||
@@ -127,8 +83,7 @@ namespace OpenRa.FileFormats
|
||||
{
|
||||
foreach( var ext in exts )
|
||||
{
|
||||
var s = GetFromCache( allFiles, filename + ext )
|
||||
?? GetFromCache( allTemporaryFiles, filename + ext );
|
||||
var s = GetFromCache( allFiles, filename + ext );
|
||||
if( s != null )
|
||||
return s;
|
||||
}
|
||||
|
||||
@@ -37,11 +37,11 @@ namespace OpenRa
|
||||
|
||||
public static void LoadModPackages(Manifest manifest)
|
||||
{
|
||||
FileSystem.UnmountTemporaryPackages();
|
||||
FileSystem.UnmountAll();
|
||||
Timer.Time("reset: {0}");
|
||||
|
||||
foreach (var dir in manifest.Folders) FileSystem.MountTemporaryEx(dir);
|
||||
foreach (var pkg in manifest.Packages) FileSystem.MountTemporaryEx(pkg);
|
||||
foreach (var dir in manifest.Folders) FileSystem.Mount(dir);
|
||||
foreach (var pkg in manifest.Packages) FileSystem.Mount(pkg);
|
||||
|
||||
Timer.Time("mount temporary packages: {0}");
|
||||
}
|
||||
|
||||
@@ -74,11 +74,11 @@ namespace OpenRa
|
||||
{
|
||||
Game.Settings = new UserSettings();
|
||||
var settingsFile = settings.GetValue("settings", "settings.ini");
|
||||
FileSystem.MountTemporary(new Folder("./"));
|
||||
FileSystem.Mount("./");
|
||||
if (FileSystem.Exists(settingsFile))
|
||||
FieldLoader.Load(Game.Settings,
|
||||
new IniFile(FileSystem.Open(settingsFile)).GetSection("Settings"));
|
||||
FileSystem.UnmountTemporaryPackages();
|
||||
FileSystem.UnmountAll();
|
||||
}
|
||||
|
||||
internal void Run()
|
||||
|
||||
@@ -79,8 +79,8 @@ namespace SequenceEditor
|
||||
var mods = args[0].Split(',');
|
||||
var manifest = new Manifest(mods);
|
||||
|
||||
foreach (var folder in manifest.Folders) FileSystem.MountTemporaryEx(folder);
|
||||
foreach (var pkg in manifest.Packages) FileSystem.MountTemporaryEx(pkg);
|
||||
foreach (var folder in manifest.Folders) FileSystem.Mount(folder);
|
||||
foreach (var pkg in manifest.Packages) FileSystem.Mount(pkg);
|
||||
|
||||
XmlFilename = args[1];
|
||||
Doc = new XmlDocument();
|
||||
|
||||
Reference in New Issue
Block a user