using System.IO; using SabreTools.Data.Models.MSDOS; namespace SabreTools.Wrappers { public partial class MSDOS : WrapperBase { #region Descriptive Properties /// public override string DescriptionString => "MS-DOS Executable"; #endregion #region Constructors /// public MSDOS(Executable model, byte[] data) : base(model, data) { } /// public MSDOS(Executable model, byte[] data, int offset) : base(model, data, offset) { } /// public MSDOS(Executable model, byte[] data, int offset, int length) : base(model, data, offset, length) { } /// public MSDOS(Executable model, Stream data) : base(model, data) { } /// public MSDOS(Executable model, Stream data, long offset) : base(model, data, offset) { } /// public MSDOS(Executable model, Stream data, long offset, long length) : base(model, data, offset, length) { } #endregion #region Static Constructors /// /// Create an MS-DOS executable from a byte array and offset /// /// Byte array representing the executable /// Offset within the array to parse /// An MS-DOS executable wrapper on success, null on failure public static MSDOS? Create(byte[]? data, int offset) { // If the data is invalid if (data is null || data.Length == 0) return null; // If the offset is out of bounds if (offset < 0 || offset >= data.Length) return null; // Create a memory stream and use that var dataStream = new MemoryStream(data, offset, data.Length - offset); return Create(dataStream); } /// /// Create an MS-DOS executable from a Stream /// /// Stream representing the executable /// An MS-DOS executable wrapper on success, null on failure public static MSDOS? Create(Stream? data) { // If the data is invalid if (data is null || !data.CanRead) return null; try { // Cache the current offset long currentOffset = data.Position; var model = new Serialization.Readers.MSDOS().Deserialize(data); if (model is null) return null; return new MSDOS(model, data, currentOffset); } catch { return null; } } #endregion } }