From c456854263be17264aeb8446986bc401d3921f33 Mon Sep 17 00:00:00 2001 From: Star Rauchenberger Date: Sat, 13 Sep 2025 11:34:49 -0400 Subject: Added anti collectable traps --- apworld/static_logic.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'apworld/static_logic.py') 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 @@ from .generated import data_pb2 as data_pb2 -from .items import SYMBOL_ITEMS +from .items import SYMBOL_ITEMS, ANTI_COLLECTABLE_TRAPS import pkgutil class Lingo2StaticLogic: @@ -12,11 +12,14 @@ class Lingo2StaticLogic: item_name_groups: dict[str, list[str]] location_name_groups: dict[str, list[str]] + letter_weights: dict[str, int] + def __init__(self): self.item_id_to_name = {} self.location_id_to_name = {} self.item_name_groups = {} self.location_name_groups = {} + self.letter_weights = {} file = pkgutil.get_data(__name__, "generated/data.binpb") self.objects = data_pb2.AllObjects() @@ -68,9 +71,16 @@ class Lingo2StaticLogic: for symbol_name in SYMBOL_ITEMS.values(): self.item_id_to_name[self.objects.special_ids[symbol_name]] = symbol_name + for trap_name in ANTI_COLLECTABLE_TRAPS: + self.item_id_to_name[self.objects.special_ids[trap_name]] = trap_name + self.item_name_to_id = {name: ap_id for ap_id, name in self.item_id_to_name.items()} self.location_name_to_id = {name: ap_id for ap_id, name in self.location_id_to_name.items()} + for panel in self.objects.panels: + for letter in panel.answer.upper(): + self.letter_weights[letter] = self.letter_weights.get(letter, 0) + 1 + def get_door_item_name(self, door: data_pb2.Door) -> str: return f"{self.get_map_object_map_name(door)} - {door.name}" -- cgit 1.4.1