diff options
| author | Star Rauchenberger <fefferburbia@gmail.com> | 2026-02-06 13:43:45 -0500 |
|---|---|---|
| committer | Star Rauchenberger <fefferburbia@gmail.com> | 2026-02-06 13:43:45 -0500 |
| commit | 2a3916c1c58e033b06042d5d5413ea85cd94babf (patch) | |
| tree | a785aafad640db15ca8c6a80d1a3aaf55a7639fa /apworld/static_logic.py | |
| parent | 225a6dba793386f36e72b432c8374e1978cee72a (diff) | |
| download | lingo2-archipelago-2a3916c1c58e033b06042d5d5413ea85cd94babf.tar.gz lingo2-archipelago-2a3916c1c58e033b06042d5d5413ea85cd94babf.tar.bz2 lingo2-archipelago-2a3916c1c58e033b06042d5d5413ea85cd94babf.zip | |
Add shuffle_fast_travel and fast_travel_access to apworld
Diffstat (limited to 'apworld/static_logic.py')
| -rw-r--r-- | apworld/static_logic.py | 12 |
1 files changed, 12 insertions, 0 deletions
| diff --git a/apworld/static_logic.py b/apworld/static_logic.py index 715178e..672ae5a 100644 --- a/apworld/static_logic.py +++ b/apworld/static_logic.py | |||
| @@ -18,6 +18,8 @@ class Lingo2StaticLogic: | |||
| 18 | door_id_by_ap_id: dict[int, int] | 18 | door_id_by_ap_id: dict[int, int] |
| 19 | port_id_by_ap_id: dict[int, int] | 19 | port_id_by_ap_id: dict[int, int] |
| 20 | 20 | ||
| 21 | map_id_by_name: dict[str, int] | ||
| 22 | |||
| 21 | def __init__(self): | 23 | def __init__(self): |
| 22 | self.item_id_to_name = {} | 24 | self.item_id_to_name = {} |
| 23 | self.location_id_to_name = {} | 25 | self.location_id_to_name = {} |
| @@ -79,6 +81,10 @@ class Lingo2StaticLogic: | |||
| 79 | for trap_name in ANTI_COLLECTABLE_TRAPS: | 81 | for trap_name in ANTI_COLLECTABLE_TRAPS: |
| 80 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name | 82 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name |
| 81 | 83 | ||
| 84 | for game_map in self.objects.maps: | ||
| 85 | if game_map.HasField("rte_room"): | ||
| 86 | self.item_id_to_name[game_map.rte_ap_id] = self.get_map_rte_item_name(game_map.id) | ||
| 87 | |||
| 82 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} | 88 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} |
| 83 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} | 89 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} |
| 84 | 90 | ||
| @@ -90,6 +96,8 @@ class Lingo2StaticLogic: | |||
| 90 | self.door_id_by_ap_id = {door.ap_id: door.id for door in self.objects.doors if door.HasField("ap_id")} | 96 | self.door_id_by_ap_id = {door.ap_id: door.id for door in self.objects.doors if door.HasField("ap_id")} |
| 91 | self.port_id_by_ap_id = {port.ap_id: port.id for port in self.objects.ports if port.HasField("ap_id")} | 97 | self.port_id_by_ap_id = {port.ap_id: port.id for port in self.objects.ports if port.HasField("ap_id")} |
| 92 | 98 | ||
| 99 | self.map_id_by_name = {game_map.name: game_map.id for game_map in self.objects.maps} | ||
| 100 | |||
| 93 | def get_door_item_name(self, door: data_pb2.Door) -> str: | 101 | def get_door_item_name(self, door: data_pb2.Door) -> str: |
| 94 | return f"{self.get_map_object_map_name(door)} - {door.name}" | 102 | return f"{self.get_map_object_map_name(door)} - {door.name}" |
| 95 | 103 | ||
| @@ -177,6 +185,10 @@ class Lingo2StaticLogic: | |||
| 177 | def get_room_object_map_id(self, obj) -> int: | 185 | def get_room_object_map_id(self, obj) -> int: |
| 178 | return self.objects.rooms[obj.room_id].map_id | 186 | return self.objects.rooms[obj.room_id].map_id |
| 179 | 187 | ||
| 188 | def get_map_rte_item_name(self, map_id: int) -> str: | ||
| 189 | game_map = self.objects.maps[map_id] | ||
| 190 | return f"Return to {game_map.display_name}" | ||
| 191 | |||
| 180 | def get_data_version(self) -> list[int]: | 192 | def get_data_version(self) -> list[int]: |
| 181 | version = self.objects.version | 193 | version = self.objects.version |
| 182 | return [version.major, version.minor, version.patch] | 194 | return [version.major, version.minor, version.patch] |
