diff options
Diffstat (limited to 'apworld/static_logic.py')
| -rw-r--r-- | apworld/static_logic.py | 35 |
1 files changed, 31 insertions, 4 deletions
| diff --git a/apworld/static_logic.py b/apworld/static_logic.py index e4d7d49..48ad78e 100644 --- a/apworld/static_logic.py +++ b/apworld/static_logic.py | |||
| @@ -2,6 +2,7 @@ from .generated import data_pb2 as data_pb2 | |||
| 2 | from .items import SYMBOL_ITEMS, ANTI_COLLECTABLE_TRAPS | 2 | from .items import SYMBOL_ITEMS, ANTI_COLLECTABLE_TRAPS |
| 3 | import pkgutil | 3 | import pkgutil |
| 4 | 4 | ||
| 5 | |||
| 5 | class Lingo2StaticLogic: | 6 | class Lingo2StaticLogic: |
| 6 | item_id_to_name: dict[int, str] | 7 | item_id_to_name: dict[int, str] |
| 7 | location_id_to_name: dict[int, str] | 8 | location_id_to_name: dict[int, str] |
| @@ -14,6 +15,11 @@ class Lingo2StaticLogic: | |||
| 14 | 15 | ||
| 15 | letter_weights: dict[str, int] | 16 | letter_weights: dict[str, int] |
| 16 | 17 | ||
| 18 | door_id_by_ap_id: dict[int, int] | ||
| 19 | port_id_by_ap_id: dict[int, int] | ||
| 20 | |||
| 21 | map_id_by_name: dict[str, int] | ||
| 22 | |||
| 17 | def __init__(self): | 23 | def __init__(self): |
| 18 | self.item_id_to_name = {} | 24 | self.item_id_to_name = {} |
| 19 | self.location_id_to_name = {} | 25 | self.location_id_to_name = {} |
| @@ -67,19 +73,32 @@ class Lingo2StaticLogic: | |||
| 67 | self.location_name_groups.setdefault("Keyholders", []).append(location_name) | 73 | self.location_name_groups.setdefault("Keyholders", []).append(location_name) |
| 68 | 74 | ||
| 69 | self.item_id_to_name[self.objects.special_ids["A Job Well Done"]] = "A Job Well Done" | 75 | self.item_id_to_name[self.objects.special_ids["A Job Well Done"]] = "A Job Well Done" |
| 76 | self.item_id_to_name[self.objects.special_ids["Numbers"]] = "Numbers" | ||
| 70 | 77 | ||
| 78 | self.item_name_groups["Symbols"] = [] | ||
| 71 | for symbol_name in SYMBOL_ITEMS.values(): | 79 | for symbol_name in SYMBOL_ITEMS.values(): |
| 72 | self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name | 80 | self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name |
| 81 | self.item_name_groups["Symbols"].append(symbol_name) | ||
| 73 | 82 | ||
| 74 | for trap_name in ANTI_COLLECTABLE_TRAPS: | 83 | for trap_name in ANTI_COLLECTABLE_TRAPS: |
| 75 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name | 84 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name |
| 76 | 85 | ||
| 86 | for game_map in self.objects.maps: | ||
| 87 | if game_map.HasField("rte_room"): | ||
| 88 | self.item_id_to_name[game_map.rte_ap_id] = self.get_map_rte_item_name(game_map.id) | ||
| 89 | |||
| 77 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} | 90 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} |
| 78 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} | 91 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} |
| 79 | 92 | ||
| 80 | for panel in self.objects.panels: | 93 | for panel in self.objects.panels: |
| 81 | for letter in panel.answer.upper(): | 94 | for letter in panel.answer.upper(): |
| 82 | self.letter_weights[letter] = self.letter_weights.get(letter, 0) + 1 | 95 | if letter.isalpha(): |
| 96 | self.letter_weights[letter] = self.letter_weights.get(letter, 0) + 1 | ||
| 97 | |||
| 98 | self.door_id_by_ap_id = {door.ap_id: door.id for door in self.objects.doors if door.HasField("ap_id")} | ||
| 99 | self.port_id_by_ap_id = {port.ap_id: port.id for port in self.objects.ports if port.HasField("ap_id")} | ||
| 100 | |||
| 101 | self.map_id_by_name = {game_map.name: game_map.id for game_map in self.objects.maps} | ||
| 83 | 102 | ||
| 84 | def get_door_item_name(self, door: data_pb2.Door) -> str: | 103 | def get_door_item_name(self, door: data_pb2.Door) -> str: |
| 85 | return f"{self.get_map_object_map_name(door)} - {door.name}" | 104 | return f"{self.get_map_object_map_name(door)} - {door.name}" |
| @@ -104,7 +123,7 @@ class Lingo2StaticLogic: | |||
| 104 | if door.type != data_pb2.DoorType.STANDARD: | 123 | if door.type != data_pb2.DoorType.STANDARD: |
| 105 | return None | 124 | return None |
| 106 | 125 | ||
| 107 | if len(door.keyholders) > 0 or len(door.endings) > 0 or door.HasField("complete_at"): | 126 | if len(door.keyholders) > 0 or door.white_ending or door.HasField("complete_at"): |
| 108 | return None | 127 | return None |
| 109 | 128 | ||
| 110 | if len(door.panels) > 4: | 129 | if len(door.panels) > 4: |
| @@ -165,5 +184,13 @@ class Lingo2StaticLogic: | |||
| 165 | else: | 184 | else: |
| 166 | return game_map.display_name | 185 | return game_map.display_name |
| 167 | 186 | ||
| 168 | def get_data_version(self) -> int: | 187 | def get_room_object_map_id(self, obj) -> int: |
| 169 | return self.objects.version | 188 | return self.objects.rooms[obj.room_id].map_id |
| 189 | |||
| 190 | def get_map_rte_item_name(self, map_id: int) -> str: | ||
| 191 | game_map = self.objects.maps[map_id] | ||
| 192 | return f"Return to {game_map.display_name}" | ||
| 193 | |||
| 194 | def get_data_version(self) -> list[int]: | ||
| 195 | version = self.objects.version | ||
| 196 | return [version.major, version.minor, version.patch] | ||
