mirror of
https://github.com/kwsch/PKHeX
synced 2025-01-10 19:48:53 +00:00
5e1fd36b96
If the feeling is zero the game's string formatter will treat it as null, and will newline before the period. Gen6 (if I recall correctly) had "it was happy" as index 0 Gen8 (new) has "it was happy" as index 1, with 0 being invalid-bad. Slice the array differently for gen8 to include the empty line as index 0. Closes #2549 , ty @crzyc && @architdate for testing index 0 :)
74 lines
3 KiB
C#
74 lines
3 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
|
|
namespace PKHeX.Core
|
|
{
|
|
public sealed class MemoryStrings
|
|
{
|
|
private readonly GameStrings s;
|
|
|
|
public MemoryStrings(GameStrings strings, int format)
|
|
{
|
|
s = strings;
|
|
memories = new Lazy<List<ComboItem>>(GetMemories);
|
|
none = new Lazy<List<ComboItem>>(() => Util.GetCBList(new[] {string.Empty}));
|
|
species = new Lazy<List<ComboItem>>(() => Util.GetCBList(s.specieslist));
|
|
item = new Lazy<List<ComboItem>>(() => GetItems(format));
|
|
genloc = new Lazy<List<ComboItem>>(() => Util.GetCBList(s.genloc));
|
|
moves = new Lazy<List<ComboItem>>(() => Util.GetCBList(s.movelist)); // Hyperspace Fury
|
|
specific = new Lazy<List<ComboItem>>(() => Util.GetCBList(s.metXY_00000, Legal.Met_XY_0));
|
|
}
|
|
|
|
private List<ComboItem> GetItems(int format)
|
|
{
|
|
var permit = format < 8 ? Legal.HeldItem_AO : Legal.HeldItem_AO.Concat(Legal.HeldItems_SWSH).Distinct();
|
|
var asInt = permit.Select(z => (int) z).ToArray();
|
|
return Util.GetCBList(s.itemlist, asInt);
|
|
}
|
|
|
|
private readonly Lazy<List<ComboItem>> memories;
|
|
private readonly Lazy<List<ComboItem>> none, species, item, genloc, moves, specific;
|
|
|
|
public List<ComboItem> Memory => memories.Value;
|
|
public List<ComboItem> None => none.Value;
|
|
public List<ComboItem> Moves => moves.Value;
|
|
public List<ComboItem> Items => item.Value;
|
|
public List<ComboItem> GeneralLocations => genloc.Value;
|
|
public List<ComboItem> SpecificLocations => specific.Value;
|
|
public List<ComboItem> Species => species.Value;
|
|
|
|
private List<ComboItem> GetMemories()
|
|
{
|
|
// Memory Chooser
|
|
int memorycount = s.memories.Length - 38;
|
|
string[] mems = new string[memorycount];
|
|
int[] allowed = new int[memorycount];
|
|
for (int i = 0; i < memorycount; i++)
|
|
{
|
|
mems[i] = s.memories[38 + i];
|
|
allowed[i] = i + 1;
|
|
}
|
|
Array.Resize(ref allowed, allowed.Length - 1);
|
|
var memory_list1 = Util.GetCBList(new[] { mems[0] });
|
|
Util.AddCBWithOffset(memory_list1, mems, 0, allowed);
|
|
return memory_list1;
|
|
}
|
|
|
|
public string[] GetMemoryQualities() => s.memories.Slice(2, 7);
|
|
public string[] GetMemoryFeelings(int format) => format >= 8 ? s.memories.Slice(9, 25) : s.memories.Slice(10, 24); // empty line for 0 in gen8+
|
|
|
|
public List<ComboItem> GetArgumentStrings(MemoryArgType memIndex)
|
|
{
|
|
return memIndex switch
|
|
{
|
|
MemoryArgType.Species => Species,
|
|
MemoryArgType.GeneralLocation => GeneralLocations,
|
|
MemoryArgType.Item => Items,
|
|
MemoryArgType.Move => Moves,
|
|
MemoryArgType.SpecificLocation => SpecificLocations,
|
|
_ => None
|
|
};
|
|
}
|
|
}
|
|
}
|