Archipelago/worlds/ror2/locations.py

90 lines
3.9 KiB
Python

from typing import Dict
from BaseClasses import Location
from .options import TotalLocations, ChestsPerEnvironment, ShrinesPerEnvironment, ScavengersPerEnvironment, \
ScannersPerEnvironment, AltarsPerEnvironment
from .ror2environments import compress_dict_list_horizontal, environment_vanilla_orderedstages_table, \
environment_sotv_orderedstages_table
class RiskOfRainLocation(Location):
game: str = "Risk of Rain 2"
ror2_locations_start_id = 38000
def get_classic_item_pickups(n: int) -> Dict[str, int]:
"""Get n ItemPickups, capped at the max value for TotalLocations"""
n = max(n, 0)
n = min(n, TotalLocations.range_end)
return {f"ItemPickup{i + 1}": ror2_locations_start_id + i for i in range(n)}
item_pickups = get_classic_item_pickups(TotalLocations.range_end)
location_table = item_pickups
# this is so we can easily calculate the environment and location "offset" ids
ror2_locations_start_ordered_stage = ror2_locations_start_id + TotalLocations.range_end
# TODO is there a better, more generic way to do this?
offset_chests = 0
offset_shrines = offset_chests + ChestsPerEnvironment.range_end
offset_scavengers = offset_shrines + ShrinesPerEnvironment.range_end
offset_scanners = offset_scavengers + ScavengersPerEnvironment.range_end
offset_altars = offset_scanners + ScannersPerEnvironment.range_end
# total space allocated to the locations in a single orderedstage environment
allocation = offset_altars + AltarsPerEnvironment.range_end
def get_environment_locations(chests: int, shrines: int, scavengers: int, scanners: int, altars: int,
environment_name: str, environment_index: int) -> Dict[str, int]:
"""Get the locations within a specific environment"""
locations = {}
# due to this mapping, since environment ids are not consecutive, there are lots of "wasted" id numbers
environment_start_id = environment_index * allocation + ror2_locations_start_ordered_stage
for n in range(chests):
locations.update({f"{environment_name}: Chest {n + 1}": n + offset_chests + environment_start_id})
for n in range(shrines):
locations.update({f"{environment_name}: Shrine {n + 1}": n + offset_shrines + environment_start_id})
for n in range(scavengers):
locations.update({f"{environment_name}: Scavenger {n + 1}": n + offset_scavengers + environment_start_id})
for n in range(scanners):
locations.update({f"{environment_name}: Radio Scanner {n + 1}": n + offset_scanners + environment_start_id})
for n in range(altars):
locations.update({f"{environment_name}: Newt Altar {n + 1}": n + offset_altars + environment_start_id})
return locations
def get_locations(chests: int, shrines: int, scavengers: int, scanners: int, altars: int, dlc_sotv: bool) \
-> Dict[str, int]:
"""Get a dictionary of locations for the orderedstage environments with the locations from the parameters."""
locations = {}
orderedstages = compress_dict_list_horizontal(environment_vanilla_orderedstages_table)
if dlc_sotv:
orderedstages.update(compress_dict_list_horizontal(environment_sotv_orderedstages_table))
# for every environment, generate the respective locations
for environment_name, environment_index in orderedstages.items():
locations.update(get_environment_locations(
chests=chests,
shrines=shrines,
scavengers=scavengers,
scanners=scanners,
altars=altars,
environment_name=environment_name,
environment_index=environment_index),
)
return locations
# Get all locations in ordered stages.
location_table.update(get_locations(
chests=ChestsPerEnvironment.range_end,
shrines=ShrinesPerEnvironment.range_end,
scavengers=ScavengersPerEnvironment.range_end,
scanners=ScannersPerEnvironment.range_end,
altars=AltarsPerEnvironment.range_end,
dlc_sotv=True,
))