about summary refs log tree commit diff stats
path: root/apworld/static_logic.py
diff options
context:
space:
mode:
authorStar Rauchenberger <fefferburbia@gmail.com>2026-02-06 13:45:01 -0500
committerStar Rauchenberger <fefferburbia@gmail.com>2026-02-06 13:45:01 -0500
commit27a1d63608cc370cdf491ae08c70c74f76956367 (patch)
tree3e1dbbfedc130e17eb8b0da575671e8f99c98a1e /apworld/static_logic.py
parentbde801d654ce6ddc41f703e55adfcc33b3f3104e (diff)
parent2a3916c1c58e033b06042d5d5413ea85cd94babf (diff)
downloadlingo2-archipelago-27a1d63608cc370cdf491ae08c70c74f76956367.tar.gz
lingo2-archipelago-27a1d63608cc370cdf491ae08c70c74f76956367.tar.bz2
lingo2-archipelago-27a1d63608cc370cdf491ae08c70c74f76956367.zip
Merge branch 'main' of fourisland.com:/srv/git/lingo2-archipelago
Diffstat (limited to 'apworld/static_logic.py')
-rw-r--r--apworld/static_logic.py12
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]