mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	entrances and locations
This commit is contained in:
		
							
								
								
									
										128
									
								
								Rules.py
									
									
									
									
									
								
							
							
						
						
									
										128
									
								
								Rules.py
									
									
									
									
									
								
							| @@ -713,57 +713,113 @@ def add_conditional_lamps(world, player): | |||||||
|  |  | ||||||
|  |  | ||||||
| def overworld_glitches_rules(world, player): | def overworld_glitches_rules(world, player): | ||||||
|     # spots that are immediately accessible |     # spots that are immediately accessible due to fake flippering | ||||||
|     set_rule(world.get_entrance('Hobo Bridge', player), lambda state: True) |     set_rule(world.get_entrance('Hobo Bridge', player), lambda state: True) | ||||||
|     set_rule(world.get_region('Lake Hylia Central Island', player), lambda state: True) |     set_rule(world.get_region('Lake Hylia Central Island', player), lambda state: True) | ||||||
|     set_rule(world.get_entrance('Zoras River', player), lambda state: True) |     set_rule(world.get_entrance('Zoras River', player), lambda state: True) | ||||||
|     # lw boots-accessible locations |  | ||||||
|     lw_boots_accessible_regions = [ |     # boots-accessible stuff | ||||||
|  |     lw_boots_accessible_entrances = [ | ||||||
|         'Bat Cave Drop Ledge', |         'Bat Cave Drop Ledge', | ||||||
|  |         'Bat Cave Drop Ledge Mirror Spot', | ||||||
|  |         'Lake Hylia Island Mirror Spot', | ||||||
|  |         'Desert Ledge Return Rocks', | ||||||
|  |         'Desert Ledge Mirror Spot', | ||||||
|  |         'Checkerboard Cave', | ||||||
|  |         'Old Man House Exit (Bottom)', | ||||||
|  |         'Desert Ledge (Northeast) Mirror Spot', | ||||||
|  |         'Death Mountain Return Cave Exit (East)', | ||||||
|  |         'Desert Palace Entrance (North) Rocks', | ||||||
|  |         'Desert Palace Entrance (North) Mirror Spot', | ||||||
|  |         'Flute Spot 1', | ||||||
|  |         'Broken Bridge (East)', | ||||||
|  |         'Death Mountain Drop', | ||||||
|  |         'Death Mountain Return Cave Exit (West)', | ||||||
|  |         'Old Man Cave Exit (East)', | ||||||
|  |         'Bumper Cave Ledge Mirror Spot', | ||||||
|  |         'Broken Bridge (West)', | ||||||
|  |         'East Death Mountain Drop', | ||||||
|  |         'Spiral Cave Ledge Drop', | ||||||
|  |         'Fairy Ascension Drop', | ||||||
|  |         'East Death Mountain (Top)', | ||||||
|  |         'East Death Mountain (Top) Mirror Spot', | ||||||
|  |         'Death Mountain (Top)', | ||||||
|  |         'Spectacle Rock Drop', | ||||||
|  |         'Spectacle Rock Mirror Spot', | ||||||
|  |         'Floating Island Mirror Spot', | ||||||
|  |         'Fairy Ascension Cave Exit (Top)', | ||||||
|  |         'Fairy Ascension Cave Exit (Bottom)', | ||||||
|  |         'Death Mountain Return Cave Exit (East)', | ||||||
|  |         'Spiral Cave Exit', | ||||||
|  |     ] | ||||||
|  |     lw_boots_accessible_locations = [ | ||||||
|         'Lake Hylia Island', |         'Lake Hylia Island', | ||||||
|         'Desert Ledge', |         'Desert Ledge', | ||||||
|         'Desert Ledge (Northeast)', |         'Ether Tablet', | ||||||
|         'Desert Palace Lone Stairs', |  | ||||||
|         'Desert Palace Entrance (North) Spot', |  | ||||||
|         'Death Mountain', |  | ||||||
|         'Death Mountain Return Ledge', |  | ||||||
|         'East Death Mountain (Bottom)', |  | ||||||
|         'East Death Mountain (Top)', |  | ||||||
|         'Death Mountain (Top)', |  | ||||||
|         'Spectacle Rock', |         'Spectacle Rock', | ||||||
|         'Death Mountain Floating Island (Light World)', |         'Floating Island', | ||||||
|     ] |     ] | ||||||
|     # dw boots-accessible regions |     dw_boots_accessible_entrances = [ | ||||||
|     dw_boots_accessible_regions = [ |         'Northeast Dark World Broken Bridge Pass', | ||||||
|         'East Dark World', |         'Death Mountain Return Cave Exit (West)', | ||||||
|         'Northeast Dark World', |         'Peg Area Rocks', | ||||||
|         'West Dark World', |         'Grassy Lawn Pegs', | ||||||
|         'Hammer Peg Area', |         'West Dark World Gap', | ||||||
|  |         'Bumper Cave Ledge Drop', | ||||||
|  |         'Turtle Rock Ledge Exit (West)', | ||||||
|  |         'Turtle Rock Isolated Ledge Exit', | ||||||
|  |         'Dark Desert Teleporter', | ||||||
|  |         'Turtle Rock Exit (Front)', | ||||||
|  |         'Turtle Rock Drop', | ||||||
|  |         'Floating Island Drop', | ||||||
|  |         'Turtle Rock Ledge Exit (East)', | ||||||
|  |         'Dark Death Mountain Drop (East)', | ||||||
|  |         'Village of Outcasts Drop', | ||||||
|  |         'Dark Lake Hylia Ledge', | ||||||
|  |         'Hype Cave', | ||||||
|  |         'Dark World Potion Shop', | ||||||
|  |         'Big Bomb Shop', | ||||||
|  |         'Archery Game', | ||||||
|  |         'Brewery', | ||||||
|  |         'C-Shaped House', | ||||||
|  |         'Chest Game', | ||||||
|  |         'Thieves Town', | ||||||
|  |         'Graveyard Ledge Mirror Spot', | ||||||
|  |         'Kings Grave Mirror Spot', | ||||||
|  |         'Bumper Cave Entrance Rock', | ||||||
|  |         'Red Shield Shop', | ||||||
|  |         'Dark Sanctuary Hint', | ||||||
|  |         'Fortune Teller (Dark)', | ||||||
|  |         'Dark World Lumberjack Shop', | ||||||
|  |     ] | ||||||
|  |     dw_boots_accessible_locations = [ | ||||||
|  |         'Catfish', | ||||||
|  |         'Frog', | ||||||
|  |         'Dark Blacksmith Ruins', | ||||||
|         'Bumper Cave Ledge', |         'Bumper Cave Ledge', | ||||||
|         'Dark Desert', |  | ||||||
|         'Dark Death Mountain (Top)', |  | ||||||
|         'Dark Death Mountain (East Bottom)', |  | ||||||
|         'Dark Death Mountain Ledge', |  | ||||||
|         'Death Mountain Floating Island (Dark World)', |  | ||||||
|         'Turtle Rock (Top)', |  | ||||||
|     ] |     ] | ||||||
|     # set up boots-accessible regions |     # set up boots-accessible regions | ||||||
|     if world.mode[player] != 'inverted': |     if world.mode[player] != 'inverted': | ||||||
|         lw_boots_accessible_regions.append('Cave 45 Ledge') |         lw_boots_accessible_entrances.append('Cave 45 Mirror Spot') | ||||||
|         lw_boots_accessible_regions.append('Graveyard Ledge') |         lw_boots_accessible_entrances.append('Graveyard Ledge Mirror Spot') | ||||||
|         # couple other random spots |         # couple other random spots | ||||||
|         set_rule(world.get_location('Bombos Tablet', player), lambda state: state.has('Book of Mudora', player) and state.has_beam_sword(player) and (state.has_Mirror(player) or state.has_Boots(player))) |         set_rule(world.get_location('Bombos Tablet', player), lambda state: state.has('Book of Mudora', player) and state.has_beam_sword(player) and (state.has_Mirror(player) or state.has_Boots(player))) | ||||||
|         set_rule(world.get_entrance('Dark Desert Teleporter', player), lambda state: (state.has('Ocarina', player) or state.has_Boots(player)) and state.can_lift_heavy_rocks(player)) |         set_rule(world.get_entrance('Dark Desert Teleporter', player), lambda state: state.has('Ocarina', player) or (state.has_Boots(player) and state.can_lift_heavy_rocks(player))) | ||||||
|         set_rule(world.get_location('Zora\'s Ledge', player), lambda state: state.has_Boots(player)) |         set_rule(world.get_location('Zora\'s Ledge', player), lambda state: state.has_Boots(player)) | ||||||
|         add_rule(world.get_entrance('Ganons Tower', player), lambda state: state.has_Boots(player) and state.has_Pearl(player), 'or') |         add_rule(world.get_entrance('Ganons Tower', player), lambda state: state.has_Boots(player) and state.has_Pearl(player), 'or') | ||||||
|  |         add_rule(world.get_entrance('East Death Mountain Teleporter', player), lambda state: state.can_lift_heavy_rocks(player) and state.has_Boots(player), 'or') | ||||||
|  |         add_rule(world.get_entrance('Turtle Rock Teleporter', player), lambda state: state.has_Boots(player) and state.has('Hammer', player)) | ||||||
|     needs_boots = lambda state: state.has_Boots(player) |     needs_boots = lambda state: state.has_Boots(player) | ||||||
|     needs_boots_and_pearl = lambda state: state.has_Boots(player) and state.has_Pearl(player) |     needs_boots_and_pearl = lambda state: state.has_Boots(player) and state.has_Pearl(player) | ||||||
|     for spot in lw_boots_accessible_regions: |     for entrance in lw_boots_accessible_entrances: | ||||||
|         for location in world.get_region(spot, player).locations: |         add_rule(world.get_entrance(entrance, player), needs_boots_and_pearl if world.mode[player] == 'inverted' else needs_boots, 'or') | ||||||
|  |     for location in lw_boots_accessible_locations: | ||||||
|         add_rule(world.get_location(location, player), needs_boots_and_pearl if world.mode[player] == 'inverted' else needs_boots, 'or') |         add_rule(world.get_location(location, player), needs_boots_and_pearl if world.mode[player] == 'inverted' else needs_boots, 'or') | ||||||
|     for spot in dw_boots_accessible_regions: |     # no inverted rules here; no DMD bunny known so far | ||||||
|         for location in world.get_region(spot, player).locations: |     for entrance in dw_boots_accessible_entrances: | ||||||
|             add_rule(world.get_location(location, player), needs_boots if world.mode[player] == 'inverted' else needs_boots_and_pearl, 'or') |         add_rule(world.get_entrance(entrance, player), needs_boots_and_pearl, 'or') | ||||||
|  |     for location in dw_boots_accessible_locations: | ||||||
|  |         add_rule(world.get_location(location, player), needs_boots_and_pearl, 'or') | ||||||
|     # bunny DMD rules |     # bunny DMD rules | ||||||
|     if world.mode[player] != 'inverted': |     if world.mode[player] != 'inverted': | ||||||
|         # set up some mirror-accessible dw entrances. |         # set up some mirror-accessible dw entrances. | ||||||
| @@ -779,13 +835,13 @@ def overworld_glitches_rules(world, player): | |||||||
|         ] |         ] | ||||||
|         mirror_hookshot_accessible_dw_locations.extend(world.get_region('Dark Death Mountain Ledge', player).locations) |         mirror_hookshot_accessible_dw_locations.extend(world.get_region('Dark Death Mountain Ledge', player).locations) | ||||||
|         for spot in mirror_hookshot_accessible_dw_locations: |         for spot in mirror_hookshot_accessible_dw_locations: | ||||||
|             add_rule(world.get_entrance(spot, player), lambda state: state.has_Boots(player) and state.has_Mirror(player) and state.has('Hookshot', player), 'or') |             add_rule(world.get_entrance(spot, player), lambda state: state.has_Mirror(player) and state.has('Hookshot', player), 'or') | ||||||
|         # dw entrances accessible with mirror and titans |         # dw entrances accessible with mirror and titans | ||||||
|         boots_mirror_titans = lambda state: state.has_Boots(player) and state.has_Mirror(player) and state.can_lift_heavy_rocks(player) |         boots_mirror_titans = lambda state: state.has_Mirror(player) and state.can_lift_heavy_rocks(player) | ||||||
|         add_rule(world.get_entrance('Mire Shed', player), boots_mirror_titans, 'or') |         add_rule(world.get_entrance('Mire Shed', player), boots_mirror_titans, 'or') | ||||||
|         add_rule(world.get_location('Frog', player), boots_mirror_titans, 'or') |         add_rule(world.get_location('Frog', player), boots_mirror_titans, 'or') | ||||||
|  |  | ||||||
|     # all entrances you can't mirror bunny into |     # all entrances you can't mirror bunny into. @todo: use for inverted | ||||||
|     invalid_mirror_bunny_entrances_lw = [ |     invalid_mirror_bunny_entrances_lw = [ | ||||||
|         'Bonk Rock Cave', |         'Bonk Rock Cave', | ||||||
|         'Bonk Fairy (Light)', |         'Bonk Fairy (Light)', | ||||||
| @@ -1372,7 +1428,7 @@ def set_bunny_rules(world, player): | |||||||
|  |  | ||||||
|     def get_rule_to_add(region, location = None): |     def get_rule_to_add(region, location = None): | ||||||
|         if not region.is_light_world: |         if not region.is_light_world: | ||||||
|             if location in superbunny_accessible_locations and region.name not in invalid_mirror_bunny_entrances_dw: |             if world.logic[player] == 'owglitches' and location in superbunny_accessible_locations and region.name not in invalid_mirror_bunny_entrances_dw: | ||||||
|                 return lambda state: (state.can_reach(region) and state.has_Mirror(player)) or state.has_Pearl(player) |                 return lambda state: (state.can_reach(region) and state.has_Mirror(player)) or state.has_Pearl(player) | ||||||
|             return lambda state: state.has_Pearl(player) |             return lambda state: state.has_Pearl(player) | ||||||
|         # in this case we are mixed region. |         # in this case we are mixed region. | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 qadan
					qadan