mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	Skip looping over every location in set_rules and set_entrances_based_rules, use filter instead
This commit is contained in:
		| @@ -74,6 +74,7 @@ class OOTLogic(LogicMixin): | |||||||
|                     self.path[new_region] = (new_region.name, self.path.get(connection, None)) |                     self.path[new_region] = (new_region.name, self.path.get(connection, None)) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | # Sets extra rules on various specific locations not handled by the rule parser. | ||||||
| def set_rules(ootworld): | def set_rules(ootworld): | ||||||
|     logger = logging.getLogger('') |     logger = logging.getLogger('') | ||||||
|  |  | ||||||
| @@ -92,44 +93,22 @@ def set_rules(ootworld): | |||||||
|     # is_child = ootworld.parser.parse_rule('is_child') |     # is_child = ootworld.parser.parse_rule('is_child') | ||||||
|     guarantee_hint = ootworld.parser.parse_rule('guarantee_hint') |     guarantee_hint = ootworld.parser.parse_rule('guarantee_hint') | ||||||
|  |  | ||||||
|  |     for location in filter(lambda location: location.name in ootworld.shop_prices or 'Deku Scrub' in location.name, ootworld.get_locations()): | ||||||
|  |  | ||||||
|     for location in ootworld.get_locations(): |  | ||||||
|         if ootworld.shuffle_song_items == 'song': |  | ||||||
|             if location.type == 'Song': |  | ||||||
|                 # must be a song, or there are songs in starting items; then it can be anything |  | ||||||
|                 add_item_rule(location, lambda item:  |  | ||||||
|                     (ootworld.starting_songs and item.type != 'Song') |  | ||||||
|                     or (item.type == 'Song' and item.player == location.player)) |  | ||||||
|             else: |  | ||||||
|                 add_item_rule(location, lambda item: item.type != 'Song') |  | ||||||
|  |  | ||||||
|         if location.type == 'Shop': |         if location.type == 'Shop': | ||||||
|             if location.name in ootworld.shop_prices: |             location.price = ootworld.shop_prices[location.name] | ||||||
|                 add_item_rule(location, lambda item: item.type != 'Shop') |         add_rule(location, create_shop_rule(location, ootworld.parser)) | ||||||
|                 location.price = ootworld.shop_prices[location.name] |  | ||||||
|                 add_rule(location, create_shop_rule(location, ootworld.parser)) |  | ||||||
|             else: |  | ||||||
|                 add_item_rule(location, lambda item: item.type == 'Shop' and item.player == location.player) |  | ||||||
|         elif 'Deku Scrub' in location.name: |  | ||||||
|             add_rule(location, create_shop_rule(location, ootworld.parser)) |  | ||||||
|         else: |  | ||||||
|             add_item_rule(location, lambda item: item.type != 'Shop') |  | ||||||
|  |  | ||||||
|         if ootworld.skip_child_zelda and location.name == 'Song from Impa': |     if ootworld.dungeon_mq['Forest Temple'] and ootworld.shuffle_bosskeys == 'dungeon' and ootworld.shuffle_smallkeys == 'dungeon' and ootworld.tokensanity == 'off': | ||||||
|             limit_to_itemset(location, SaveContext.giveable_items) |         # First room chest needs to be a small key. Make sure the boss key isn't placed here. | ||||||
|             add_item_rule(location, lambda item: item.player == location.player) |         location = world.get_location('Forest Temple MQ First Room Chest', player) | ||||||
|  |         forbid_item(location, 'Boss Key (Forest Temple)', ootworld.player) | ||||||
|  |  | ||||||
|         if location.name == 'Forest Temple MQ First Room Chest' and ootworld.shuffle_bosskeys == 'dungeon' and ootworld.shuffle_smallkeys == 'dungeon' and ootworld.tokensanity == 'off': |     for name in ootworld.always_hints: | ||||||
|             # This location needs to be a small key. Make sure the boss key isn't placed here. |         add_rule(world.get_location(name, player), guarantee_hint) | ||||||
|             forbid_item(location, 'Boss Key (Forest Temple)', ootworld.player) |  | ||||||
|  |  | ||||||
|         # TODO: re-add hints once they are working |     # TODO: re-add hints once they are working | ||||||
|         # if location.type == 'HintStone' and ootworld.hints == 'mask': |     # if location.type == 'HintStone' and ootworld.hints == 'mask': | ||||||
|         #     location.add_rule(is_child) |     #     location.add_rule(is_child) | ||||||
|  |  | ||||||
|         if location.name in ootworld.always_hints: |  | ||||||
|             add_rule(location, guarantee_hint) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| def create_shop_rule(location, parser): | def create_shop_rule(location, parser): | ||||||
| @@ -196,9 +175,9 @@ def set_entrances_based_rules(ootworld): | |||||||
|  |  | ||||||
|     all_state = ootworld.world.get_all_state(False) |     all_state = ootworld.world.get_all_state(False) | ||||||
|  |  | ||||||
|     for location in ootworld.get_locations(): |     for location in filter(lambda location: location.type == 'Shop', ootworld.get_locations()): | ||||||
|         # If a shop is not reachable as adult, it can't have Goron Tunic or Zora Tunic as child can't buy these |         # If a shop is not reachable as adult, it can't have Goron Tunic or Zora Tunic as child can't buy these | ||||||
|         if location.type == 'Shop' and not all_state._oot_reach_as_age(location.parent_region.name, 'adult', ootworld.player): |         if not all_state._oot_reach_as_age(location.parent_region.name, 'adult', ootworld.player): | ||||||
|             forbid_item(location, 'Buy Goron Tunic', ootworld.player) |             forbid_item(location, 'Buy Goron Tunic', ootworld.player) | ||||||
|             forbid_item(location, 'Buy Zora Tunic', ootworld.player) |             forbid_item(location, 'Buy Zora Tunic', ootworld.player) | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 espeon65536
					espeon65536