2019-03-23 17:05:33 +00:00
|
|
|
using System;
|
2018-05-19 19:07:50 +00:00
|
|
|
using System.Collections.Generic;
|
|
|
|
|
2022-06-18 18:04:24 +00:00
|
|
|
namespace PKHeX.Core;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Generation 1 Evolution Branch Entries
|
|
|
|
/// </summary>
|
|
|
|
public static class EvolutionSet1
|
2018-05-19 19:07:50 +00:00
|
|
|
{
|
2022-06-18 18:04:24 +00:00
|
|
|
private static EvolutionMethod GetMethod(ReadOnlySpan<byte> data)
|
2018-05-19 19:07:50 +00:00
|
|
|
{
|
2022-06-18 18:04:24 +00:00
|
|
|
int method = data[0];
|
|
|
|
int species = data[1];
|
|
|
|
var arg = data[2];
|
2022-01-03 05:35:59 +00:00
|
|
|
|
2022-06-18 18:04:24 +00:00
|
|
|
return (method == 1)
|
|
|
|
? new EvolutionMethod(method, species, level: arg)
|
|
|
|
: new EvolutionMethod(method, species, argument: arg);
|
|
|
|
}
|
2018-09-15 05:37:47 +00:00
|
|
|
|
2022-06-18 18:04:24 +00:00
|
|
|
public static IReadOnlyList<EvolutionMethod[]> GetArray(ReadOnlySpan<byte> data, int maxSpecies)
|
|
|
|
{
|
|
|
|
var evos = new EvolutionMethod[maxSpecies + 1][];
|
|
|
|
int ofs = 0;
|
|
|
|
const int bpe = 3;
|
|
|
|
for (int i = 0; i < evos.Length; i++)
|
2018-05-19 19:07:50 +00:00
|
|
|
{
|
2022-06-18 18:04:24 +00:00
|
|
|
int count = data[ofs];
|
|
|
|
ofs++;
|
|
|
|
if (count == 0)
|
|
|
|
{
|
|
|
|
evos[i] = Array.Empty<EvolutionMethod>();
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
var m = new EvolutionMethod[count];
|
|
|
|
for (int j = 0; j < m.Length; j++)
|
2018-05-19 19:07:50 +00:00
|
|
|
{
|
2022-06-18 18:04:24 +00:00
|
|
|
m[j] = GetMethod(data.Slice(ofs, bpe));
|
|
|
|
ofs += bpe;
|
2018-05-19 19:07:50 +00:00
|
|
|
}
|
2022-06-18 18:04:24 +00:00
|
|
|
evos[i] = m;
|
2018-05-19 19:07:50 +00:00
|
|
|
}
|
2022-06-18 18:04:24 +00:00
|
|
|
return evos;
|
2018-05-19 19:07:50 +00:00
|
|
|
}
|
2022-01-03 05:35:59 +00:00
|
|
|
}
|