using System; using System.Collections.Generic; namespace PKHeX.Core { /// /// Generation 3 Evolution Branch Entries /// public sealed class EvolutionSet3 : EvolutionSet { private static EvolutionMethod GetMethod(byte[] data, int offset) { int method = BitConverter.ToUInt16(data, offset + 0); int arg = BitConverter.ToUInt16(data, offset + 2); int species = SpeciesConverter.GetG4Species(BitConverter.ToUInt16(data, offset + 4)); //2 bytes padding switch (method) { case 1: /* Friendship*/ case 2: /* Friendship day*/ case 3: /* Friendship night*/ case 5: /* Trade */ case 6: /* Trade while holding */ return new EvolutionMethod { Method = method, Species = species, Argument = arg }; case 4: /* Level Up */ return new EvolutionMethod { Method = 4, Species = species, Level = arg, Argument = arg }; case 7: /* Use item */ case 15: /* Beauty evolution*/ return new EvolutionMethod { Method = method + 1, Species = species, Argument = arg }; case 8: /* Tyrogue -> Hitmonchan */ case 9: /* Tyrogue -> Hitmonlee */ case 10: /* Tyrogue -> Hitmontop*/ case 11: /* Wurmple -> Silcoon evolution */ case 12: /* Wurmple -> Cascoon evolution */ case 13: /* Nincada -> Ninjask evolution */ case 14: /* Shedinja spawn in Nincada -> Ninjask evolution */ return new EvolutionMethod { Method = method + 1, Species = species, Level = arg, Argument = arg }; } throw new ArgumentException(nameof(method)); } private static readonly EvolutionSet Blank = new EvolutionSet3 { PossibleEvolutions = Array.Empty() }; public static IReadOnlyList GetArray(byte[] data) { var evos = new EvolutionSet[Legal.MaxSpeciesID_3 + 1]; evos[0] = Blank; for (int i = 1; i <= Legal.MaxSpeciesIndex_3; i++) { int g4species = SpeciesConverter.GetG4Species(i); if (g4species == 0) continue; const int maxCount = 5; const int size = 8; int offset = i * (maxCount * size); int count = 0; for (; count < maxCount; count++) { if (data[offset + (count * size)] == 0) break; } if (count == 0) { evos[g4species] = Blank; continue; } var set = new EvolutionMethod[count]; for (int j = 0; j < set.Length; j++) set[j] = GetMethod(data, offset + (j * size)); evos[g4species] = new EvolutionSet3 { PossibleEvolutions = set }; } return evos; } } }