diff options
Diffstat (limited to 'client/Archipelago/gamedata.gd')
| -rw-r--r-- | client/Archipelago/gamedata.gd | 62 |
1 files changed, 62 insertions, 0 deletions
| diff --git a/client/Archipelago/gamedata.gd b/client/Archipelago/gamedata.gd index 16368a9..41d966a 100644 --- a/client/Archipelago/gamedata.gd +++ b/client/Archipelago/gamedata.gd | |||
| @@ -5,13 +5,42 @@ var SCRIPT_proto | |||
| 5 | var objects | 5 | var objects |
| 6 | var door_id_by_map_node_path = {} | 6 | var door_id_by_map_node_path = {} |
| 7 | var painting_id_by_map_node_path = {} | 7 | var painting_id_by_map_node_path = {} |
| 8 | var panel_id_by_map_node_path = {} | ||
| 8 | var door_id_by_ap_id = {} | 9 | var door_id_by_ap_id = {} |
| 9 | var map_id_by_name = {} | 10 | var map_id_by_name = {} |
| 11 | var progressive_id_by_ap_id = {} | ||
| 12 | var letter_id_by_ap_id = {} | ||
| 13 | var symbol_item_ids = [] | ||
| 14 | var anti_trap_ids = {} | ||
| 15 | |||
| 16 | var kSYMBOL_ITEMS | ||
| 10 | 17 | ||
| 11 | 18 | ||
| 12 | func _init(proto_script): | 19 | func _init(proto_script): |
| 13 | SCRIPT_proto = proto_script | 20 | SCRIPT_proto = proto_script |
| 14 | 21 | ||
| 22 | kSYMBOL_ITEMS = { | ||
| 23 | SCRIPT_proto.PuzzleSymbol.SUN: "Sun Symbol", | ||
| 24 | SCRIPT_proto.PuzzleSymbol.SPARKLES: "Sparkles Symbol", | ||
| 25 | SCRIPT_proto.PuzzleSymbol.ZERO: "Zero Symbol", | ||
| 26 | SCRIPT_proto.PuzzleSymbol.EXAMPLE: "Example Symbol", | ||
| 27 | SCRIPT_proto.PuzzleSymbol.BOXES: "Boxes Symbol", | ||
| 28 | SCRIPT_proto.PuzzleSymbol.PLANET: "Planet Symbol", | ||
| 29 | SCRIPT_proto.PuzzleSymbol.PYRAMID: "Pyramid Symbol", | ||
| 30 | SCRIPT_proto.PuzzleSymbol.CROSS: "Cross Symbol", | ||
| 31 | SCRIPT_proto.PuzzleSymbol.SWEET: "Sweet Symbol", | ||
| 32 | SCRIPT_proto.PuzzleSymbol.GENDER: "Gender Symbol", | ||
| 33 | SCRIPT_proto.PuzzleSymbol.AGE: "Age Symbol", | ||
| 34 | SCRIPT_proto.PuzzleSymbol.SOUND: "Sound Symbol", | ||
| 35 | SCRIPT_proto.PuzzleSymbol.ANAGRAM: "Anagram Symbol", | ||
| 36 | SCRIPT_proto.PuzzleSymbol.JOB: "Job Symbol", | ||
| 37 | SCRIPT_proto.PuzzleSymbol.STARS: "Stars Symbol", | ||
| 38 | SCRIPT_proto.PuzzleSymbol.NULL: "Null Symbol", | ||
| 39 | SCRIPT_proto.PuzzleSymbol.EVAL: "Eval Symbol", | ||
| 40 | SCRIPT_proto.PuzzleSymbol.LINGO: "Lingo Symbol", | ||
| 41 | SCRIPT_proto.PuzzleSymbol.QUESTION: "Question Symbol", | ||
| 42 | } | ||
| 43 | |||
| 15 | 44 | ||
| 16 | func load(data_bytes): | 45 | func load(data_bytes): |
| 17 | objects = SCRIPT_proto.AllObjects.new() | 46 | objects = SCRIPT_proto.AllObjects.new() |
| @@ -50,6 +79,31 @@ func load(data_bytes): | |||
| 50 | 79 | ||
| 51 | var _map_data = painting_id_by_map_node_path[map.get_name()] | 80 | var _map_data = painting_id_by_map_node_path[map.get_name()] |
| 52 | 81 | ||
| 82 | for progressive in objects.get_progressives(): | ||
| 83 | progressive_id_by_ap_id[progressive.get_ap_id()] = progressive.get_id() | ||
| 84 | |||
| 85 | for letter in objects.get_letters(): | ||
| 86 | letter_id_by_ap_id[letter.get_ap_id()] = letter.get_id() | ||
| 87 | |||
| 88 | for panel in objects.get_panels(): | ||
| 89 | var room = objects.get_rooms()[panel.get_room_id()] | ||
| 90 | var map = objects.get_maps()[room.get_map_id()] | ||
| 91 | |||
| 92 | if not map.get_name() in panel_id_by_map_node_path: | ||
| 93 | panel_id_by_map_node_path[map.get_name()] = {} | ||
| 94 | |||
| 95 | var map_data = panel_id_by_map_node_path[map.get_name()] | ||
| 96 | map_data[panel.get_path()] = panel.get_id() | ||
| 97 | |||
| 98 | for symbol_name in kSYMBOL_ITEMS.values(): | ||
| 99 | symbol_item_ids.append(objects.get_special_ids()[symbol_name]) | ||
| 100 | |||
| 101 | for special_name in objects.get_special_ids().keys(): | ||
| 102 | if special_name.begins_with("Anti "): | ||
| 103 | anti_trap_ids[objects.get_special_ids()[special_name]] = ( | ||
| 104 | special_name.substr(5).to_lower() | ||
| 105 | ) | ||
| 106 | |||
| 53 | 107 | ||
| 54 | func get_door_for_map_node_path(map_name, node_path): | 108 | func get_door_for_map_node_path(map_name, node_path): |
| 55 | if not door_id_by_map_node_path.has(map_name): | 109 | if not door_id_by_map_node_path.has(map_name): |
| @@ -59,6 +113,14 @@ func get_door_for_map_node_path(map_name, node_path): | |||
| 59 | return map_data.get(node_path, null) | 113 | return map_data.get(node_path, null) |
| 60 | 114 | ||
| 61 | 115 | ||
| 116 | func get_panel_for_map_node_path(map_name, node_path): | ||
| 117 | if not panel_id_by_map_node_path.has(map_name): | ||
| 118 | return null | ||
| 119 | |||
| 120 | var map_data = panel_id_by_map_node_path[map_name] | ||
| 121 | return map_data.get(node_path, null) | ||
| 122 | |||
| 123 | |||
| 62 | func get_door_ap_id(door_id): | 124 | func get_door_ap_id(door_id): |
| 63 | var door = objects.get_doors()[door_id] | 125 | var door = objects.get_doors()[door_id] |
| 64 | if door.has_ap_id(): | 126 | if door.has_ap_id(): |
