Roblox-File-Format/RobloxFile.cs

100 lines
3.1 KiB
C#
Raw Normal View History

using System;
using System.IO;
using System.Text;
using System.Threading.Tasks;
using RobloxFiles.BinaryFormat;
using RobloxFiles.XmlFormat;
namespace RobloxFiles
{
/// <summary>
/// Represents a loaded *.rbxl/*.rbxm Roblox file.
/// The contents of the RobloxFile are stored as its children.
/// </summary>
2019-05-19 04:44:51 +00:00
public abstract class RobloxFile : Instance
{
2019-05-19 04:44:51 +00:00
protected abstract void ReadFile(byte[] buffer);
public abstract void Save(Stream stream);
/// <summary>
2019-05-19 04:44:51 +00:00
/// Opens a RobloxFile using the provided buffer.
/// </summary>
2019-05-19 04:44:51 +00:00
public static RobloxFile Open(byte[] buffer)
{
2019-05-19 04:44:51 +00:00
if (buffer.Length > 14)
{
2019-05-19 04:44:51 +00:00
string header = Encoding.UTF7.GetString(buffer, 0, 14);
RobloxFile file = null;
2019-05-19 04:44:51 +00:00
if (header == BinaryRobloxFile.MagicHeader)
file = new BinaryRobloxFile();
else if (header.StartsWith("<roblox"))
file = new XmlRobloxFile();
2019-05-19 04:44:51 +00:00
if (file != null)
{
file.ReadFile(buffer);
return file;
}
}
2019-05-19 04:44:51 +00:00
throw new Exception("Unrecognized header!");
}
2019-05-19 04:44:51 +00:00
/// <summary>
/// Opens a Roblox file by reading from a provided Stream.
/// </summary>
/// <param name="stream">The stream to read the Roblox file from.</param>
public static RobloxFile Open(Stream stream)
{
byte[] buffer;
using (MemoryStream memoryStream = new MemoryStream())
{
stream.CopyTo(memoryStream);
buffer = memoryStream.ToArray();
}
return Open(buffer);
}
/// <summary>
/// Opens a Roblox file from a provided file path.
/// </summary>
/// <param name="filePath">A path to a Roblox file to be opened.</param>
public static RobloxFile Open(string filePath)
{
byte[] buffer = File.ReadAllBytes(filePath);
return Open(buffer);
}
/// <summary>
/// Creates and runs a Task to open a Roblox file from a byte sequence that represents the file.
/// </summary>
/// <param name="buffer">A byte sequence that represents the file.</param>
public static Task<RobloxFile> OpenAsync(byte[] buffer)
{
return Task.Run(() => Open(buffer));
}
/// <summary>
/// Creates and runs a Task to open a Roblox file using a provided Stream.
/// </summary>
/// <param name="stream">The stream to read the Roblox file from.</param>
public static Task<RobloxFile> OpenAsync(Stream stream)
{
return Task.Run(() => Open(stream));
}
/// <summary>
/// Opens a Roblox file from a provided file path.
/// </summary>
/// <param name="filePath">A path to a Roblox file to be opened.</param>
public static Task<RobloxFile> OpenAsync(string filePath)
{
return Task.Run(() => Open(filePath));
}
}
}