Skip to content

Commit

Permalink
Fix cave entrance names
Browse files Browse the repository at this point in the history
  • Loading branch information
wooferzfg committed Aug 28, 2023
1 parent 4c32947 commit 175ef4f
Show file tree
Hide file tree
Showing 5 changed files with 250 additions and 131 deletions.
24 changes: 0 additions & 24 deletions src/data/cave-entrances.json

This file was deleted.

178 changes: 156 additions & 22 deletions src/data/caves.json
Original file line number Diff line number Diff line change
@@ -1,24 +1,158 @@
[
"Savage Labyrinth",
"Dragon Roost Island Secret Cave",
"Fire Mountain Secret Cave",
"Ice Ring Isle Secret Cave",
"Cabana Labyrinth",
"Needle Rock Isle Secret Cave",
"Angular Isles Secret Cave",
"Boating Course Secret Cave",
"Stone Watcher Island Secret Cave",
"Overlook Island Secret Cave",
"Bird's Peak Rock Secret Cave",
"Pawprint Isle Chuchu Cave",
"Pawprint Isle Wizzrobe Cave",
"Diamond Steppe Island Warp Maze Cave",
"Bomb Island Secret Cave",
"Rock Spire Isle Secret Cave",
"Shark Island Secret Cave",
"Cliff Plateau Isles Secret Cave",
"Horseshoe Island Secret Cave",
"Star Island Secret Cave",
"Ice Ring Isle Inner Cave",
"Cliff Plateau Isles Inner Cave"
{
"islandName": "Outset Island",
"entranceName": "Outset Island Cave",
"exitName": "Savage Labyrinth",
"entranceMacroName": "Secret Cave Entrance on Outset Island",
"internalName": "Savage Labyrinth"
},
{
"islandName": "Dragon Roost Island",
"entranceName": "Dragon Roost Island Cave",
"exitName": "Dragon Roost Island Cave",
"entranceMacroName": "Secret Cave Entrance on Dragon Roost Island",
"internalName": "Dragon Roost Island Secret Cave"
},
{
"islandName": "Fire Mountain",
"entranceName": "Fire Mountain Cave",
"exitName": "Fire Mountain Cave",
"entranceMacroName": "Secret Cave Entrance on Fire Mountain",
"internalName": "Fire Mountain Secret Cave"
},
{
"islandName": "Ice Ring Isle",
"entranceName": "Ice Ring Isle Cave",
"exitName": "Ice Ring Isle Cave",
"entranceMacroName": "Secret Cave Entrance on Ice Ring Isle",
"internalName": "Ice Ring Isle Secret Cave"
},
{
"islandName": "Private Oasis",
"entranceName": "Private Oasis Cave",
"exitName": "Cabana Labyrinth",
"entranceMacroName": "Secret Cave Entrance on Private Oasis",
"internalName": "Cabana Labyrinth"
},
{
"islandName": "Needle Rock Isle",
"entranceName": "Needle Rock Isle Cave",
"exitName": "Needle Rock Isle Cave",
"entranceMacroName": "Secret Cave Entrance on Needle Rock Isle",
"internalName": "Needle Rock Isle Secret Cave"
},
{
"islandName": "Angular Isles",
"entranceName": "Angular Isles Cave",
"exitName": "Angular Isles Cave",
"entranceMacroName": "Secret Cave Entrance on Angular Isles",
"internalName": "Angular Isles Secret Cave"
},
{
"islandName": "Boating Course",
"entranceName": "Boating Course Cave",
"exitName": "Boating Course Cave",
"entranceMacroName": "Secret Cave Entrance on Boating Course",
"internalName": "Boating Course Secret Cave"
},
{
"islandName": "Stone Watcher Island",
"entranceName": "Stone Watcher Island Cave",
"exitName": "Stone Watcher Island Cave",
"entranceMacroName": "Secret Cave Entrance on Stone Watcher Island",
"internalName": "Stone Watcher Island Secret Cave"
},
{
"islandName": "Overlook Island",
"entranceName": "Overlook Island Cave",
"exitName": "Overlook Island Cave",
"entranceMacroName": "Secret Cave Entrance on Overlook Island",
"internalName": "Overlook Island Secret Cave"
},
{
"islandName": "Bird's Peak Rock",
"entranceName": "Bird's Peak Rock Cave",
"exitName": "Bird's Peak Rock Cave",
"entranceMacroName": "Secret Cave Entrance on Bird's Peak Rock",
"internalName": "Bird's Peak Rock Secret Cave"
},
{
"islandName": "Pawprint Isle",
"entranceName": "Pawprint Isle Cave",
"exitName": "Pawprint Isle Chuchu Cave",
"entranceMacroName": "Secret Cave Entrance on Pawprint Isle",
"internalName": "Pawprint Isle Chuchu Cave"
},
{
"islandName": "Pawprint Isle",
"entranceName": "Pawprint Isle Side Isle Cave",
"exitName": "Pawprint Isle Wizzrobe Cave",
"entranceMacroName": "Secret Cave Entrance on Pawprint Isle Side Isle",
"internalName": "Pawprint Isle Wizzrobe Cave"
},
{
"islandName": "Diamond Steppe Island",
"entranceName": "Diamond Steppe Island Cave",
"exitName": "Diamond Steppe Island Cave",
"entranceMacroName": "Secret Cave Entrance on Diamond Steppe Island",
"internalName": "Diamond Steppe Island Warp Maze Cave"
},
{
"islandName": "Bomb Island",
"entranceName": "Bomb Island Cave",
"exitName": "Bomb Island Cave",
"entranceMacroName": "Secret Cave Entrance on Bomb Island",
"internalName": "Bomb Island Secret Cave"
},
{
"islandName": "Rock Spire Isle",
"entranceName": "Rock Spire Isle Cave",
"exitName": "Rock Spire Isle Cave",
"entranceMacroName": "Secret Cave Entrance on Rock Spire Isle",
"internalName": "Rock Spire Isle Secret Cave"
},
{
"islandName": "Shark Island",
"entranceName": "Shark Island Cave",
"exitName": "Shark Island Cave",
"entranceMacroName": "Secret Cave Entrance on Shark Island",
"internalName": "Shark Island Secret Cave"
},
{
"islandName": "Cliff Plateau Isles",
"entranceName": "Cliff Plateau Isles Cave",
"exitName": "Cliff Plateau Isles Cave",
"entranceMacroName": "Secret Cave Entrance on Cliff Plateau Isles",
"internalName": "Cliff Plateau Isles Secret Cave"
},
{
"islandName": "Horseshoe Island",
"entranceName": "Horseshoe Island Cave",
"exitName": "Horseshoe Island Cave",
"entranceMacroName": "Secret Cave Entrance on Horseshoe Island",
"internalName": "Horseshoe Island Secret Cave"
},
{
"islandName": "Star Island",
"entranceName": "Star Island Cave",
"exitName": "Star Island Cave",
"entranceMacroName": "Secret Cave Entrance on Star Island",
"internalName": "Star Island Secret Cave"
},
{
"islandName": "Ice Ring Isle",
"entranceName": "Ice Ring Isle Inner Cave",
"exitName": "Ice Ring Isle Inner Cave",
"isInnerCave": true,
"entranceMacroName": "Inner Entrance in Ice Ring Isle Secret Cave",
"internalName": "Ice Ring Isle Inner Cave"
},
{
"islandName": "Cliff Plateau Isles",
"entranceName": "Cliff Plateau Isles Inner Cave",
"exitName": "Cliff Plateau Isles Inner Cave",
"isInnerCave": true,
"entranceMacroName": "Inner Entrance in Cliff Plateau Isles Secret Cave",
"internalName": "Cliff Plateau Isles Inner Cave"
}
]
89 changes: 44 additions & 45 deletions src/services/logic-helper.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import _ from 'lodash';

