Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rando: Master Sword Shuffle #2981

Merged
merged 46 commits into from
Oct 22, 2023
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
a65f141
The mother of all commits
stratomaster64 Jun 11, 2023
a2dbdd3
Removed `GI_SWORD_MASTER`;
stratomaster64 Jun 12, 2023
677a0a4
Removed dupe MS entries in item pool;
stratomaster64 Jun 12, 2023
6775ba9
Give Adult Link a freebie with shuffle MS on;
stratomaster64 Jun 12, 2023
b3f0579
add master sword GI draw func based on ToT MS object
Archez Jun 12, 2023
88c8e7e
Merge pull request #8 from Archez/master-sword-gi-draw
stratomaster64 Jun 12, 2023
7cb1ccc
Force `MasterSword` logic var to only update upon getting MS
stratomaster64 Jun 12, 2023
4ee5d66
Dorf funny line now activates with LA and MS in inv
stratomaster64 Jun 12, 2023
778bf5a
Apply suggestions
stratomaster64 Jun 13, 2023
5ff88c7
Updated RAND_INF;
stratomaster64 Jun 14, 2023
0012f4b
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Jun 14, 2023
b848eb9
ToT MS Check now works in check tracker;
stratomaster64 Jun 14, 2023
9a56086
adult equips no longer reset in MS shuffle
stratomaster64 Jun 15, 2023
af1761d
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Jun 15, 2023
f272589
Apply (most) locacc review suggestions
stratomaster64 Jun 15, 2023
1c74cf4
Reorganized swordless check for interface to fit edge cases;
stratomaster64 Jun 16, 2023
d96f9cf
Merge branch 'develop' into mister-sword
stratomaster64 Jun 21, 2023
04ddd0d
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Jul 7, 2023
a9f3688
Edge case for BGS but no bow
stratomaster64 Jul 7, 2023
04e5f73
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Jul 19, 2023
39274ba
Fix implicit declaration error for GI hooks (#9)
lilacLunatic Jul 19, 2023
35277a9
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Aug 14, 2023
715c5f7
Merge branch 'develop' into mister-sword
stratomaster64 Aug 24, 2023
bf41e38
Adjusted `CanAdultAttack/Damage`; applied logic suggestions
stratomaster64 Aug 25, 2023
598639f
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Aug 30, 2023
586b085
Merge branch 'develop' into mister-sword
stratomaster64 Sep 6, 2023
ccfc63f
Merge branch 'develop' into mister-sword
stratomaster64 Sep 11, 2023
e180ec5
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Sep 15, 2023
4110667
Fixed build errors (hopefully)
stratomaster64 Sep 17, 2023
dc73dfb
Merge branch 'develop' into mister-sword
stratomaster64 Sep 17, 2023
14cee45
Merge branch 'develop' into mister-sword
stratomaster64 Sep 27, 2023
8b9299d
Cleanup merge
stratomaster64 Sep 27, 2023
f1d5a18
get shit working again
stratomaster64 Sep 28, 2023
da616eb
Merge branch 'develop' into mister-sword
stratomaster64 Oct 1, 2023
a0d897f
Tidied up remaining uses of DD flag as rando indicator
stratomaster64 Oct 1, 2023
c3ecfc8
make master sword invisible and fix ms flag (#10)
Archez Oct 1, 2023
8147b1f
Add text to sheik if go mode is obtained but barrier is still up
stratomaster64 Oct 2, 2023
e7f68de
overhaul swordless behavior in `func_80083108`
stratomaster64 Oct 2, 2023
a838fb9
reworked ToT MS Check to have an actual GI
stratomaster64 Oct 2, 2023
0de9f5d
suggestions
stratomaster64 Oct 4, 2023
d8def23
Merge branch 'develop' into mister-sword
stratomaster64 Oct 4, 2023
05b9c12
Apply suggestions
stratomaster64 Oct 11, 2023
a281280
Merge branch 'HarbourMasters:develop' into mister-sword
stratomaster64 Oct 13, 2023
f23f39d
Better swordless handling with temp B (#11)
Archez Oct 14, 2023
5616436
enum fix
stratomaster64 Oct 16, 2023
f8f79b1
Merge branch 'develop' into mister-sword
stratomaster64 Oct 17, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 3 additions & 2 deletions soh/include/z64save.h
Original file line number Diff line number Diff line change
Expand Up @@ -303,7 +303,7 @@ typedef struct {
/* */ char childAltarText[250];
/* */ char adultAltarText[750];
/* */ RandomizerCheck rewardCheck[9];
/* */ char ganonHintText[150];
/* */ char ganonHintText[300];
/* */ char gregHintText[250];
/* */ char ganonText[250];
/* */ char dampeText[150];
Expand All @@ -313,7 +313,8 @@ typedef struct {
/* */ char warpRequiemText[100];
/* */ char warpNocturneText[100];
/* */ char warpPreludeText[100];
/* */ RandomizerCheck ganonHintCheck;
/* */ RandomizerCheck LAHintCheck;
/* */ RandomizerCheck MSHintCheck;
/* */ RandomizerCheck gregCheck;
/* */ RandomizerCheck dampeCheck;
/* */ u8 seedIcons[5];
Expand Down
14 changes: 14 additions & 0 deletions soh/soh/Enhancements/randomizer/3drando/hint_list.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2958,6 +2958,20 @@ void HintTable_Init() {
"Ja, ja, ja... Nunca me derrotarás reflejando mis esferas de energía y desplegando la flecha de luz de " },
});


/*--------------------------
|MASTER SWORD LOCATION TEXT|
---------------------------*/

hintTable[MASTER_SWORD_LOCATION_HINT] = HintText::MasterSword({
// obscure text
Text{"And even if you do, you'll never find the legendary blade hidden in ",
/*french*/
"Et même si tu les trouves, tu ne touveras jamais l'épée de légende cachée dans ",
/*spanish*/
"E incluso si lo haces, nunca encontrarás la espada legendaria escondida en " },
});

hintTable[YOUR_POCKET] = HintText::Exclude({
// obscure text
Text{ "your pocket", /*french*/ "tes poches", /*spanish*/ "tu bolsillo" },
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,10 @@ void HintTable_Init_Exclude_Overworld() {
Text{"a #hole in a volcano# holds", /*french*/"la #grotte dans le volcan# contient", /*spanish*/"bajo el #hoyo de un volcán# yace"},
});

hintTable[TOT_MASTER_SWORD] = HintText::Exclude({
//obscure text
Text{"a #pedestal in a temple# holds", /*french*/"un #piédestal dans un temple# contient", /*spanish*/"un #pedestal en un templo# sostiene"},
});

hintTable[TOT_LIGHT_ARROWS_CUTSCENE] = HintText::Exclude({
//obscure text
Expand Down
32 changes: 27 additions & 5 deletions soh/soh/Enhancements/randomizer/3drando/hints.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include "item_pool.hpp"
#include "logic.hpp"
#include "random.hpp"
#include "settings.hpp"
#include "spoiler_log.hpp"
#include "fill.hpp"
#include "hint_list.hpp"
Expand Down Expand Up @@ -141,7 +142,8 @@ Text warpRequiemText;
Text warpNocturneText;
Text warpPreludeText;

std::string ganonHintLoc;
std::string LAHintLoc;
std::string MSHintLoc;
std::string dampeHintLoc;

Text& GetChildAltarText() {
Expand Down Expand Up @@ -192,8 +194,12 @@ Text& GetWarpPreludeText() {
return warpPreludeText;
}

std::string GetGanonHintLoc() {
return ganonHintLoc;
std::string GetLAHintLoc() {
return LAHintLoc;
}

std::string GetMSHintLoc() {
return MSHintLoc;
}

std::string GetDampeHintLoc() {
Expand Down Expand Up @@ -589,13 +595,29 @@ void CreateGanonText() {
auto hint = Hint(LIGHT_ARROW_LOCATION_HINT);
if (lightArrowLocation.empty()) {
ganonHintText = hint.GetText()+Hint(YOUR_POCKET).GetText();
ganonHintLoc = "Link's Pocket";
LAHintLoc = "Link's Pocket";
} else {
ganonHintText = hint.GetText()+GetHintRegion(Location(lightArrowLocation[0])->GetParentRegionKey())->GetHint().GetText();
ganonHintLoc = Location(lightArrowLocation[0])->GetName();
LAHintLoc = Location(lightArrowLocation[0])->GetName();
}
ganonHintText = ganonHintText + "!";

if (ShuffleMasterSword) {
//Get the location of the master sword
auto masterSwordLocation = FilterFromPool(allLocations, [](const LocationKey loc){return Location(loc)->GetPlacedItemKey() == MASTER_SWORD;});

// Add second text box
ganonHintText = ganonHintText + "^";
if (masterSwordLocation.empty()) {
ganonHintText = ganonHintText+Hint(MASTER_SWORD_LOCATION_HINT).GetText()+Hint(YOUR_POCKET).GetText();
MSHintLoc = "Link's Pocket";
} else {
ganonHintText = ganonHintText+Hint(MASTER_SWORD_LOCATION_HINT).GetText()+GetHintRegion(Location(masterSwordLocation[0])->GetParentRegionKey())->GetHint().GetText();
MSHintLoc = Location(masterSwordLocation[0])->GetName();
}
ganonHintText = ganonHintText + "!";
}

CreateMessageFromTextObject(0x70CC, 0, 2, 3, AddColorsAndFormat(ganonHintText));
}

Expand Down
8 changes: 7 additions & 1 deletion soh/soh/Enhancements/randomizer/3drando/hints.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ enum class HintCategory {
Altar,
Validation,
LightArrow,
MasterSword,
GanonLine,
MerchantsDialogs,
};
Expand Down Expand Up @@ -116,6 +117,10 @@ class HintText {
return HintText{std::move(obscureText), std::move(ambiguousText), std::move(clearText), HintCategory::LightArrow};
}

static auto MasterSword(std::vector<Text>&& obscureText, std::vector<Text>&& ambiguousText = {}, Text&& clearText = {}) {
return HintText{std::move(obscureText), std::move(ambiguousText), std::move(clearText), HintCategory::MasterSword};
}

static auto GanonLine(std::vector<Text>&& obscureText, std::vector<Text>&& ambiguousText = {}, Text&& clearText = {}) {
return HintText{std::move(obscureText), std::move(ambiguousText), std::move(clearText), HintCategory::GanonLine};
}
Expand Down Expand Up @@ -224,4 +229,5 @@ Text& GetWarpNocturneText();
Text& GetWarpPreludeText();

std::string GetDampeHintLoc();
std::string GetGanonHintLoc();
std::string GetLAHintLoc();
std::string GetMSHintLoc();
2 changes: 1 addition & 1 deletion soh/soh/Enhancements/randomizer/3drando/item_list.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ static std::array<Item, KEY_ENUM_MAX> itemTable;
void ItemTable_Init() { // RandomizerGet English name French Spanish Item Type getItemID advancement logic hint key
itemTable[NONE] = Item(RG_NONE, Text{"No Item", "Rien", "Sin Objeto"}, ITEMTYPE_EVENT, GI_RUPEE_GREEN, false, &noVariable, NONE);
itemTable[KOKIRI_SWORD] = Item(RG_KOKIRI_SWORD, Text{"Kokiri Sword", "Épée Kokiri", "Espada Kokiri"}, ITEMTYPE_ITEM, GI_SWORD_KOKIRI, true, &KokiriSword, KOKIRI_SWORD);
//[MASTER_SWORD]
itemTable[MASTER_SWORD] = Item(RG_MASTER_SWORD, Text{"Master Sword", "Épée de Legende", "Espada Master"}, ITEMTYPE_ITEM, 0x73, true, &MasterSword, MASTER_SWORD);
itemTable[GIANTS_KNIFE] = Item(RG_GIANTS_KNIFE, Text{"Giant's Knife", "Lame des Géants", "Espada de Biggoron"}, ITEMTYPE_ITEM, GI_SWORD_KNIFE, false, &noVariable, GIANTS_KNIFE);
itemTable[BIGGORON_SWORD] = Item(RG_BIGGORON_SWORD, Text{"Biggoron's Sword", "Épée de Biggoron", "Espada de Biggoron"}, ITEMTYPE_ITEM, GI_SWORD_BGS, true, &BiggoronSword, BIGGORON_SWORD);
itemTable[DEKU_SHIELD] = Item(RG_DEKU_SHIELD, Text{"Deku Shield", "Bouclier Mojo", "Escudo deku"}, ITEMTYPE_ITEM, GI_SHIELD_DEKU, false, &noVariable, DEKU_SHIELD);
Expand Down
2 changes: 2 additions & 0 deletions soh/soh/Enhancements/randomizer/3drando/item_location.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -756,6 +756,7 @@ void LocationTable_Init() {
--- CUTSCENES ---
-------------------------------*/

locationTable[TOT_MASTER_SWORD] = ItemLocation::Delayed(RC_TOT_MASTER_SWORD, 0xFF, 0x00, "ToT Master Sword", TOT_MASTER_SWORD, MASTER_SWORD, {Category::cTempleOfTime, Category::cMarket}, SpoilerCollectionCheck::MasterSword(), SpoilerCollectionCheckGroup::GROUP_HYRULE_CASTLE);
locationTable[TOT_LIGHT_ARROWS_CUTSCENE] = ItemLocation::Delayed(RC_TOT_LIGHT_ARROWS_CUTSCENE, 0xFF, 0x01, "ToT Light Arrow Cutscene", TOT_LIGHT_ARROWS_CUTSCENE, LIGHT_ARROWS, {Category::cTempleOfTime, Category::cMarket}, SpoilerCollectionCheck::Chest(0x43, 0x1E), SpoilerCollectionCheckGroup::GROUP_HYRULE_CASTLE);
locationTable[LW_GIFT_FROM_SARIA] = ItemLocation::Delayed(RC_LW_GIFT_FROM_SARIA, 0xFF, 0x02, "LW Gift From Saria", LW_GIFT_FROM_SARIA, PROGRESSIVE_OCARINA, {Category::cLostWoods, Category::cForest}, SpoilerCollectionCheck::EventChkInf(0xC1), SpoilerCollectionCheckGroup::GROUP_LOST_WOODS);
locationTable[ZF_GREAT_FAIRY_REWARD] = ItemLocation::Delayed(RC_ZF_GREAT_FAIRY_REWARD, 0xFF, 0x10, "ZF Great Fairy Reward", ZF_GREAT_FAIRY_REWARD, FARORES_WIND, {Category::cZorasFountain, Category::cFairies}, SpoilerCollectionCheck::Chest(0x3D, 0x01), SpoilerCollectionCheckGroup::GROUP_ZORAS_DOMAIN);
Expand Down Expand Up @@ -1266,6 +1267,7 @@ std::vector<uint32_t> overworldLocations = {
OGC_GREAT_FAIRY_REWARD,

//Temple of Time
TOT_MASTER_SWORD,
SHEIK_AT_TEMPLE,
TOT_LIGHT_ARROWS_CUTSCENE,

Expand Down
4 changes: 4 additions & 0 deletions soh/soh/Enhancements/randomizer/3drando/item_location.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -155,6 +155,10 @@ class SpoilerCollectionCheck {
return SpoilerCollectionCheck(SpoilerCollectionCheckType::SPOILER_CHK_MAGIC_BEANS, scene, flag);
}

static auto MasterSword() {
return SpoilerCollectionCheck(SpoilerCollectionCheckType::SPOILER_CHK_MASTER_SWORD, 0x00, 0x00);
}

static auto Merchant(int8_t scene, uint8_t flag) {
return SpoilerCollectionCheck(SpoilerCollectionCheckType::SPOILER_CHK_MERCHANT, scene, flag);
}
Expand Down
14 changes: 13 additions & 1 deletion soh/soh/Enhancements/randomizer/3drando/item_pool.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -108,9 +108,10 @@ const std::array<uint32_t, 59> alwaysItems = {
ARROWS_10,
TREASURE_GAME_HEART,
};
const std::array<uint32_t, 43> easyItems = {
const std::array<uint32_t, 44> easyItems = {
stratomaster64 marked this conversation as resolved.
Show resolved Hide resolved
BIGGORON_SWORD,
KOKIRI_SWORD,
MASTER_SWORD,
BOOMERANG,
LENS_OF_TRUTH,
MEGATON_HAMMER,
Expand Down Expand Up @@ -674,6 +675,13 @@ void GenerateItemPool() {
PlaceItemInLocation(KF_KOKIRI_SWORD_CHEST, KOKIRI_SWORD, false, true);
}

if (ShuffleMasterSword) {
AddItemToMainPool(MASTER_SWORD);
IceTrapModels.push_back(0x73); //Master Sword without the GI enum
} else {
PlaceItemInLocation(TOT_MASTER_SWORD, MASTER_SWORD, false, true);
}

if (ShuffleWeirdEgg) {
AddItemToMainPool(WEIRD_EGG);
IceTrapModels.push_back(GI_WEIRD_EGG);
Expand Down Expand Up @@ -1153,6 +1161,10 @@ void GenerateItemPool() {
ReplaceMaxItem(KOKIRI_SWORD, 0);
}

if (!ShuffleMasterSword) {
ReplaceMaxItem(MASTER_SWORD, 0);
}

if (ProgressiveGoronSword) {
ReplaceMaxItem(BIGGORON_SWORD, 0);
AddItemToMainPool(PROGRESSIVE_GORONSWORD, 2);
Expand Down
2 changes: 2 additions & 0 deletions soh/soh/Enhancements/randomizer/3drando/keys.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -356,6 +356,7 @@ typedef enum {
MARKET_BOMBCHU_SHOP_ITEM_6,
MARKET_BOMBCHU_SHOP_ITEM_7,
MARKET_BOMBCHU_SHOP_ITEM_8,
TOT_MASTER_SWORD,
TOT_LIGHT_ARROWS_CUTSCENE,
//HYRULE_CASTLE
HC_MALON_EGG,
Expand Down Expand Up @@ -1803,6 +1804,7 @@ typedef enum {

VALIDATION_LINE,
LIGHT_ARROW_LOCATION_HINT,
MASTER_SWORD_LOCATION_HINT,
DAMPE_DIARY,
YOUR_POCKET,

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ void AreaTable_Init_CastleTown() {

areaTable[TEMPLE_OF_TIME] = Area("Temple of Time", "Temple of Time", TEMPLE_OF_TIME, NO_DAY_NIGHT_CYCLE, {}, {
//Locations
LocationAccess(TOT_MASTER_SWORD, {[]{return IsAdult;}}),
LocationAccess(TOT_LIGHT_ARROWS_CUTSCENE, {[]{return IsAdult && CanTriggerLACS;}}),
}, {
//Exits
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ void AreaTable_Init_DeathMountain() {
LocationAccess(GC_ROLLING_GORON_AS_CHILD, {[]{return IsChild && (HasExplosives || (GoronBracelet && LogicChildRollingWithStrength));}}),
LocationAccess(GC_ROLLING_GORON_AS_ADULT, {[]{return StopGCRollingGoronAsAdult;}}),
LocationAccess(GC_GS_BOULDER_MAZE, {[]{return IsChild && CanBlastOrSmash;}}),
LocationAccess(GC_GS_CENTER_PLATFORM, {[]{return IsAdult;}}),
LocationAccess(GC_GS_CENTER_PLATFORM, {[]{return CanAdultAttack;}}),
LocationAccess(GC_MEDIGORON, {[]{return IsAdult && AdultsWallet && (CanBlastOrSmash || GoronBracelet);}}),
LocationAccess(GC_MAZE_GOSSIP_STONE, {[]{return CanBlastOrSmash || CanUse(SILVER_GAUNTLETS);}}),
LocationAccess(GC_MEDIGORON_GOSSIP_STONE, {[]{return CanBlastOrSmash || GoronBracelet;}}),
Expand Down
Loading