| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | import os | 
					
						
							|  |  |  | import pkgutil | 
					
						
							| 
									
										
											  
											
												Lingo: The Pilgrim Update (#2884)
* An option was added to enable or disable the pilgrimage, and it defaults to disabled. When disabled, the client will prevent you from performing a pilgrimage (i.e. the yellow border will not appear when you enter the 1 sunwarp). The sun painting is added to the item pool when pilgrimage is disabled, as otherwise there is no way into the Pilgrim Antechamber. Inversely, the sun painting is no longer in the item pool when pilgrimage is enabled (even if door shuffle is on), requiring you to perform a pilgrimage to get to that room.
* The canonical pilgrimage has been deprecated. Instead, there is logic for determining whether a pilgrimage is possible.
* Two options were added that allow the player to decide whether paintings and/or Crossroads - Roof Access are permitted during the pilgrimage. Both default to disabled. These options apply both to logical expectations in the generator, and are also enforced by the game client.
* An option was added to control how sunwarps are accessed. The default is for them to always be accessible, like in the base game. It is also possible to disable them entirely (which is not possible when pilgrimage is enabled), or lock them behind items similar to door shuffle. It can either be one item that unlocks all sunwarps at the same time, six progressive items that unlock the sunwarps from 1 to 6, or six individual items that unlock the sunwarps in any order. This option is independent from door shuffle.
* An option was added that shuffles sunwarps. This acts similarly to painting shuffle. The 12 sunwarps are re-ordered and re-paired. Sunwarps that were previously entrances or exits do not need to stay entrances or exits. Performing a pilgrimage requires proceeding through the sunwarps in the new order, rather than the original one.
* Pilgrimage was added as a win condition. It requires you to solve the blue PILGRIM panel in the Pilgrim Antechamber.
											
										 
											2024-04-18 11:45:33 -05:00
										 |  |  | import pickle | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | from io import BytesIO | 
					
						
							|  |  |  | from typing import Dict, List, Set | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  | from .datatypes import Door, Painting, Panel, PanelDoor, Progression, Room | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ALL_ROOMS: List[Room] = [] | 
					
						
							|  |  |  | DOORS_BY_ROOM: Dict[str, Dict[str, Door]] = {} | 
					
						
							|  |  |  | PANELS_BY_ROOM: Dict[str, Dict[str, Panel]] = {} | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  | PANEL_DOORS_BY_ROOM: Dict[str, Dict[str, PanelDoor]] = {} | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | PAINTINGS: Dict[str, Painting] = {} | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  | PROGRESSIVE_ITEMS: Set[str] = set() | 
					
						
							|  |  |  | PROGRESSIVE_DOORS_BY_ROOM: Dict[str, Dict[str, Progression]] = {} | 
					
						
							|  |  |  | PROGRESSIVE_PANELS_BY_ROOM: Dict[str, Dict[str, Progression]] = {} | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | PAINTING_ENTRANCES: int = 0 | 
					
						
							|  |  |  | PAINTING_EXIT_ROOMS: Set[str] = set() | 
					
						
							|  |  |  | PAINTING_EXITS: int = 0 | 
					
						
							|  |  |  | REQUIRED_PAINTING_ROOMS: List[str] = [] | 
					
						
							|  |  |  | REQUIRED_PAINTING_WHEN_NO_DOORS_ROOMS: List[str] = [] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Lingo: The Pilgrim Update (#2884)
* An option was added to enable or disable the pilgrimage, and it defaults to disabled. When disabled, the client will prevent you from performing a pilgrimage (i.e. the yellow border will not appear when you enter the 1 sunwarp). The sun painting is added to the item pool when pilgrimage is disabled, as otherwise there is no way into the Pilgrim Antechamber. Inversely, the sun painting is no longer in the item pool when pilgrimage is enabled (even if door shuffle is on), requiring you to perform a pilgrimage to get to that room.
* The canonical pilgrimage has been deprecated. Instead, there is logic for determining whether a pilgrimage is possible.
* Two options were added that allow the player to decide whether paintings and/or Crossroads - Roof Access are permitted during the pilgrimage. Both default to disabled. These options apply both to logical expectations in the generator, and are also enforced by the game client.
* An option was added to control how sunwarps are accessed. The default is for them to always be accessible, like in the base game. It is also possible to disable them entirely (which is not possible when pilgrimage is enabled), or lock them behind items similar to door shuffle. It can either be one item that unlocks all sunwarps at the same time, six progressive items that unlock the sunwarps from 1 to 6, or six individual items that unlock the sunwarps in any order. This option is independent from door shuffle.
* An option was added that shuffles sunwarps. This acts similarly to painting shuffle. The 12 sunwarps are re-ordered and re-paired. Sunwarps that were previously entrances or exits do not need to stay entrances or exits. Performing a pilgrimage requires proceeding through the sunwarps in the new order, rather than the original one.
* Pilgrimage was added as a win condition. It requires you to solve the blue PILGRIM panel in the Pilgrim Antechamber.
											
										 
											2024-04-18 11:45:33 -05:00
										 |  |  | SUNWARP_ENTRANCES: List[str] = [] | 
					
						
							|  |  |  | SUNWARP_EXITS: List[str] = [] | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | SPECIAL_ITEM_IDS: Dict[str, int] = {} | 
					
						
							|  |  |  | PANEL_LOCATION_IDS: Dict[str, Dict[str, int]] = {} | 
					
						
							|  |  |  | DOOR_LOCATION_IDS: Dict[str, Dict[str, int]] = {} | 
					
						
							|  |  |  | DOOR_ITEM_IDS: Dict[str, Dict[str, int]] = {} | 
					
						
							|  |  |  | DOOR_GROUP_ITEM_IDS: Dict[str, int] = {} | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  | PANEL_DOOR_ITEM_IDS: Dict[str, Dict[str, int]] = {} | 
					
						
							|  |  |  | PANEL_GROUP_ITEM_IDS: Dict[str, int] = {} | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | PROGRESSIVE_ITEM_IDS: Dict[str, int] = {} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | HASHES: Dict[str, str] = {} | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_special_item_id(name: str): | 
					
						
							|  |  |  |     if name not in SPECIAL_ITEM_IDS: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for special item {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return SPECIAL_ITEM_IDS[name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_panel_location_id(room: str, name: str): | 
					
						
							|  |  |  |     if room not in PANEL_LOCATION_IDS or name not in PANEL_LOCATION_IDS[room]: | 
					
						
							|  |  |  |         raise Exception(f"Location ID for panel {room} - {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return PANEL_LOCATION_IDS[room][name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_door_location_id(room: str, name: str): | 
					
						
							|  |  |  |     if room not in DOOR_LOCATION_IDS or name not in DOOR_LOCATION_IDS[room]: | 
					
						
							|  |  |  |         raise Exception(f"Location ID for door {room} - {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return DOOR_LOCATION_IDS[room][name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_door_item_id(room: str, name: str): | 
					
						
							|  |  |  |     if room not in DOOR_ITEM_IDS or name not in DOOR_ITEM_IDS[room]: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for door {room} - {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return DOOR_ITEM_IDS[room][name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_door_group_item_id(name: str): | 
					
						
							|  |  |  |     if name not in DOOR_GROUP_ITEM_IDS: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for door group {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return DOOR_GROUP_ITEM_IDS[name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  | def get_panel_door_item_id(room: str, name: str): | 
					
						
							|  |  |  |     if room not in PANEL_DOOR_ITEM_IDS or name not in PANEL_DOOR_ITEM_IDS[room]: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for panel door {room} - {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return PANEL_DOOR_ITEM_IDS[room][name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | def get_panel_group_item_id(name: str): | 
					
						
							|  |  |  |     if name not in PANEL_GROUP_ITEM_IDS: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for panel group {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return PANEL_GROUP_ITEM_IDS[name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | def get_progressive_item_id(name: str): | 
					
						
							|  |  |  |     if name not in PROGRESSIVE_ITEM_IDS: | 
					
						
							|  |  |  |         raise Exception(f"Item ID for progressive item {name} not found in ids.yaml.") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return PROGRESSIVE_ITEM_IDS[name] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | def load_static_data_from_file(): | 
					
						
							|  |  |  |     global PAINTING_ENTRANCES, PAINTING_EXITS | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-29 13:38:29 -05:00
										 |  |  |     from . import datatypes | 
					
						
							|  |  |  |     from Utils import safe_builtins | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  |     class RenameUnpickler(pickle.Unpickler): | 
					
						
							|  |  |  |         def find_class(self, module, name): | 
					
						
							| 
									
										
										
										
											2024-04-29 13:38:29 -05:00
										 |  |  |             if module in ("worlds.lingo.datatypes", "datatypes"): | 
					
						
							|  |  |  |                 return getattr(datatypes, name) | 
					
						
							|  |  |  |             elif module == "builtins" and name in safe_builtins: | 
					
						
							|  |  |  |                 return getattr(safe_builtins, name) | 
					
						
							|  |  |  |             raise pickle.UnpicklingError(f"global '{module}.{name}' is forbidden") | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-12-08 19:59:40 -05:00
										 |  |  |     file = pkgutil.get_data(__name__, "data/generated.dat") | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  |     pickdata = RenameUnpickler(BytesIO(file)).load() | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |     HASHES.update(pickdata["HASHES"]) | 
					
						
							|  |  |  |     PAINTINGS.update(pickdata["PAINTINGS"]) | 
					
						
							|  |  |  |     ALL_ROOMS.extend(pickdata["ALL_ROOMS"]) | 
					
						
							|  |  |  |     DOORS_BY_ROOM.update(pickdata["DOORS_BY_ROOM"]) | 
					
						
							|  |  |  |     PANELS_BY_ROOM.update(pickdata["PANELS_BY_ROOM"]) | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  |     PANEL_DOORS_BY_ROOM.update(pickdata["PANEL_DOORS_BY_ROOM"]) | 
					
						
							|  |  |  |     PROGRESSIVE_ITEMS.update(pickdata["PROGRESSIVE_ITEMS"]) | 
					
						
							|  |  |  |     PROGRESSIVE_DOORS_BY_ROOM.update(pickdata["PROGRESSIVE_DOORS_BY_ROOM"]) | 
					
						
							|  |  |  |     PROGRESSIVE_PANELS_BY_ROOM.update(pickdata["PROGRESSIVE_PANELS_BY_ROOM"]) | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  |     PAINTING_ENTRANCES = pickdata["PAINTING_ENTRANCES"] | 
					
						
							|  |  |  |     PAINTING_EXIT_ROOMS.update(pickdata["PAINTING_EXIT_ROOMS"]) | 
					
						
							|  |  |  |     PAINTING_EXITS = pickdata["PAINTING_EXITS"] | 
					
						
							|  |  |  |     REQUIRED_PAINTING_ROOMS.extend(pickdata["REQUIRED_PAINTING_ROOMS"]) | 
					
						
							|  |  |  |     REQUIRED_PAINTING_WHEN_NO_DOORS_ROOMS.extend(pickdata["REQUIRED_PAINTING_WHEN_NO_DOORS_ROOMS"]) | 
					
						
							| 
									
										
											  
											
												Lingo: The Pilgrim Update (#2884)
* An option was added to enable or disable the pilgrimage, and it defaults to disabled. When disabled, the client will prevent you from performing a pilgrimage (i.e. the yellow border will not appear when you enter the 1 sunwarp). The sun painting is added to the item pool when pilgrimage is disabled, as otherwise there is no way into the Pilgrim Antechamber. Inversely, the sun painting is no longer in the item pool when pilgrimage is enabled (even if door shuffle is on), requiring you to perform a pilgrimage to get to that room.
* The canonical pilgrimage has been deprecated. Instead, there is logic for determining whether a pilgrimage is possible.
* Two options were added that allow the player to decide whether paintings and/or Crossroads - Roof Access are permitted during the pilgrimage. Both default to disabled. These options apply both to logical expectations in the generator, and are also enforced by the game client.
* An option was added to control how sunwarps are accessed. The default is for them to always be accessible, like in the base game. It is also possible to disable them entirely (which is not possible when pilgrimage is enabled), or lock them behind items similar to door shuffle. It can either be one item that unlocks all sunwarps at the same time, six progressive items that unlock the sunwarps from 1 to 6, or six individual items that unlock the sunwarps in any order. This option is independent from door shuffle.
* An option was added that shuffles sunwarps. This acts similarly to painting shuffle. The 12 sunwarps are re-ordered and re-paired. Sunwarps that were previously entrances or exits do not need to stay entrances or exits. Performing a pilgrimage requires proceeding through the sunwarps in the new order, rather than the original one.
* Pilgrimage was added as a win condition. It requires you to solve the blue PILGRIM panel in the Pilgrim Antechamber.
											
										 
											2024-04-18 11:45:33 -05:00
										 |  |  |     SUNWARP_ENTRANCES.extend(pickdata["SUNWARP_ENTRANCES"]) | 
					
						
							|  |  |  |     SUNWARP_EXITS.extend(pickdata["SUNWARP_EXITS"]) | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  |     SPECIAL_ITEM_IDS.update(pickdata["SPECIAL_ITEM_IDS"]) | 
					
						
							|  |  |  |     PANEL_LOCATION_IDS.update(pickdata["PANEL_LOCATION_IDS"]) | 
					
						
							|  |  |  |     DOOR_LOCATION_IDS.update(pickdata["DOOR_LOCATION_IDS"]) | 
					
						
							|  |  |  |     DOOR_ITEM_IDS.update(pickdata["DOOR_ITEM_IDS"]) | 
					
						
							|  |  |  |     DOOR_GROUP_ITEM_IDS.update(pickdata["DOOR_GROUP_ITEM_IDS"]) | 
					
						
							| 
									
										
										
										
											2024-07-26 04:53:11 -04:00
										 |  |  |     PANEL_DOOR_ITEM_IDS.update(pickdata["PANEL_DOOR_ITEM_IDS"]) | 
					
						
							|  |  |  |     PANEL_GROUP_ITEM_IDS.update(pickdata["PANEL_GROUP_ITEM_IDS"]) | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  |     PROGRESSIVE_ITEM_IDS.update(pickdata["PROGRESSIVE_ITEM_IDS"]) | 
					
						
							| 
									
										
										
										
											2023-11-08 18:35:12 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | # Initialize the static data at module scope. | 
					
						
							| 
									
										
										
										
											2024-03-15 04:26:00 -04:00
										 |  |  | load_static_data_from_file() |