diff options
Diffstat (limited to 'apworld/static_logic.py')
| -rw-r--r-- | apworld/static_logic.py | 63 |
1 files changed, 52 insertions, 11 deletions
| diff --git a/apworld/static_logic.py b/apworld/static_logic.py index ff1f17d..2700601 100644 --- a/apworld/static_logic.py +++ b/apworld/static_logic.py | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | from .generated import data_pb2 as data_pb2 | 1 | from .generated import data_pb2 as data_pb2 |
| 2 | from .items import SYMBOL_ITEMS, ANTI_COLLECTABLE_TRAPS | ||
| 2 | import pkgutil | 3 | import pkgutil |
| 3 | 4 | ||
| 4 | class Lingo2StaticLogic: | 5 | class Lingo2StaticLogic: |
| @@ -8,9 +9,17 @@ class Lingo2StaticLogic: | |||
| 8 | item_name_to_id: dict[str, int] | 9 | item_name_to_id: dict[str, int] |
| 9 | location_name_to_id: dict[str, int] | 10 | location_name_to_id: dict[str, int] |
| 10 | 11 | ||
| 12 | item_name_groups: dict[str, list[str]] | ||
| 13 | location_name_groups: dict[str, list[str]] | ||
| 14 | |||
| 15 | letter_weights: dict[str, int] | ||
| 16 | |||
| 11 | def __init__(self): | 17 | def __init__(self): |
| 12 | self.item_id_to_name = {} | 18 | self.item_id_to_name = {} |
| 13 | self.location_id_to_name = {} | 19 | self.location_id_to_name = {} |
| 20 | self.item_name_groups = {} | ||
| 21 | self.location_name_groups = {} | ||
| 22 | self.letter_weights = {} | ||
| 14 | 23 | ||
| 15 | file = pkgutil.get_data(__name__, "generated/data.binpb") | 24 | file = pkgutil.get_data(__name__, "generated/data.binpb") |
| 16 | self.objects = data_pb2.AllObjects() | 25 | self.objects = data_pb2.AllObjects() |
| @@ -29,23 +38,49 @@ class Lingo2StaticLogic: | |||
| 29 | letter_name = f"{letter.key.upper()}{'2' if letter.level2 else '1'}" | 38 | letter_name = f"{letter.key.upper()}{'2' if letter.level2 else '1'}" |
| 30 | location_name = f"{self.get_room_object_map_name(letter)} - {letter_name}" | 39 | location_name = f"{self.get_room_object_map_name(letter)} - {letter_name}" |
| 31 | self.location_id_to_name[letter.ap_id] = location_name | 40 | self.location_id_to_name[letter.ap_id] = location_name |
| 41 | self.location_name_groups.setdefault("Letters", []).append(location_name) | ||
| 32 | 42 | ||
| 33 | if not letter.level2: | 43 | if not letter.level2: |
| 34 | self.item_id_to_name[letter.ap_id] = letter_name | 44 | self.item_id_to_name[letter.ap_id] = letter.key.upper() |
| 45 | self.item_name_groups.setdefault("Letters", []).append(letter.key.upper()) | ||
| 35 | 46 | ||
| 36 | for mastery in self.objects.masteries: | 47 | for mastery in self.objects.masteries: |
| 37 | location_name = f"{self.get_room_object_map_name(mastery)} - Mastery" | 48 | location_name = f"{self.get_room_object_map_name(mastery)} - Mastery" |
| 38 | self.location_id_to_name[mastery.ap_id] = location_name | 49 | self.location_id_to_name[mastery.ap_id] = location_name |
| 50 | self.location_name_groups.setdefault("Masteries", []).append(location_name) | ||
| 39 | 51 | ||
| 40 | for ending in self.objects.endings: | 52 | for ending in self.objects.endings: |
| 41 | location_name = f"{self.get_room_object_map_name(ending)} - {ending.name.title()} Ending" | 53 | location_name = f"{self.get_room_object_map_name(ending)} - {ending.name.title()} Ending" |
| 42 | self.location_id_to_name[ending.ap_id] = location_name | 54 | self.location_id_to_name[ending.ap_id] = location_name |
| 55 | self.location_name_groups.setdefault("Endings", []).append(location_name) | ||
| 56 | |||
| 57 | for progressive in self.objects.progressives: | ||
| 58 | self.item_id_to_name[progressive.ap_id] = progressive.name | ||
| 59 | |||
| 60 | for door_group in self.objects.door_groups: | ||
| 61 | self.item_id_to_name[door_group.ap_id] = door_group.name | ||
| 62 | |||
| 63 | for keyholder in self.objects.keyholders: | ||
| 64 | if keyholder.HasField("key"): | ||
| 65 | location_name = f"{self.get_room_object_location_prefix(keyholder)} - {keyholder.key.upper()} Keyholder" | ||
| 66 | self.location_id_to_name[keyholder.ap_id] = location_name | ||
| 67 | self.location_name_groups.setdefault("Keyholders", []).append(location_name) | ||
| 43 | 68 | ||
| 44 | self.item_id_to_name[self.objects.special_ids["Nothing"]] = "Nothing" | 69 | self.item_id_to_name[self.objects.special_ids["A Job Well Done"]] = "A Job Well Done" |
| 70 | |||
| 71 | for symbol_name in SYMBOL_ITEMS.values(): | ||
| 72 | self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name | ||
| 73 | |||
| 74 | for trap_name in ANTI_COLLECTABLE_TRAPS: | ||
| 75 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name | ||
| 45 | 76 | ||
| 46 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} | 77 | self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} |
| 47 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} | 78 | self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} |
| 48 | 79 | ||
| 80 | for panel in self.objects.panels: | ||
| 81 | for letter in panel.answer.upper(): | ||
| 82 | self.letter_weights[letter] = self.letter_weights.get(letter, 0) + 1 | ||
| 83 | |||
| 49 | def get_door_item_name(self, door: data_pb2.Door) -> str: | 84 | def get_door_item_name(self, door: data_pb2.Door) -> str: |
| 50 | return f"{self.get_map_object_map_name(door)} - {door.name}" | 85 | return f"{self.get_map_object_map_name(door)} - {door.name}" |
| 51 | 86 | ||
| @@ -54,13 +89,7 @@ class Lingo2StaticLogic: | |||
| 54 | return self.get_door_item_name(door_id) | 89 | return self.get_door_item_name(door_id) |
| 55 | 90 | ||
| 56 | def get_door_location_name(self, door: data_pb2.Door) -> str: | 91 | def get_door_location_name(self, door: data_pb2.Door) -> str: |
| 57 | game_map = self.objects.maps[door.map_id] | 92 | map_part = self.get_room_object_location_prefix(door) |
| 58 | room = self.objects.rooms[door.room_id] | ||
| 59 | |||
| 60 | if room.HasField("panel_display_name"): | ||
| 61 | map_part = f"{game_map.display_name} ({room.panel_display_name})" | ||
| 62 | else: | ||
| 63 | map_part = game_map.display_name | ||
| 64 | 93 | ||
| 65 | if door.HasField("location_name"): | 94 | if door.HasField("location_name"): |
| 66 | return f"{map_part} - {door.location_name}" | 95 | return f"{map_part} - {door.location_name}" |
| @@ -75,7 +104,7 @@ class Lingo2StaticLogic: | |||
| 75 | if door.type != data_pb2.DoorType.STANDARD: | 104 | if door.type != data_pb2.DoorType.STANDARD: |
| 76 | return None | 105 | return None |
| 77 | 106 | ||
| 78 | if len(door.keyholders) > 0 or len(door.endings) > 0: | 107 | if len(door.keyholders) > 0 or len(door.endings) > 0 or not door.HasField("complete_at"): |
| 79 | return None | 108 | return None |
| 80 | 109 | ||
| 81 | if len(door.panels) > 4: | 110 | if len(door.panels) > 4: |
| @@ -111,7 +140,7 @@ class Lingo2StaticLogic: | |||
| 111 | for panel_id in door.panels] | 140 | for panel_id in door.panels] |
| 112 | panel_names.sort() | 141 | panel_names.sort() |
| 113 | 142 | ||
| 114 | return f"{map_part} - {", ".join(panel_names)}" | 143 | return map_part + " - " + ", ".join(panel_names) |
| 115 | 144 | ||
| 116 | def get_door_location_name_by_id(self, door_id: int) -> str: | 145 | def get_door_location_name_by_id(self, door_id: int) -> str: |
| 117 | door = self.objects.doors[door_id] | 146 | door = self.objects.doors[door_id] |
| @@ -126,3 +155,15 @@ class Lingo2StaticLogic: | |||
| 126 | 155 | ||
| 127 | def get_room_object_map_name(self, obj) -> str: | 156 | def get_room_object_map_name(self, obj) -> str: |
| 128 | return self.get_map_object_map_name(self.objects.rooms[obj.room_id]) | 157 | return self.get_map_object_map_name(self.objects.rooms[obj.room_id]) |
| 158 | |||
| 159 | def get_room_object_location_prefix(self, obj) -> str: | ||
| 160 | room = self.objects.rooms[obj.room_id] | ||
| 161 | game_map = self.objects.maps[room.map_id] | ||
| 162 | |||
| 163 | if room.HasField("panel_display_name"): | ||
| 164 | return f"{game_map.display_name} ({room.panel_display_name})" | ||
| 165 | else: | ||
| 166 | return game_map.display_name | ||
| 167 | |||
| 168 | def get_data_version(self) -> int: | ||
| 169 | return self.objects.version | ||
