mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	Core: generalize pre_fill item pool handling
This commit is contained in:
		| @@ -1,3 +1,5 @@ | ||||
| import typing | ||||
|  | ||||
| from BaseClasses import Dungeon | ||||
| from worlds.alttp.Bosses import BossFactory | ||||
| from Fill import fill_restrictive | ||||
| @@ -13,6 +15,7 @@ def create_dungeons(world, player): | ||||
|                           dungeon_items, player) | ||||
|         for item in dungeon.all_items: | ||||
|             item.dungeon = dungeon | ||||
|             item.world = world | ||||
|         dungeon.boss = BossFactory(default_boss, player) if default_boss else None | ||||
|         for region in dungeon.regions: | ||||
|             world.get_region(region, player).dungeon = dungeon | ||||
| @@ -108,21 +111,15 @@ def create_dungeons(world, player): | ||||
|         world.dungeons[dungeon.name, dungeon.player] = dungeon | ||||
|  | ||||
|  | ||||
| def get_dungeon_item_pool(world): | ||||
|     items = [item for dungeon in world.dungeons.values() for item in dungeon.all_items] | ||||
|     for item in items: | ||||
|         item.world = world | ||||
|     return items | ||||
| def get_dungeon_item_pool(world) -> typing.List: | ||||
|     return [item for dungeon in world.dungeons.values() for item in dungeon.all_items] | ||||
|  | ||||
|  | ||||
| def get_dungeon_item_pool_player(world, player): | ||||
|     items = [item for dungeon in world.dungeons.values() if dungeon.player == player for item in dungeon.all_items] | ||||
|     for item in items: | ||||
|         item.world = world | ||||
|     return items | ||||
| def get_dungeon_item_pool_player(world, player) -> typing.List: | ||||
|     return [item for dungeon in world.dungeons.values() if dungeon.player == player for item in dungeon.all_items] | ||||
|  | ||||
|  | ||||
| def fill_dungeons_restrictive(autoworld, world): | ||||
| def fill_dungeons_restrictive(world): | ||||
|     """Places dungeon-native items into their dungeons, places nothing if everything is shuffled outside.""" | ||||
|     localized: set = set() | ||||
|     dungeon_specific: set = set() | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| import typing | ||||
|  | ||||
| def GetBeemizerItem(world, player, item): | ||||
|  | ||||
| def GetBeemizerItem(world, player: int, item): | ||||
|     item_name = item if isinstance(item, str) else item.name | ||||
|  | ||||
|     if item_name not in trap_replaceable: | ||||
| @@ -16,6 +17,7 @@ def GetBeemizerItem(world, player, item): | ||||
|     else: | ||||
|         return "Bee Trap" if isinstance(item, str) else world.create_item("Bee Trap", player)         | ||||
|  | ||||
|  | ||||
| # should be replaced with direct world.create_item(item) call in the future | ||||
| def ItemFactory(items, player: int): | ||||
|     from worlds.alttp import ALTTPWorld | ||||
| @@ -35,6 +37,7 @@ def ItemFactory(items, player: int): | ||||
|         return ret[0] | ||||
|     return ret | ||||
|  | ||||
|  | ||||
| class ItemData(typing.NamedTuple): | ||||
|     advancement: bool | ||||
|     type: typing.Optional[str] | ||||
|   | ||||
| @@ -249,7 +249,7 @@ class ALTTPWorld(World): | ||||
|     @classmethod | ||||
|     def stage_pre_fill(cls, world): | ||||
|         from .Dungeons import fill_dungeons_restrictive | ||||
|         fill_dungeons_restrictive(cls, world) | ||||
|         fill_dungeons_restrictive(world) | ||||
|  | ||||
|     @classmethod | ||||
|     def stage_post_fill(cls, world): | ||||
| @@ -363,17 +363,9 @@ class ALTTPWorld(World): | ||||
|                 fill_locations.remove(loc) | ||||
|             world.random.shuffle(fill_locations) | ||||
|             # TODO: investigate not creating the key in the first place | ||||
|             if __debug__: | ||||
|                 # keeping this here while I'm not sure we caught all instances of multiple HC small keys in the pool | ||||
|                 count = len(progitempool) | ||||
|                 progitempool[:] = [item for item in progitempool if | ||||
|                                    item.player not in standard_keyshuffle_players or | ||||
|                                    item.name != "Small Key (Hyrule Castle)"] | ||||
|                 assert len(progitempool) + len(standard_keyshuffle_players) == count | ||||
|             else: | ||||
|                 progitempool[:] = [item for item in progitempool if | ||||
|                                    item.player not in standard_keyshuffle_players or | ||||
|                                    item.name != "Small Key (Hyrule Castle)"] | ||||
|             progitempool[:] = [item for item in progitempool if | ||||
|                                item.player not in standard_keyshuffle_players or | ||||
|                                item.name != "Small Key (Hyrule Castle)"] | ||||
|  | ||||
|         if trash_counts: | ||||
|             locations_mapping = {player: [] for player in trash_counts} | ||||
| @@ -405,6 +397,16 @@ class ALTTPWorld(World): | ||||
|     def get_filler_item_name(self) -> str: | ||||
|         return "Rupees (5)"  # temporary | ||||
|  | ||||
|     def get_pre_fill_items(self): | ||||
|         res = [] | ||||
|         if self.dungeon_local_item_names: | ||||
|             for (name, player), dungeon in self.world.dungeons.items(): | ||||
|                 if player == self.player: | ||||
|                     for item in dungeon.all_items: | ||||
|                         if item.name in self.dungeon_local_item_names: | ||||
|                             res.append(item) | ||||
|         return res | ||||
|  | ||||
|  | ||||
| def get_same_seed(world, seed_def: tuple) -> str: | ||||
|     seeds: typing.Dict[tuple, str] = getattr(world, "__named_seeds", {}) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Fabian Dill
					Fabian Dill