mirror of
https://github.com/kwsch/PKHeX
synced 2024-12-25 03:43:16 +00:00
55c7bf9858
EvolutionSet was just an object that hides an array, with no logic was planning to use the EvolutionSet to do the evolution checks, but EvolutionTree was required to connect the evolution chains together
79 lines
No EOL
3 KiB
C#
79 lines
No EOL
3 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
|
|
namespace PKHeX.Core
|
|
{
|
|
/// <summary>
|
|
/// Generation 3 Evolution Branch Entries
|
|
/// </summary>
|
|
public static class EvolutionSet3
|
|
{
|
|
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 };
|
|
|
|
default:
|
|
throw new ArgumentException(nameof(method));
|
|
}
|
|
}
|
|
|
|
public static IReadOnlyList<EvolutionMethod[]> GetArray(byte[] data)
|
|
{
|
|
var evos = new EvolutionMethod[Legal.MaxSpeciesID_3 + 1][];
|
|
evos[0] = Array.Empty<EvolutionMethod>();
|
|
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] = Array.Empty<EvolutionMethod>();
|
|
continue;
|
|
}
|
|
|
|
var set = new EvolutionMethod[count];
|
|
for (int j = 0; j < set.Length; j++)
|
|
set[j] = GetMethod(data, offset + (j * size));
|
|
evos[g4species] = set;
|
|
}
|
|
return evos;
|
|
}
|
|
}
|
|
} |