Revert "Broken changes"

This reverts commit 42af88374e.
This commit is contained in:
shadowninja108 2018-12-25 23:05:54 -07:00
parent 42af88374e
commit 148f641d30
3 changed files with 24 additions and 42 deletions

View file

@ -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;
}
}
} }
} }

View file

@ -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;

View file

@ -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();