summary refs log tree commit diff stats
path: root/regions.py
diff options
context:
space:
mode:
authorStar Rauchenberger <fefferburbia@gmail.com>2023-12-10 13:15:42 -0500
committerGitHub <noreply@github.com>2023-12-10 19:15:42 +0100
commit99128f67a3b4478a5561b1ba33a2f3588a61a1df (patch)
tree6afdfc1d51bb8b6d22e6b20725aacaef9437ebb4 /regions.py
parentee4ebe472759e91d511f3f151311f3a54e68051b (diff)
downloadlingo-apworld-99128f67a3b4478a5561b1ba33a2f3588a61a1df.tar.gz
lingo-apworld-99128f67a3b4478a5561b1ba33a2f3588a61a1df.tar.bz2
lingo-apworld-99128f67a3b4478a5561b1ba33a2f3588a61a1df.zip
Lingo: Fix entrance checking being broken on default settings (#2506)
The most serious issue this PR addresses is that entrances that use doors without items (a small subset of doors when door shuffle is on, but *every* door when door shuffle is off, which is the default) underestimate the requirements needed to use that entrance. The logic would calculate the panels needed to open the door, but would neglect to keep track of the rooms those panels were in, meaning that doors would be considered openable if you had the colors needed to solve a panel that's in a room you have no access to.

Another issue is that, previously, logic would always consider the "ANOTHER TRY" panel accessible for the purposes of the LEVEL 2 panel hunt. This could result in seeds where the player is expected to have exactly the correct number of solves to reach LEVEL 2, but in reality is short by one because ANOTHER TRY itself is not revealed until the panel hunt is complete. This change marks ANOTHER TRY as non-counting, because even though it is technically a counting panel in-game, it can never contribute to the LEVEL 2 panel hunt. This issue could also apply to THE MASTER, since it is the only other counting panel with special access rules, although it is much less likely. This change adds special handling for counting THE MASTER. These issues were possible to manifest whenever the LEVEL 2 panel hunt was enabled, which it is by default.

Smaller logic issues also fixed in this PR:

* The Orange Tower Basement MASTERY panel was marked as requiring the mastery doors to be opened, when it was actually possible to get it without them by using a painting to get into the room.
* The Pilgrim Room painting item was incorrectly being marked as a filler item, despite it being progression.
* There has been another update to the game that adds connections between areas that were previously not connected. These changes were additive, which is why they are not critical.
* The panel stacks in the rhyme room now require both colours on each panel.
Diffstat (limited to 'regions.py')
-rw-r--r--regions.py15
1 files changed, 4 insertions, 11 deletions
diff --git a/regions.py b/regions.py index c24144a..bdc42f4 100644 --- a/regions.py +++ b/regions.py
@@ -4,7 +4,7 @@ from BaseClasses import Entrance, ItemClassification, Region
4from .items import LingoItem 4from .items import LingoItem
5from .locations import LingoLocation 5from .locations import LingoLocation
6from .player_logic import LingoPlayerLogic 6from .player_logic import LingoPlayerLogic
7from .rules import lingo_can_use_entrance, lingo_can_use_pilgrimage, make_location_lambda 7from .rules import lingo_can_use_entrance, make_location_lambda
8from .static_logic import ALL_ROOMS, PAINTINGS, Room, RoomAndDoor 8from .static_logic import ALL_ROOMS, PAINTINGS, Room, RoomAndDoor
9 9
10if TYPE_CHECKING: 10if TYPE_CHECKING:
@@ -25,15 +25,6 @@ def create_region(room: Room, world: "LingoWorld", player_logic: LingoPlayerLogi
25 return new_region 25 return new_region
26 26
27 27
28def handle_pilgrim_room(regions: Dict[str, Region], world: "LingoWorld", player_logic: LingoPlayerLogic) -> None:
29 target_region = regions["Pilgrim Antechamber"]
30 source_region = regions["Outside The Agreeable"]
31 source_region.connect(
32 target_region,
33 "Pilgrimage",
34 lambda state: lingo_can_use_pilgrimage(state, world, player_logic))
35
36
37def connect_entrance(regions: Dict[str, Region], source_region: Region, target_region: Region, description: str, 28def connect_entrance(regions: Dict[str, Region], source_region: Region, target_region: Region, description: str,
38 door: Optional[RoomAndDoor], world: "LingoWorld", player_logic: LingoPlayerLogic): 29 door: Optional[RoomAndDoor], world: "LingoWorld", player_logic: LingoPlayerLogic):
39 connection = Entrance(world.player, description, source_region) 30 connection = Entrance(world.player, description, source_region)
@@ -91,7 +82,9 @@ def create_regions(world: "LingoWorld", player_logic: LingoPlayerLogic) -> None:
91 connect_entrance(regions, regions[entrance.room], regions[room.name], entrance_name, entrance.door, world, 82 connect_entrance(regions, regions[entrance.room], regions[room.name], entrance_name, entrance.door, world,
92 player_logic) 83 player_logic)
93 84
94 handle_pilgrim_room(regions, world, player_logic) 85 # Add the fake pilgrimage.
86 connect_entrance(regions, regions["Outside The Agreeable"], regions["Pilgrim Antechamber"], "Pilgrimage",
87 RoomAndDoor("Pilgrim Antechamber", "Pilgrimage"), world, player_logic)
95 88
96 if early_color_hallways: 89 if early_color_hallways:
97 regions["Starting Room"].connect(regions["Outside The Undeterred"], "Early Color Hallways") 90 regions["Starting Room"].connect(regions["Outside The Undeterred"], "Early Color Hallways")