summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--docs/release-notes.md6
-rw-r--r--src/SMAPI.Mods.ConsoleCommands/Framework/ItemRepository.cs62
2 files changed, 52 insertions, 16 deletions
diff --git a/docs/release-notes.md b/docs/release-notes.md
index f45df4bd..f1911716 100644
--- a/docs/release-notes.md
+++ b/docs/release-notes.md
@@ -2,7 +2,11 @@
# Release notes
## Upcoming release
-* Improved translations. Thanks to ChulkyBow (updated Ukrainian)!
+* For players:
+ * Improved translations. Thanks to ChulkyBow (updated Ukrainian)!
+
+* For console commands:
+ * Fixed `player_add` with Journal Scraps and Secret Notes.
## 3.13.4
Released 16 January 2022 for Stardew Valley 1.5.6 or later.
diff --git a/src/SMAPI.Mods.ConsoleCommands/Framework/ItemRepository.cs b/src/SMAPI.Mods.ConsoleCommands/Framework/ItemRepository.cs
index 4a57ba5a..8704a403 100644
--- a/src/SMAPI.Mods.ConsoleCommands/Framework/ItemRepository.cs
+++ b/src/SMAPI.Mods.ConsoleCommands/Framework/ItemRepository.cs
@@ -134,24 +134,34 @@ namespace StardewModdingAPI.Mods.ConsoleCommands.Framework
{
string[] fields = Game1.objectInformation[id]?.Split('/');
- // secret notes
- if (id == 79)
+ // ring
+ if (id != 801 && fields?.Length >= 4 && fields[3] == "Ring") // 801 = wedding ring, which isn't an equippable ring
+ {
+ if (ShouldGet(ItemType.Ring))
+ yield return this.TryCreate(ItemType.Ring, id, p => new Ring(p.ID));
+ }
+
+ // journal scrap
+ else if (id == 842)
{
if (ShouldGet(ItemType.Object))
{
- foreach (SearchableItem secretNote in this.GetSecretNotes())
- yield return secretNote;
+ foreach (SearchableItem journalScrap in this.GetSecretNotes(isJournalScrap: true))
+ yield return journalScrap;
}
}
- // ring
- else if (id != 801 && fields?.Length >= 4 && fields[3] == "Ring") // 801 = wedding ring, which isn't an equippable ring
+ // secret notes
+ else if (id == 79)
{
- if (ShouldGet(ItemType.Ring))
- yield return this.TryCreate(ItemType.Ring, id, p => new Ring(p.ID));
+ if (ShouldGet(ItemType.Object))
+ {
+ foreach (SearchableItem secretNote in this.GetSecretNotes(isJournalScrap: false))
+ yield return secretNote;
+ }
}
- // item
+ // object
else if (ShouldGet(ItemType.Object))
{
// spawn main item
@@ -184,16 +194,38 @@ namespace StardewModdingAPI.Mods.ConsoleCommands.Framework
/*********
** Private methods
*********/
- /// <summary>Get the individual secret note items, if any.</summary>
+ /// <summary>Get the individual secret note or journal scrap items.</summary>
+ /// <param name="isJournalScrap">Whether to get journal scraps.</param>
/// <remarks>Derived from <see cref="GameLocation.tryToCreateUnseenSecretNote"/>.</remarks>
- private IEnumerable<SearchableItem> GetSecretNotes()
+ private IEnumerable<SearchableItem> GetSecretNotes(bool isJournalScrap)
{
- foreach (int secretNoteId in this.TryLoad<int, string>("Data\\SecretNotes").Keys)
+ // get base item ID
+ int baseId = isJournalScrap ? 842 : 79;
+
+ // get secret note IDs
+ var ids = this
+ .TryLoad<int, string>("Data\\SecretNotes")
+ .Keys
+ .Where(isJournalScrap
+ ? id => (id >= GameLocation.JOURNAL_INDEX)
+ : id => (id < GameLocation.JOURNAL_INDEX)
+ )
+ .Select<int, int>(isJournalScrap
+ ? id => (id - GameLocation.JOURNAL_INDEX)
+ : id => id
+ );
+
+ // build items
+ foreach (int id in ids)
{
- yield return this.TryCreate(ItemType.Object, this.CustomIDOffset + secretNoteId, _ =>
+ int fakeId = this.CustomIDOffset * 8 + id;
+ if (isJournalScrap)
+ fakeId += GameLocation.JOURNAL_INDEX;
+
+ yield return this.TryCreate(ItemType.Object, fakeId, _ =>
{
- SObject note = new(79, 1);
- note.name = $"{note.name} #{secretNoteId}";
+ SObject note = new(baseId, 1);
+ note.Name = $"{note.Name} #{id}";
return note;
});
}