public static byte[] Compress(Stream input, Method method) { if (input.Length > 0xffffff) { throw new Exception("File too big to be compressed with Nintendo compression!"); } var res = new List <byte>(); res.AddRange(new[] { (byte)method, (byte)(input.Length & 0xff), (byte)((input.Length >> 8) & 0xff), (byte)((input.Length >> 16) & 0xff) }); switch (method) { case Method.LZ10: res.AddRange(LZ10.Compress(input)); return(res.ToArray()); case Method.LZ11: res.AddRange(LZ11.Compress(input)); return(res.ToArray()); case Method.Huff4: res.AddRange(Huffman.Compress(input, 4, ByteOrder.BigEndian)); return(res.ToArray()); case Method.Huff8: res.AddRange(Huffman.Compress(input, 8)); return(res.ToArray()); case Method.RLE: res.AddRange(RLE.Compress(input)); return(res.ToArray()); case Method.LZ60: throw new Exception("LZ60 isn't implemented yet"); //return LZ60.Compress(input); default: return(input.StructToBytes()); } }
public static byte[] Decompress(Stream input) { using (var br = new BinaryReaderX(input, true)) { var methodSize = br.ReadUInt32(); var method = (Method)(methodSize & 0xff); var size = (int)((methodSize & 0xffffff00) >> 8); using (var brB = new BinaryReaderX(new MemoryStream(br.ReadBytes((int)input.Length - 4)))) { switch (method) { case Method.LZ10: return(LZ10.Decompress(brB.BaseStream, size)); case Method.LZ11: return(LZ11.Decompress(brB.BaseStream, size)); case Method.Huff4: return(Huffman.Decompress(brB.BaseStream, 4, size, ByteOrder.BigEndian)); case Method.Huff8: return(Huffman.Decompress(brB.BaseStream, 8, size)); case Method.RLE: return(RLE.Decompress(brB.BaseStream, size)); case Method.LZ60: throw new Exception("LZ60 isn't implemented yet"); //return LZ60.Decompress(brB.BaseStream); default: br.BaseStream.Position -= 4; return(br.BaseStream.StructToBytes()); } } } }