PKHeX/PKHeX.Core/Legality/Structures/EggMoves.cs

82 lines
2.6 KiB
C#
Raw Normal View History

using System.IO;
using System.Linq;
namespace PKHeX.Core
{
public abstract class EggMoves
{
protected int Count;
public int[] Moves;
public int FormTableIndex;
public bool GetHasEggMove(int move) => Moves.Contains(move);
}
public class EggMoves2 : EggMoves
{
private EggMoves2(byte[] data)
{
Count = data.Length;
Moves = data.Select(i => (int) i).ToArray();
}
public static EggMoves[] GetArray(byte[] data, int count)
{
int[] ptrs = new int[count+1];
int baseOffset = (data[1] << 8 | data[0]) - count * 2;
for (int i = 1; i < ptrs.Length; i++)
ptrs[i] = (data[(i - 1)*2 + 1] << 8 | data[(i - 1)*2]) - baseOffset;
EggMoves[] entries = new EggMoves[count + 1];
entries[0] = new EggMoves2(new byte[0]);
for (int i = 1; i < entries.Length; i++)
entries[i] = new EggMoves2(data.Skip(ptrs[i]).TakeWhile(b => b != 0xFF).ToArray());
return entries;
}
}
public class EggMoves6 : EggMoves
{
private EggMoves6(byte[] data)
{
if (data.Length < 2 || data.Length % 2 != 0)
{ Count = 0; Moves = new int[0]; return; }
using (BinaryReader br = new BinaryReader(new MemoryStream(data)))
{
Moves = new int[Count = br.ReadUInt16()];
for (int i = 0; i < Count; i++)
Moves[i] = br.ReadUInt16();
}
}
public static EggMoves[] GetArray(byte[][] entries)
{
EggMoves[] data = new EggMoves[entries.Length];
for (int i = 0; i < data.Length; i++)
data[i] = new EggMoves6(entries[i]);
return data;
}
}
public class EggMoves7 : EggMoves
{
private EggMoves7(byte[] data)
{
if (data.Length < 2 || data.Length % 2 != 0)
{ Count = 0; Moves = new int[0]; return; }
using (BinaryReader br = new BinaryReader(new MemoryStream(data)))
{
FormTableIndex = br.ReadUInt16();
Count = br.ReadUInt16();
Moves = new int[Count];
for (int i = 0; i < Count; i++)
Moves[i] = br.ReadUInt16();
}
}
public static EggMoves[] GetArray(byte[][] entries)
{
EggMoves[] data = new EggMoves[entries.Length];
for (int i = 0; i < data.Length; i++)
data[i] = new EggMoves7(entries[i]);
return data;
}
}
}