mirror of
https://github.com/Thealexbarney/LibHac.git
synced 2024-11-14 10:49:41 +01:00
parent
42af88374e
commit
148f641d30
3 changed files with 24 additions and 42 deletions
|
@ -50,10 +50,10 @@ namespace LibHac
|
||||||
|
|
||||||
public abstract class IFileSytemEntry
|
public abstract class IFileSytemEntry
|
||||||
{
|
{
|
||||||
public abstract IFileSystem FileSystem { get; protected set; }
|
public abstract IFileSystem FileSystem { get; }
|
||||||
public abstract string Path { get; protected set; }
|
public abstract string Path { get; }
|
||||||
public virtual string Name => System.IO.Path.GetFileName(Path);
|
public virtual string Name => System.IO.Path.GetFileName(Path);
|
||||||
public virtual bool Exists { get; protected set; }
|
public abstract bool Exists { get; }
|
||||||
|
|
||||||
public IDirectory Parent
|
public IDirectory Parent
|
||||||
{
|
{
|
||||||
|
@ -68,18 +68,19 @@ namespace LibHac
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract class IDirectory : IFileSytemEntry
|
public class IDirectory : IFileSytemEntry
|
||||||
{
|
{
|
||||||
public override IFileSystem FileSystem { get; protected set; }
|
public override IFileSystem FileSystem { get; }
|
||||||
public override string Path { get; protected set; }
|
public override string Path { get; }
|
||||||
public override bool Exists => FileSystem.DirectoryExists(this);
|
public override bool Exists => FileSystem.DirectoryExists(this);
|
||||||
|
|
||||||
public IFile[] Files => FileSystem.GetFiles(this);
|
public IFile[] Files => FileSystem.GetFiles(this);
|
||||||
public IDirectory[] Directories => FileSystem.GetDirectories(this);
|
public IDirectory[] Directories => FileSystem.GetDirectories(this);
|
||||||
|
|
||||||
public IDirectory(IFileSystem filesystem)
|
public IDirectory(IFileSystem filesystem, string path)
|
||||||
{
|
{
|
||||||
FileSystem = filesystem;
|
FileSystem = filesystem;
|
||||||
|
Path = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IFile GetFile(string path)
|
public IFile GetFile(string path)
|
||||||
|
@ -103,27 +104,20 @@ namespace LibHac
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public class Directory : IDirectory
|
|
||||||
{
|
|
||||||
public Directory(IFileSystem fileSystem, string path) : base(fileSystem)
|
|
||||||
{
|
|
||||||
Path = path;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public class IFile : IFileSytemEntry
|
public class IFile : IFileSytemEntry
|
||||||
{
|
{
|
||||||
public override IFileSystem FileSystem { get; protected set; }
|
public override IFileSystem FileSystem { get; }
|
||||||
public override string Path { get; protected set; }
|
public override string Path { get; }
|
||||||
public override bool Exists => FileSystem.FileExists(this);
|
public override bool Exists => FileSystem.FileExists(this);
|
||||||
|
|
||||||
public string Extension => System.IO.Path.GetExtension(Path);
|
public string Extension => System.IO.Path.GetExtension(Path);
|
||||||
public string FileName => System.IO.Path.GetFileName(Path);
|
public string FileName => System.IO.Path.GetFileName(Path);
|
||||||
public long Length => FileSystem.GetSize(this);
|
public long Length => FileSystem.GetSize(this);
|
||||||
|
|
||||||
public IFile(IFileSystem filesystem)
|
public IFile(IFileSystem filesystem, string path)
|
||||||
{
|
{
|
||||||
FileSystem = filesystem;
|
FileSystem = filesystem;
|
||||||
|
Path = path;
|
||||||
}
|
}
|
||||||
|
|
||||||
public IStorage Open(FileMode mode)
|
public IStorage Open(FileMode mode)
|
||||||
|
@ -146,13 +140,5 @@ namespace LibHac
|
||||||
{
|
{
|
||||||
return base.GetHashCode();
|
return base.GetHashCode();
|
||||||
}
|
}
|
||||||
|
|
||||||
public class File : IFile
|
|
||||||
{
|
|
||||||
public File(IFileSystem fileSystem, string path) : base(fileSystem)
|
|
||||||
{
|
|
||||||
Path = path;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,10 +6,8 @@ using LibHac.IO;
|
||||||
|
|
||||||
namespace LibHac
|
namespace LibHac
|
||||||
{
|
{
|
||||||
public class Romfs : IFileSystem
|
public class Romfs
|
||||||
{
|
{
|
||||||
public const string Delimiter = "/";
|
|
||||||
public new string PathSeperator = Romfs.Delimiter;
|
|
||||||
public const int IvfcMaxLevel = 6;
|
public const int IvfcMaxLevel = 6;
|
||||||
public RomfsHeader Header { get; }
|
public RomfsHeader Header { get; }
|
||||||
public List<RomfsDir> Directories { get; } = new List<RomfsDir>();
|
public List<RomfsDir> Directories { get; } = new List<RomfsDir>();
|
||||||
|
@ -39,7 +37,7 @@ namespace LibHac
|
||||||
int position = 0;
|
int position = 0;
|
||||||
while (position + 20 < Header.DirMetaTableSize)
|
while (position + 20 < Header.DirMetaTableSize)
|
||||||
{
|
{
|
||||||
var dir = new RomfsDir(reader, this) { Offset = position };
|
var dir = new RomfsDir(reader) { Offset = position };
|
||||||
Directories.Add(dir);
|
Directories.Add(dir);
|
||||||
if (dir.ParentDirOffset == position) RootDir = dir;
|
if (dir.ParentDirOffset == position) RootDir = dir;
|
||||||
position = (int)reader.BaseStream.Position;
|
position = (int)reader.BaseStream.Position;
|
||||||
|
|
|
@ -5,31 +5,30 @@ using System.Text;
|
||||||
|
|
||||||
namespace LibHac
|
namespace LibHac
|
||||||
{
|
{
|
||||||
public abstract class RomfsEntry : IFileSytemEntry
|
public abstract class RomfsEntry
|
||||||
{
|
{
|
||||||
private const string PathSeperator = "/";
|
|
||||||
public int Offset { get; set; }
|
public int Offset { get; set; }
|
||||||
public int ParentDirOffset { get; protected set; }
|
public int ParentDirOffset { get; protected set; }
|
||||||
public int NameLength { get; protected set; }
|
public int NameLength { get; protected set; }
|
||||||
public new string Name { get; protected set; }
|
public string Name { get; protected set; }
|
||||||
|
|
||||||
public new IDirectory Parent { get; internal set; }
|
public RomfsDir ParentDir { get; internal set; }
|
||||||
public override string Path { get; protected set; }
|
public string FullPath { get; private set; }
|
||||||
|
|
||||||
internal static void ResolveFilenames(IEnumerable<RomfsEntry> entries)
|
internal static void ResolveFilenames(IEnumerable<RomfsEntry> entries)
|
||||||
{
|
{
|
||||||
var list = new List<string>();
|
var list = new List<string>();
|
||||||
var sb = new StringBuilder();
|
var sb = new StringBuilder();
|
||||||
const string delimiter = RomfsEntry.PathSeperator;
|
const string delimiter = "/";
|
||||||
foreach (RomfsEntry file in entries)
|
foreach (RomfsEntry file in entries)
|
||||||
{
|
{
|
||||||
list.Add(file.Name);
|
list.Add(file.Name);
|
||||||
RomfsDir dir = file.Parent as RomfsDir;
|
RomfsDir dir = file.ParentDir;
|
||||||
while (dir != null)
|
while (dir != null)
|
||||||
{
|
{
|
||||||
list.Add(delimiter);
|
list.Add(delimiter);
|
||||||
list.Add(dir.Name);
|
list.Add(dir.Name);
|
||||||
dir = dir.Parent as RomfsDir;
|
dir = dir.ParentDir;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = list.Count - 1; i >= 0; i--)
|
for (int i = list.Count - 1; i >= 0; i--)
|
||||||
|
@ -37,7 +36,7 @@ namespace LibHac
|
||||||
sb.Append(list[i]);
|
sb.Append(list[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
file.Path = sb.ToString();
|
file.FullPath = sb.ToString();
|
||||||
list.Clear();
|
list.Clear();
|
||||||
sb.Clear();
|
sb.Clear();
|
||||||
}
|
}
|
||||||
|
@ -45,7 +44,7 @@ namespace LibHac
|
||||||
}
|
}
|
||||||
|
|
||||||
[DebuggerDisplay("{" + nameof(Name) + "}")]
|
[DebuggerDisplay("{" + nameof(Name) + "}")]
|
||||||
public class RomfsDir : Directory
|
public class RomfsDir : RomfsEntry
|
||||||
{
|
{
|
||||||
public int NextSiblingOffset { get; }
|
public int NextSiblingOffset { get; }
|
||||||
public int FirstChildOffset { get; }
|
public int FirstChildOffset { get; }
|
||||||
|
@ -57,9 +56,8 @@ namespace LibHac
|
||||||
public RomfsFile FirstFile { get; internal set; }
|
public RomfsFile FirstFile { get; internal set; }
|
||||||
public RomfsDir NextDirHash { get; internal set; }
|
public RomfsDir NextDirHash { get; internal set; }
|
||||||
|
|
||||||
public RomfsDir(BinaryReader reader, IFileSystem fs) : base(fs)
|
public RomfsDir(BinaryReader reader)
|
||||||
{
|
{
|
||||||
FileSystem = fs;
|
|
||||||
ParentDirOffset = reader.ReadInt32();
|
ParentDirOffset = reader.ReadInt32();
|
||||||
NextSiblingOffset = reader.ReadInt32();
|
NextSiblingOffset = reader.ReadInt32();
|
||||||
FirstChildOffset = reader.ReadInt32();
|
FirstChildOffset = reader.ReadInt32();
|
||||||
|
|
Loading…
Reference in a new issue