PKHeX/PKHeX.Core/Legality/BulkGenerator.cs

69 lines
2.1 KiB
C#
Raw Normal View History

2020-03-20 20:33:15 +00:00
using System;
using System.Collections.Generic;
using System.Linq;
namespace PKHeX.Core
{
/// <summary>
/// Logic for generating a large amount of <see cref="PKM"/> data.
/// </summary>
public static class BulkGenerator
{
2020-03-20 20:33:15 +00:00
public static List<PKM> GetLivingDex(this SaveFile sav)
{
var speciesToGenerate = Enumerable.Range(1, sav.MaxSpeciesID);
2020-03-20 20:33:15 +00:00
return GetLivingDex(sav, speciesToGenerate);
}
2020-03-20 20:33:15 +00:00
private static List<PKM> GetLivingDex(SaveFile sav, IEnumerable<int> speciesToGenerate)
{
return sav.GetLivingDex(speciesToGenerate, sav.BlankPKM);
}
public static List<PKM> GetLivingDex(this ITrainerInfo tr, IEnumerable<int> speciesToGenerate, PKM blank)
{
var result = new List<PKM>();
var destType = blank.GetType();
foreach (var s in speciesToGenerate)
{
var pk = blank.Clone();
pk.Species = s;
pk.Gender = pk.GetSaneGender();
var pi = pk.PersonalInfo;
for (int f = 0; f < pi.FormCount; f++)
{
2020-03-20 20:33:15 +00:00
var entry = tr.GetLivingEntry(pk, s, f, destType);
if (entry == null)
continue;
2020-03-20 20:33:15 +00:00
result.Add(entry);
}
}
return result;
}
2020-03-20 20:33:15 +00:00
public static PKM? GetLivingEntry(this ITrainerInfo tr, PKM template, int species, int form, Type destType)
{
template.Species = species;
template.Form = form;
2020-03-20 20:33:15 +00:00
template.Gender = template.GetSaneGender();
var f = EncounterMovesetGenerator.GeneratePKMs(template, tr).FirstOrDefault();
if (f == null)
return null;
var result = PKMConverter.ConvertToType(f, destType, out _);
if (result == null)
return null;
result.Species = species;
result.Form = form;
result.CurrentLevel = 100;
2020-03-20 20:33:15 +00:00
result.Heal();
return result;
}
}
}