mirror of
https://github.com/kwsch/PKHeX
synced 2025-02-17 05:48:44 +00:00
* Heavily rewrites the `PKH` abstractions. * Uses HOME's core-side classes as the transfer middlemen instead of direct A->B transfers. * Revises logic to account for most of HOME's quirks (scale/height copying, safe refuge PLA) Future revisions hinge on better handling of evotree (need better metadata about existing as specific evolutions in each game). --------- Co-authored-by: sora10pls <17801814+sora10pls@users.noreply.github.com> Co-authored-by: Lusamine <30205550+Lusamine@users.noreply.github.com>
156 lines
4.6 KiB
C#
156 lines
4.6 KiB
C#
namespace PKHeX.Core;
|
|
|
|
/// <summary>
|
|
/// Minimal Trainer Information necessary for generating a <see cref="PKM"/>.
|
|
/// </summary>
|
|
public interface ITrainerInfo : ITrainerID32
|
|
{
|
|
string OT { get; }
|
|
int Gender { get; }
|
|
int Game { get; }
|
|
int Language { get; }
|
|
|
|
int Generation { get; }
|
|
EntityContext Context { get; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Extension methods for <see cref="ITrainerInfo"/>.
|
|
/// </summary>
|
|
public static class TrainerInfoExtensions
|
|
{
|
|
/// <summary>
|
|
/// Copies the <see cref="ITrainerInfo"/> data to the <see cref="PKM"/> object.
|
|
/// </summary>
|
|
/// <param name="info">Trainer Information</param>
|
|
/// <param name="pk">Pokémon to copy to</param>
|
|
public static void ApplyTo(this ITrainerInfo info, PKM pk)
|
|
{
|
|
pk.OT_Name = info.OT;
|
|
pk.TID16 = info.TID16;
|
|
pk.SID16 = pk.Format < 3 || pk.VC ? (ushort)0 : info.SID16;
|
|
pk.OT_Gender = info.Gender;
|
|
pk.Language = info.Language;
|
|
pk.Version = info.Game;
|
|
|
|
if (pk is not IRegionOrigin tr)
|
|
return;
|
|
|
|
if (info is not IRegionOrigin o)
|
|
return;
|
|
tr.Country = o.Country;
|
|
tr.Region = o.Region;
|
|
tr.ConsoleRegion = o.ConsoleRegion;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Copies the <see cref="ITrainerInfo"/> data to the <see cref="PKM"/> object's Handling Trainer data.
|
|
/// </summary>
|
|
/// <param name="sav">Trainer Information</param>
|
|
/// <param name="pk">Pokémon to copy to</param>
|
|
/// <param name="force">If true, will overwrite the Handling Trainer Data even if it has not been traded.</param>
|
|
public static void ApplyHandlingTrainerInfo(this ITrainerInfo sav, PKM pk, bool force = false)
|
|
{
|
|
if (pk.Format == sav.Generation && !force)
|
|
return;
|
|
|
|
pk.HT_Name = sav.OT;
|
|
pk.HT_Gender = sav.Gender;
|
|
pk.HT_Friendship = pk.OT_Friendship;
|
|
pk.CurrentHandler = 1;
|
|
if (pk is IHandlerLanguage h)
|
|
h.HT_Language = (byte)sav.Language;
|
|
|
|
if (pk is PK6 pk6 && sav is IRegionOrigin o)
|
|
{
|
|
pk6.Geo1_Country = o.Country;
|
|
pk6.Geo1_Region = o.Region;
|
|
pk6.SetTradeMemoryHT6(true);
|
|
}
|
|
else if (pk is PK8 pk8)
|
|
{
|
|
pk8.SetTradeMemoryHT8();
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Checks if the <see cref="ITrainerInfo"/> data matches the <see cref="PKM"/> object's Original Trainer data.
|
|
/// </summary>
|
|
/// <param name="tr">Trainer Information</param>
|
|
/// <param name="pk">Pokémon to compare to</param>
|
|
/// <returns>True if the data matches.</returns>
|
|
public static bool IsFromTrainer(this ITrainerInfo tr, PKM pk)
|
|
{
|
|
if (pk.IsEgg)
|
|
return tr.IsFromTrainerEgg(pk);
|
|
|
|
if (tr.Game == (int)GameVersion.Any)
|
|
return true;
|
|
|
|
if (!IsFromTrainerNoVersion(tr, pk))
|
|
return false;
|
|
|
|
return IsMatchVersion(tr, pk);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Checks if the <see cref="ITrainerInfo"/> data matches the <see cref="PKM"/> object's Original Trainer data, ignoring the version.
|
|
/// </summary>
|
|
/// <param name="tr">Trainer Information</param>
|
|
/// <param name="pk">Pokémon to compare to</param>
|
|
/// <returns>True if the data matches.</returns>
|
|
public static bool IsFromTrainerNoVersion(ITrainerInfo tr, PKM pk)
|
|
{
|
|
if (tr.ID32 != pk.ID32)
|
|
return false;
|
|
if (tr.OT != pk.OT_Name)
|
|
return false;
|
|
|
|
if (pk.Format == 3)
|
|
return true; // Generation 3 does not check ot gender nor pokemon version
|
|
|
|
if (tr.Gender != pk.OT_Gender)
|
|
{
|
|
if (pk.Format == 2)
|
|
return pk is ICaughtData2 { CaughtData: 0 };
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Only call this if it is still an egg.
|
|
/// </summary>
|
|
public static bool IsFromTrainerEgg(this ITrainerInfo tr, PKM pk)
|
|
{
|
|
System.Diagnostics.Debug.Assert(pk.IsEgg);
|
|
|
|
if (tr.Context != pk.Context)
|
|
return false;
|
|
if (tr.ID32 != pk.ID32)
|
|
return false;
|
|
if (tr.Gender != pk.OT_Gender)
|
|
return false;
|
|
|
|
if (tr.Game != pk.Version)
|
|
{
|
|
// PK9 does not store version for Picnic eggs.
|
|
if (pk is PK9 { Version: 0 }) { }
|
|
else { return false; }
|
|
}
|
|
|
|
if (tr.OT != pk.OT_Name)
|
|
return false;
|
|
|
|
return true;
|
|
}
|
|
|
|
private static bool IsMatchVersion(ITrainerInfo tr, PKM pk)
|
|
{
|
|
if (tr.Game == pk.Version)
|
|
return true;
|
|
if (pk.GO_LGPE)
|
|
return tr.Game is (int)GameVersion.GP or (int)GameVersion.GE;
|
|
return false;
|
|
}
|
|
}
|