import BOSSES from '../data/bosses.json';
import CAVE_ENTRANCES from '../data/cave-entrances.json';
import CAVES from '../data/caves.json';
import CHARTS from '../data/charts.json';
import DUNGEON_ENTRANCES from '../data/dungeon-entrances.json';
Expand Down Expand Up @@ -35,7 +34,6 @@ class LogicHelper {
'chartForIsland',
'entrancesForDungeon',
'filterDetailedLocations',
'isInnerCave',
'islandFromChartForIsland',
'islandForChart',
'isPotentialKeyLocation',
Expand Down Expand Up @@ -65,7 +63,6 @@ class LogicHelper {
this.chartForIsland,
this.entrancesForDungeon,
this.filterDetailedLocations,
this.isInnerCave,
this.islandFromChartForIsland,
this.islandForChart,
this.isPotentialKeyLocation,
Expand Down Expand Up @@ -122,7 +119,7 @@ class LogicHelper {
};

static ALL_ITEMS = _.concat(
_.map(CAVES, (cave) => this.entryName(cave)),
_.map(CAVES, (caveData) => this.entryName(caveData.internalName)),
CHARTS,
_.map(ISLANDS, (island) => this.chartForIslandName(island)),
_.map(this.MAIN_DUNGEONS, (dungeon) => this.entryName(dungeon)),
Expand Down Expand Up @@ -195,27 +192,18 @@ class LogicHelper {
return this.isDungeon(dungeonName);
}

static isInnerCave(caveName) {
if (!_.includes(CAVES, caveName)) {
return false;
}
return _.some(
NESTED_ENTRANCES,
(entrances) => _.includes(entrances, caveName),
);
}

static entryName(zoneName) {
let entranceName;
let exitName;
if (this._isBoss(zoneName) || this._isMiniboss(zoneName)) {
entranceName = zoneName;
exitName = zoneName;
} else if (this.isDungeon(zoneName)) {
entranceName = this._shortDungeonName(zoneName);
exitName = this._shortDungeonName(zoneName);
} else {
entranceName = this._shortCaveName(zoneName);
const caveData = this._caveDataForInternalName(zoneName);
exitName = caveData.exitName;
}

return this._entryNameForEntranceName(entranceName);
return `Entered ${exitName}`;
}

static shortEntranceName(zoneName) {
Expand All @@ -235,32 +223,46 @@ class LogicHelper {
return zoneName;
}

return this._shortCaveName(zoneName);
const caveData = this._caveDataForInternalName(zoneName);
if (!_.isNil(caveData)) {
return caveData.entranceName;
}

// istanbul ignore next
throw Error(`Could not get short name for entrance: ${zoneName}`);
}

static shortExitName(zoneName) {
if (this._isBoss(zoneName) || this._isMiniboss(zoneName) || this.isDungeon(zoneName)) {
return zoneName;
}
return this._shortCaveName(zoneName);

const caveData = this._caveDataForInternalName(zoneName);
if (!_.isNil(caveData)) {
return caveData.exitName;
}

// istanbul ignore next
throw Error(`Could not get short name for exit: ${zoneName}`);
}

static cavesForIsland(islandName) {
return _.compact(
_.map(
CAVE_ENTRANCES,
(caveEntrance, caveIndex) => {
if (!_.startsWith(caveEntrance, islandName)) {
CAVES,
(caveData) => {
if (caveData.islandName !== islandName) {
return null;
}
const caveName = _.get(CAVES, caveIndex);
if (this.isInnerCave(caveName)) {

if (caveData.isInnerCave) {
if (Settings.getOptionValue(Permalink.OPTIONS.RANDOMIZE_SECRET_CAVE_INNER_ENTRANCES)) {
return caveName;
return caveData.internalName;
}
} else if (Settings.getOptionValue(Permalink.OPTIONS.RANDOMIZE_SECRET_CAVE_ENTRANCES)) {
return caveName;
return caveData.internalName;
}

return null;
},
),
Expand Down Expand Up @@ -319,12 +321,14 @@ class LogicHelper {
}

static allCaveEntrances() {
return _.filter(CAVES, (caveName) => {
if (this.isInnerCave(caveName)) {
const filteredCaves = _.filter(CAVES, (caveData) => {
if (caveData.isInnerCave) {
return Settings.getOptionValue(Permalink.OPTIONS.RANDOMIZE_SECRET_CAVE_INNER_ENTRANCES);
}
return Settings.getOptionValue(Permalink.OPTIONS.RANDOMIZE_SECRET_CAVE_ENTRANCES);
});

return _.map(filteredCaves, (caveData) => caveData.internalName);
}

static randomEntrancesForExit(zoneName) {
Expand Down Expand Up @@ -640,10 +644,6 @@ class LogicHelper {
return this._booleanExpressionForRequirements(requirements);
}

static _shortCaveName(caveName) {
return _.replace(caveName, /Secret |Warp Maze /g, '');
}

static _shortDungeonName(dungeonName) {
const dungeonIndex = _.indexOf(DUNGEONS, dungeonName);
return SHORT_DUNGEON_NAMES[dungeonIndex];
Expand All @@ -668,13 +668,9 @@ class LogicHelper {
return `Can Access Dungeon Entrance ${dungeonEntranceName}`;
}

const caveIndex = _.indexOf(CAVES, zoneName);
if (caveIndex >= 0) {
const caveEntranceName = _.get(CAVE_ENTRANCES, caveIndex);
if (this.isInnerCave(zoneName)) {
return `Can Access Inner Entrance in ${caveEntranceName} Secret Cave`;
}
return `Can Access Secret Cave Entrance on ${caveEntranceName}`;
const caveData = this._caveDataForInternalName(zoneName);
if (!_.isNil(caveData)) {
return `Can Access ${caveData.entranceMacroName}`;
}

// istanbul ignore next
Expand Down Expand Up @@ -887,10 +883,6 @@ class LogicHelper {
return this._booleanExpressionForTokens(expressionTokens);
}

static _entryNameForEntranceName(entranceName) {
return `Entered ${entranceName}`;
}

static _isBoss(bossName) {
return _.includes(BOSSES, bossName);
}
Expand Down Expand Up @@ -929,6 +921,13 @@ class LogicHelper {

return _.concat(dungeonEntrances, minibossEntrances, bossEntrances);
}

static _caveDataForInternalName(caveName) {
return _.find(
CAVES,
(caveData) => caveData.internalName === caveName,
);
}
}

export default LogicHelper;
Loading

0 comments on commit 175ef4f

Please sign in to comment.