From a5104f6647a13ff78bff9b4f8aaaab31f3cee31c Mon Sep 17 00:00:00 2001 From: Tacoman369 <90735287+Tacoman369@users.noreply.github.com> Date: Sun, 11 Feb 2024 15:38:30 -0600 Subject: [PATCH 1/3] Spoiler Log Update Creates new spoiler log function that marks all locations for an item as obtained when obtaining an item that can be obtained in multiple spots/ways --- code/include/rnd/spoiler_data.h | 1 + code/source/rnd/spoiler_data.cpp | 502 ++++++++++++++++++++++++++++++- 2 files changed, 502 insertions(+), 1 deletion(-) diff --git a/code/include/rnd/spoiler_data.h b/code/include/rnd/spoiler_data.h index 4cfefc9c..492c4223 100644 --- a/code/include/rnd/spoiler_data.h +++ b/code/include/rnd/spoiler_data.h @@ -140,6 +140,7 @@ namespace rnd { u8 SpoilerData_MagicBeansCheck(SpoilerItemLocation itemLoc); u8 SpoilerData_GetIsItemLocationRevealed(u16 itemIndex); u8 SpoilerLog_UpdateIngameLog(ItemOverride_Type type, u8 scene, u8 flag); + u8 SpoilerLog_CheckMultiLocationItems(ItemOverride_Type type, u8 scene, u8 flag); } // namespace rnd #endif // _RND_SPOILER_DATA_H_ \ No newline at end of file diff --git a/code/source/rnd/spoiler_data.cpp b/code/source/rnd/spoiler_data.cpp index 641e4c83..af8e13fe 100644 --- a/code/source/rnd/spoiler_data.cpp +++ b/code/source/rnd/spoiler_data.cpp @@ -47,9 +47,509 @@ namespace rnd { gExtSaveData.itemCollected[i] = 1; } } + SpoilerLog_CheckMultiLocationItems(type, scene, flag); + return -1; + } + u8 SpoilerLog_CheckMultiLocationItems(ItemOverride_Type type, u8 scene, u8 flag) { + //#if defined ENABLE_DEBUG || defined DEBUG_PRINT + // rnd::util::Print( + // "%s: CheckMultiLocationItems passed values:\nActor Type %d\nScene: %d\nFlag: %d\n", + // __func__, type, scene, flag); + //#endif + //#if defined ENABLE_DEBUG || defined DEBUG_PRINT + // rnd::util::Print("%s: passed the scene check for %d\n", __func__,scene); + //#endif + + //Koume in Potion Shop > Koume in Woods + if ((scene == 0x0A) && (flag == 0x59) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x64 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Koume in Woods > Koume in Potion Shop + if ((scene == 0x64) && (flag == 0x59) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x0A && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SCT Postbox > NCT & ECT Postboxes + if ((scene == 0x6F) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6C && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //NCT Postbox > SCT & ECT Postboxes + if ((scene == 0x6E) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6F && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6C && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //ECT Postbox > NCT & SCT Postboxes + if ((scene == 0x6C) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6F && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //NCT Tingle Clocktown Map > Ikana Tingle Clocktown Map + if ((scene == 0x6E) && (flag == 0xB4) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x13 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Ikana Tingle Clocktown Map > NCT Tingle Clocktown Map + if ((scene == 0x13) && (flag == 0xB4) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //NCT Tingle Woodfall Map > Woodfall Tingle Woodfall Map + if ((scene == 0x6E) && (flag == 0xB5) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Woodfall Tingle Woodfall Map > NCT Tingle Woodfall Map + if ((scene == 0x40) && (flag == 0xB5) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Woodfall Tingle Snowhead Map > Snowhead Tingle Snowhead Map (winter) + if ((scene == 0x40) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Woodfall Tingle Snowhead Map > Snowhead Tingle Snowhead Map (Spring) + if ((scene == 0x40) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Snowhead Map (Winter) > Woodfall Tingle Snowhead Map + if ((scene == 0x5D) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Snowhead Map (Spring) > Woodfall Tingle Snowhead Map + if ((scene == 0x5E) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Snowhead Map (Winter) > Snowhead Tingle Snowhead Map (Spring) + if ((scene == 0x5D) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Snowhead Map (Spring) > Snowhead Tingle Snowhead Map (Winter) + if ((scene == 0x5E) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Ranch Map (Winter) > Ranch Tingle Ranch Map + if ((scene == 0x5D) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Snowhead Tingle Ranch Map (Spring) > Ranch Tingle Ranch Map + if ((scene == 0x5E) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Ranch Tingle Ranch Map > Snowhead Tingle Snowhead Map (Winter) + if ((scene == 0x22) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Ranch Tingle Ranch Map > Snowhead Tingle Snowhead Map (Spring) + if ((scene == 0x22) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Ranch Tingle Great Bay Map > Great Bay Tingle Great Bay Map + if ((scene == 0x22) && (flag == 0xB8) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x37 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Great Bay Tingle Great Bay Map > Ranch Tingle Great Bay Map + if ((scene == 0x37) && (flag == 0xB8) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Great Bay Tingle Stone Tower Map > Stone Tower Tingle Stone Tower Map + if ((scene == 0x37) && (flag == 0xB9) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x13 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //Stone Tower Tingle Stone Tower Map > Great Bay Tingle Stone Tower Map + if ((scene == 0x13) && (flag == 0xB9) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x37 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //NCT Keaton > MR Keaton & MV Keaton + if ((scene == 0x6E) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5A && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //MR Keaton > NCT Keaton & MV Keaton + if ((scene == 0x22) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x5A && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //MV Keaton > MR Keaton & NCT Keaton + if ((scene == 0x5A) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Powder Keg Challenge (Winter) > GV Powder Keg Challenge (Spring) + if ((scene == 0x4D) && (flag == 0x34) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Powder Keg Challenge (Spring) > GV Powder Keg Challenge (Winter) + if ((scene == 0x48) && (flag == 0x34) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Deku Merchant Purchase (Winter) > GV Deku Merchant Purchase(Spring) + if ((scene == 0x4D) && (flag == 0x1D) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Deku Merchant Purchase (Spring) > GV Deku Merchant Purchase(Winter) + if ((scene == 0x48) && (flag == 0x1D) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Deku Merchant Trade (Winter) > GV Deku Merchant Trade(Spring) + if ((scene == 0x4D) && (flag == 0x99) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Deku Merchant Trade (Spring) > GV Deku Merchant Trade(Winter) + if ((scene == 0x48) && (flag == 0x99) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Ledge Heart Piece (Winter) > GV Ledge Heart Piece (Spring) + if ((scene == 0x4D) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //GV Ledge Heart Piece (Spring) > GV Ledge Heart Piece(Winter) + if ((scene == 0x48) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Deku Merchant Purchase (Poison) > SS Deku Merchant Purchase(Clear) + if ((scene == 0x45) && (flag == 0x35) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Deku Merchant Purchase (Clear) > SS Deku Merchant Purchase(Poison) + if ((scene == 0x00) && (flag == 0x35) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Deku Merchant Trade (Poison) > SS Deku Merchant Trade (Clear) + if ((scene == 0x45) && (flag == 0x98) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Deku Merchant Trade (Clear) > SS Deku Merchant Trade (Poison) + if ((scene == 0x00) && (flag == 0x98) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Tourist Center Roof HP (Poison) > SS Tourist Center Roof HP (Clear) + if ((scene == 0x45) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } + //SS Tourist Center Roof HP (Clear) > SS Tourist Center Roof HP (Poison) + if ((scene == 0x00) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && + gSpoilerData.ItemLocations[i].LocationFlag == flag) { + gSpoilerData.ItemLocations[i].Collected = true; + // Since it's not saved here, we need to return + gExtSaveData.itemCollected[i] = 1; + } + } + } return -1; } - u8 SpoilerData_CollectableCheck(SpoilerItemLocation itemLoc) { // TODO: Implement Collectable Checking. no need to use bits as we have // builtin BitField classes. From 29476c855c7ffdee166e862a3d59a5834d335c34 Mon Sep 17 00:00:00 2001 From: Tacoman369 <90735287+Tacoman369@users.noreply.github.com> Date: Mon, 12 Feb 2024 16:40:25 -0600 Subject: [PATCH 2/3] Spoiler Update 1 Makes code less derpy --- code/include/rnd/spoiler_data.h | 1 + code/source/rnd/spoiler_data.cpp | 417 ++++--------------------------- 2 files changed, 54 insertions(+), 364 deletions(-) diff --git a/code/include/rnd/spoiler_data.h b/code/include/rnd/spoiler_data.h index 492c4223..b467bca6 100644 --- a/code/include/rnd/spoiler_data.h +++ b/code/include/rnd/spoiler_data.h @@ -141,6 +141,7 @@ namespace rnd { u8 SpoilerData_GetIsItemLocationRevealed(u16 itemIndex); u8 SpoilerLog_UpdateIngameLog(ItemOverride_Type type, u8 scene, u8 flag); u8 SpoilerLog_CheckMultiLocationItems(ItemOverride_Type type, u8 scene, u8 flag); + void SpoilerData_UpdateMultiLocations(ItemOverride_Type type, u8 newScene, u8 flag); } // namespace rnd #endif // _RND_SPOILER_DATA_H_ \ No newline at end of file diff --git a/code/source/rnd/spoiler_data.cpp b/code/source/rnd/spoiler_data.cpp index af8e13fe..ed6ff1b1 100644 --- a/code/source/rnd/spoiler_data.cpp +++ b/code/source/rnd/spoiler_data.cpp @@ -62,493 +62,182 @@ namespace rnd { //Koume in Potion Shop > Koume in Woods if ((scene == 0x0A) && (flag == 0x59) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x64 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x64, flag); } //Koume in Woods > Koume in Potion Shop if ((scene == 0x64) && (flag == 0x59) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x0A && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x0A, flag); } //SCT Postbox > NCT & ECT Postboxes if ((scene == 0x6F) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6C && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); + SpoilerData_UpdateMultiLocations(type, 0x6C, flag); } //NCT Postbox > SCT & ECT Postboxes if ((scene == 0x6E) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6F && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6C && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6F, flag); + SpoilerData_UpdateMultiLocations(type, 0x6C, flag); } //ECT Postbox > NCT & SCT Postboxes if ((scene == 0x6C) && (flag == 0xBA) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6F && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); + SpoilerData_UpdateMultiLocations(type, 0x6F, flag); } //NCT Tingle Clocktown Map > Ikana Tingle Clocktown Map if ((scene == 0x6E) && (flag == 0xB4) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x13 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x13, flag); } //Ikana Tingle Clocktown Map > NCT Tingle Clocktown Map if ((scene == 0x13) && (flag == 0xB4) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); } //NCT Tingle Woodfall Map > Woodfall Tingle Woodfall Map if ((scene == 0x6E) && (flag == 0xB5) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x40, flag); } //Woodfall Tingle Woodfall Map > NCT Tingle Woodfall Map if ((scene == 0x40) && (flag == 0xB5) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); } //Woodfall Tingle Snowhead Map > Snowhead Tingle Snowhead Map (winter) if ((scene == 0x40) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5D, flag); } //Woodfall Tingle Snowhead Map > Snowhead Tingle Snowhead Map (Spring) if ((scene == 0x40) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5E, flag); } //Snowhead Tingle Snowhead Map (Winter) > Woodfall Tingle Snowhead Map if ((scene == 0x5D) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x40, flag); } //Snowhead Tingle Snowhead Map (Spring) > Woodfall Tingle Snowhead Map if ((scene == 0x5E) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x40 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x40, flag); } //Snowhead Tingle Snowhead Map (Winter) > Snowhead Tingle Snowhead Map (Spring) if ((scene == 0x5D) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5E, flag); } //Snowhead Tingle Snowhead Map (Spring) > Snowhead Tingle Snowhead Map (Winter) if ((scene == 0x5E) && (flag == 0xB6) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5D, flag); } //Snowhead Tingle Ranch Map (Winter) > Ranch Tingle Ranch Map if ((scene == 0x5D) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x22, flag); } //Snowhead Tingle Ranch Map (Spring) > Ranch Tingle Ranch Map if ((scene == 0x5E) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x22, flag); } //Ranch Tingle Ranch Map > Snowhead Tingle Snowhead Map (Winter) if ((scene == 0x22) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5E, flag); } //Ranch Tingle Ranch Map > Snowhead Tingle Snowhead Map (Spring) if ((scene == 0x22) && (flag == 0xB7) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x5D, flag); } //Ranch Tingle Great Bay Map > Great Bay Tingle Great Bay Map if ((scene == 0x22) && (flag == 0xB8) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x37 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x37, flag); } //Great Bay Tingle Great Bay Map > Ranch Tingle Great Bay Map if ((scene == 0x37) && (flag == 0xB8) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x22, flag); } //Great Bay Tingle Stone Tower Map > Stone Tower Tingle Stone Tower Map if ((scene == 0x37) && (flag == 0xB9) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x13 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x13, flag); } //Stone Tower Tingle Stone Tower Map > Great Bay Tingle Stone Tower Map if ((scene == 0x13) && (flag == 0xB9) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x37 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x37, flag); } //NCT Keaton > MR Keaton & MV Keaton if ((scene == 0x6E) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5A && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x22, flag); + SpoilerData_UpdateMultiLocations(type, 0x5A, flag); } //MR Keaton > NCT Keaton & MV Keaton if ((scene == 0x22) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x5A && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); + SpoilerData_UpdateMultiLocations(type, 0x5A, flag); } //MV Keaton > MR Keaton & NCT Keaton if ((scene == 0x5A) && (flag == 0x03) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x22 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x6E && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x22, flag); + SpoilerData_UpdateMultiLocations(type, 0x6E, flag); } //GV Powder Keg Challenge (Winter) > GV Powder Keg Challenge (Spring) if ((scene == 0x4D) && (flag == 0x34) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x48, flag); } //GV Powder Keg Challenge (Spring) > GV Powder Keg Challenge (Winter) if ((scene == 0x48) && (flag == 0x34) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x4D, flag); } //GV Deku Merchant Purchase (Winter) > GV Deku Merchant Purchase(Spring) if ((scene == 0x4D) && (flag == 0x1D) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x48, flag); } //GV Deku Merchant Purchase (Spring) > GV Deku Merchant Purchase(Winter) if ((scene == 0x48) && (flag == 0x1D) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x4D, flag); } //GV Deku Merchant Trade (Winter) > GV Deku Merchant Trade(Spring) if ((scene == 0x4D) && (flag == 0x99) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x48, flag); } //GV Deku Merchant Trade (Spring) > GV Deku Merchant Trade(Winter) if ((scene == 0x48) && (flag == 0x99) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x4D, flag); } //GV Ledge Heart Piece (Winter) > GV Ledge Heart Piece (Spring) if ((scene == 0x4D) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x48 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x48, flag); } //GV Ledge Heart Piece (Spring) > GV Ledge Heart Piece(Winter) if ((scene == 0x48) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x4D && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x4D, flag); } //SS Deku Merchant Purchase (Poison) > SS Deku Merchant Purchase(Clear) if ((scene == 0x45) && (flag == 0x35) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x00, flag); } //SS Deku Merchant Purchase (Clear) > SS Deku Merchant Purchase(Poison) if ((scene == 0x00) && (flag == 0x35) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x45, flag); } //SS Deku Merchant Trade (Poison) > SS Deku Merchant Trade (Clear) if ((scene == 0x45) && (flag == 0x98) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x00, flag); } //SS Deku Merchant Trade (Clear) > SS Deku Merchant Trade (Poison) if ((scene == 0x00) && (flag == 0x98) && (type == ItemOverride_Type::OVR_BASE_ITEM)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x45, flag); } //SS Tourist Center Roof HP (Poison) > SS Tourist Center Roof HP (Clear) if ((scene == 0x45) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x00 && gSpoilerData.ItemLocations[i].OverrideType == type && - gSpoilerData.ItemLocations[i].LocationFlag == flag) { - gSpoilerData.ItemLocations[i].Collected = true; - // Since it's not saved here, we need to return - gExtSaveData.itemCollected[i] = 1; - } - } + SpoilerData_UpdateMultiLocations(type, 0x00, flag); } //SS Tourist Center Roof HP (Clear) > SS Tourist Center Roof HP (Poison) if ((scene == 0x00) && (flag == 0x00) && (type == ItemOverride_Type::OVR_COLLECTABLE)){ - for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { - if (gSpoilerData.ItemLocations[i].LocationScene == 0x45 && gSpoilerData.ItemLocations[i].OverrideType == type && + SpoilerData_UpdateMultiLocations(type, 0x45, flag); + } + return -1; + } + void SpoilerData_UpdateMultiLocations(ItemOverride_Type type, u8 newScene, u8 flag) + { + for (int i = 0; i < gSpoilerData.ItemLocationsCount; i++) { + if (gSpoilerData.ItemLocations[i].LocationScene == newScene && gSpoilerData.ItemLocations[i].OverrideType == type && gSpoilerData.ItemLocations[i].LocationFlag == flag) { gSpoilerData.ItemLocations[i].Collected = true; // Since it's not saved here, we need to return gExtSaveData.itemCollected[i] = 1; } - } } - return -1; } u8 SpoilerData_CollectableCheck(SpoilerItemLocation itemLoc) { // TODO: Implement Collectable Checking. no need to use bits as we have From 83d81b43de91e720f15f2bda12612000877a3528 Mon Sep 17 00:00:00 2001 From: Tacoman369 <90735287+Tacoman369@users.noreply.github.com> Date: Mon, 12 Feb 2024 22:00:03 -0600 Subject: [PATCH 3/3] Update spoiler_data.cpp add breaks so it stops searching --- code/source/rnd/spoiler_data.cpp | 2 ++ 1 file changed, 2 insertions(+) diff --git a/code/source/rnd/spoiler_data.cpp b/code/source/rnd/spoiler_data.cpp index ed6ff1b1..6f4bdaf5 100644 --- a/code/source/rnd/spoiler_data.cpp +++ b/code/source/rnd/spoiler_data.cpp @@ -45,6 +45,7 @@ namespace rnd { gSpoilerData.ItemLocations[i].Collected = true; // Since it's not saved here, we need to return gExtSaveData.itemCollected[i] = 1; + break;//stop searching } } SpoilerLog_CheckMultiLocationItems(type, scene, flag); @@ -236,6 +237,7 @@ namespace rnd { gSpoilerData.ItemLocations[i].Collected = true; // Since it's not saved here, we need to return gExtSaveData.itemCollected[i] = 1; + break; } } }