Relocate gen3 ereader berry logic

This commit is contained in:
Kurt 2020-07-18 22:51:55 -05:00
parent acd97c6287
commit e4092e64df
5 changed files with 97 additions and 38 deletions

View file

@ -390,11 +390,11 @@ namespace PKHeX.Core
case GameVersion.XD:
return g3xditems;
default:
if (Legal.EReaderBerryIsEnigma)
if (EReaderBerrySettings.IsEnigma)
return g3items;
var g3ItemsWithEBerry = (string[])g3items.Clone();
g3ItemsWithEBerry[175] = Legal.EReaderBerryDisplayName;
g3ItemsWithEBerry[175] = EReaderBerrySettings.DisplayName;
return g3ItemsWithEBerry;
}
}

View file

@ -6,15 +6,6 @@ namespace PKHeX.Core
{
public static partial class Legal
{
/// <summary> e-Reader Berry is Enigma or special berry </summary>
public static bool EReaderBerryIsEnigma { get; set; } = true;
/// <summary> e-Reader Berry Name </summary>
public static string EReaderBerryName { get; set; } = string.Empty;
/// <summary> e-Reader Berry Name formatted in Title Case </summary>
public static string EReaderBerryDisplayName => string.Format(LegalityCheckStrings.L_XEnigmaBerry_0, Util.ToTitleCase(EReaderBerryName.ToLower()));
// Gen 1
internal static readonly Learnset[] LevelUpRB = LearnsetReader.GetArray(Util.GetBinaryResource("lvlmove_rb.pkl"), MaxSpeciesID_1);
internal static readonly Learnset[] LevelUpY = LearnsetReader.GetArray(Util.GetBinaryResource("lvlmove_y.pkl"), MaxSpeciesID_1);
@ -220,7 +211,7 @@ namespace PKHeX.Core
return pkm.AltForm == 1;
if (pkm.Species == (int)Species.Lycanroc)
return pkm.AltForm < 3;
return pkm.Species == 773;
return pkm.Species == (int)Species.Silvally;
}
internal static bool IsEvolutionValid(PKM pkm, int minSpecies = -1, int minLevel = -1)

View file

@ -24,29 +24,22 @@ namespace PKHeX.Core
private void VerifyEReaderBerry(LegalityAnalysis data)
{
if (Legal.EReaderBerryIsEnigma) // no E-Reader berry data provided, can't hold berry.
{
data.AddLine(GetInvalid(LItemUnreleased));
return;
var status = EReaderBerrySettings.GetStatus();
var chk = GetEReaderCheckResult(status);
if (chk != null)
data.AddLine(chk);
}
var matchUSA = Legal.EReaderBerriesNames_USA.Contains(Legal.EReaderBerryName);
var matchJP = Legal.EReaderBerriesNames_JP.Contains(Legal.EReaderBerryName);
if (!matchJP && !matchUSA) // Does not match any released E-Reader berry
private CheckResult? GetEReaderCheckResult(EReaderBerryMatch status)
{
data.AddLine(GetInvalid(LEReaderInvalid));
return;
}
if (ParseSettings.ActiveTrainer.Language <= 0)
return;
bool jp = ParseSettings.ActiveTrainer.Language == 1;
if (matchJP == jp)
return; // matches
// E-Reader is region locked
var msg = matchUSA ? LEReaderAmerica : LEReaderJapan;
data.AddLine(GetInvalid(msg));
return status switch
{
EReaderBerryMatch.NoMatch => GetInvalid(LEReaderInvalid),
EReaderBerryMatch.NoData => GetInvalid(LItemUnreleased),
EReaderBerryMatch.InvalidUSA => GetInvalid(LEReaderAmerica),
EReaderBerryMatch.InvalidJPN => GetInvalid(LEReaderJapan),
_ => null
};
}
}
}

View file

@ -0,0 +1,78 @@
using static PKHeX.Core.EReaderBerryMatch;
namespace PKHeX.Core
{
/// <summary>
/// Stores details about the Gen3 e-Reader Berry values.
/// </summary>
public static class EReaderBerrySettings
{
/// <summary> e-Reader Berry is Enigma or special berry (from e-Reader data)</summary>
public static bool IsEnigma { get; set; } = true;
/// <summary> e-Reader Berry Name </summary>
private static string Name { get; set; } = string.Empty;
/// <summary> e-Reader Berry Name formatted in Title Case </summary>
public static string DisplayName => string.Format(LegalityCheckStrings.L_XEnigmaBerry_0, Util.ToTitleCase(Name));
private static int Language { get; set; }
public static EReaderBerryMatch GetStatus()
{
if (IsEnigma) // no e-Reader Berry data provided, can't hold berry.
return NoData;
var matchUSA = Legal.EReaderBerriesNames_USA.Contains(Name);
if (matchUSA)
{
if (Language <= 0)
return ValidAny;
if (Language != 1)
return ValidUSA;
return InvalidUSA;
}
var matchJP = Legal.EReaderBerriesNames_JP.Contains(Name);
if (matchJP)
{
if (Language <= 0)
return ValidAny;
if (Language == 1)
return ValidJPN;
return InvalidJPN;
}
return NoMatch;
}
public static void LoadFrom(SAV3 sav3)
{
IsEnigma = sav3.IsEBerryIsEnigma;
Name = sav3.EBerryName;
Language = sav3.Japanese ? (int)LanguageID.Japanese : (int)LanguageID.English;
}
}
/// <summary>
/// For use in validating the current e-Reader Berry settings.
/// </summary>
public enum EReaderBerryMatch : byte
{
/// <summary> Invalid: Doesn't match either language </summary>
NoMatch,
/// <summary> Invalid: No data provided from a save file </summary>
NoData,
/// <summary> Invalid: USA berry name on JPN save file </summary>
InvalidUSA,
/// <summary> Invalid: JPN berry name on USA save file</summary>
InvalidJPN,
/// <summary> Valid: Berry name matches either USA/JPN (Ambiguous Save File Language) </summary>
ValidAny,
/// <summary> Valid: Berry name matches a USA berry name </summary>
ValidUSA,
/// <summary> Valid: Berry name matches a JPN berry name </summary>
ValidJPN,
}
}

View file

@ -707,10 +707,7 @@ namespace PKHeX.WinForms
private static void StoreLegalSaveGameData(SaveFile sav)
{
if (sav is SAV3 sav3)
{
Legal.EReaderBerryIsEnigma = sav3.IsEBerryIsEnigma;
Legal.EReaderBerryName = sav3.EBerryName;
}
EReaderBerrySettings.LoadFrom(sav3);
}
private bool OpenSAV(SaveFile sav, string path)