namespace PKHeX.Core;
public static class EntityFileNamer
{
///
/// Object that converts the data into a file name.
///
public static IFileNamer Namer { get; set; } = new DefaultEntityNamer();
///
/// Gets the file name (without extension) for the input data.
///
/// Input entity to create a file name for.
/// File name for the data
public static string GetName(PKM pk) => Namer.GetName(pk);
}
///
/// PKHeX's default file naming logic.
///
public sealed class DefaultEntityNamer : IFileNamer
{
public string GetName(PKM obj)
{
if (obj is GBPKM gb)
return GetGBPKM(gb);
return GetRegular(obj);
}
private static string GetRegular(PKM pk)
{
string form = pk.Form > 0 ? $"-{pk.Form:00}" : string.Empty;
string star = pk.IsShiny ? " ★" : string.Empty;
var chk = pk is ISanityChecksum s ? s.Checksum : PokeCrypto.GetCHK(pk.Data, pk.SIZE_STORED);
return $"{pk.Species:000}{form}{star} - {pk.Nickname} - {chk:X4}{pk.EncryptionConstant:X8}";
}
private static string GetGBPKM(GBPKM gb)
{
string form = gb.Form > 0 ? $"-{gb.Form:00}" : string.Empty;
string star = gb.IsShiny ? " ★" : string.Empty;
var raw = gb switch
{
PK1 pk1 => new PokeList1(pk1).Write(),
PK2 pk2 => new PokeList2(pk2).Write(),
_ => gb.Data,
};
var checksum = Checksums.CRC16_CCITT(raw);
return $"{gb.Species:000}{form}{star} - {gb.Nickname} - {checksum:X4}";
}
}
///
/// Exposes a method to get a file name (no extension) for the type.
///
/// Type that the implementer can create a file name for.
public interface IFileNamer
{
string GetName(T obj);
}