diff options
author | Star Rauchenberger <fefferburbia@gmail.com> | 2025-09-13 11:34:49 -0400 |
---|---|---|
committer | Star Rauchenberger <fefferburbia@gmail.com> | 2025-09-13 11:34:49 -0400 |
commit | c456854263be17264aeb8446986bc401d3921f33 (patch) | |
tree | a5c26c985f3f8dc1270f06f36ecc1dcb85385e6b /apworld/static_logic.py | |
parent | c909a4f022d252dc0da6b30c64e76cdfe9537460 (diff) | |
download | lingo2-archipelago-c456854263be17264aeb8446986bc401d3921f33.tar.gz lingo2-archipelago-c456854263be17264aeb8446986bc401d3921f33.tar.bz2 lingo2-archipelago-c456854263be17264aeb8446986bc401d3921f33.zip |
Added anti collectable traps
Diffstat (limited to 'apworld/static_logic.py')
-rw-r--r-- | apworld/static_logic.py | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/apworld/static_logic.py b/apworld/static_logic.py index 1017ec7..2700601 100644 --- a/apworld/static_logic.py +++ b/apworld/static_logic.py | |||
@@ -1,5 +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 | 2 | from .items import SYMBOL_ITEMS, ANTI_COLLECTABLE_TRAPS |
3 | import pkgutil | 3 | import pkgutil |
4 | 4 | ||
5 | class Lingo2StaticLogic: | 5 | class Lingo2StaticLogic: |
@@ -12,11 +12,14 @@ class Lingo2StaticLogic: | |||
12 | item_name_groups: dict[str, list[str]] | 12 | item_name_groups: dict[str, list[str]] |
13 | location_name_groups: dict[str, list[str]] | 13 | location_name_groups: dict[str, list[str]] |
14 | 14 | ||
15 | letter_weights: dict[str, int] | ||
16 | |||
15 | def __init__(self): | 17 | def __init__(self): |
16 | self.item_id_to_name = {} | 18 | self.item_id_to_name = {} |
17 | self.location_id_to_name = {} | 19 | self.location_id_to_name = {} |
18 | self.item_name_groups = {} | 20 | self.item_name_groups = {} |
19 | self.location_name_groups = {} | 21 | self.location_name_groups = {} |
22 | self.letter_weights = {} | ||
20 | 23 | ||
21 | file = pkgutil.get_data(__name__, "generated/data.binpb") | 24 | file = pkgutil.get_data(__name__, "generated/data.binpb") |
22 | self.objects = data_pb2.AllObjects() | 25 | self.objects = data_pb2.AllObjects() |
@@ -68,9 +71,16 @@ class Lingo2StaticLogic: | |||
68 | for symbol_name in SYMBOL_ITEMS.values(): | 71 | for symbol_name in SYMBOL_ITEMS.values(): |
69 | self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name | 72 | self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name |
70 | 73 | ||
74 | for trap_name in ANTI_COLLECTABLE_TRAPS: | ||
75 | self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name | ||
76 | |||
71 | 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()} |
72 | 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()} |
73 | 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 | |||
74 | def get_door_item_name(self, door: data_pb2.Door) -> str: | 84 | def get_door_item_name(self, door: data_pb2.Door) -> str: |
75 | return f"{self.get_map_object_map_name(door)} - {door.name}" | 85 | return f"{self.get_map_object_map_name(door)} - {door.name}" |
76 | 86 | ||