mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	[TLOZ]: Fix determinism / Add Location Name Groups / Remove Level 9 Junk Fill (#3670)
* [TLOZ]: Fix determinism / Add Location Name Groups / Remove Level 9 Junk Fill Axing the final uses of world.multiworld.random that were missed before, hopefully fixing the determinism issue brought up in Issue #3664 (at least on TLOZ's end, leaving SMZ3 alone). Also adding location name groups finally, as well as axing the Level 9 Junk Fill because with the new location name groups players can choose to exclude Level 9 with exclude locations instead. * location name groups * add take any item and sword cave location name groups * use sets like you're supposed to, silly
This commit is contained in:
		| @@ -80,7 +80,7 @@ def generate_itempool(tlozworld): | |||||||
|             location.item.classification = ItemClassification.progression |             location.item.classification = ItemClassification.progression | ||||||
|  |  | ||||||
| def get_pool_core(world): | def get_pool_core(world): | ||||||
|     random = world.multiworld.random |     random = world.random | ||||||
|  |  | ||||||
|     pool = [] |     pool = [] | ||||||
|     placed_items = {} |     placed_items = {} | ||||||
| @@ -132,14 +132,6 @@ def get_pool_core(world): | |||||||
|         else: |         else: | ||||||
|             pool.append(fragment) |             pool.append(fragment) | ||||||
|  |  | ||||||
|     # Level 9 junk fill |  | ||||||
|     if world.options.ExpandedPool > 0: |  | ||||||
|         spots = random.sample(level_locations[8], len(level_locations[8]) // 2) |  | ||||||
|         for spot in spots: |  | ||||||
|             junk = random.choice(list(minor_items.keys())) |  | ||||||
|             placed_items[spot] = junk |  | ||||||
|             minor_items[junk] -= 1 |  | ||||||
|  |  | ||||||
|     # Finish Pool |     # Finish Pool | ||||||
|     final_pool = basic_pool |     final_pool = basic_pool | ||||||
|     if world.options.ExpandedPool: |     if world.options.ExpandedPool: | ||||||
|   | |||||||
| @@ -99,6 +99,14 @@ shop_locations = [ | |||||||
|     "Potion Shop Item Left", "Potion Shop Item Middle", "Potion Shop Item Right" |     "Potion Shop Item Left", "Potion Shop Item Middle", "Potion Shop Item Right" | ||||||
| ] | ] | ||||||
|  |  | ||||||
|  | take_any_locations = [ | ||||||
|  |     "Take Any Item Left", "Take Any Item Middle", "Take Any Item Right" | ||||||
|  | ] | ||||||
|  |  | ||||||
|  | sword_cave_locations = [ | ||||||
|  |     "Starting Sword Cave", "White Sword Pond", "Magical Sword Grave" | ||||||
|  | ] | ||||||
|  |  | ||||||
| food_locations = [ | food_locations = [ | ||||||
|     "Level 7 Map", "Level 7 Boss", "Level 7 Triforce", "Level 7 Key Drop (Goriyas)", |     "Level 7 Map", "Level 7 Boss", "Level 7 Triforce", "Level 7 Key Drop (Goriyas)", | ||||||
|     "Level 7 Bomb Drop (Moldorms North)", "Level 7 Bomb Drop (Goriyas North)", |     "Level 7 Bomb Drop (Moldorms North)", "Level 7 Bomb Drop (Goriyas North)", | ||||||
|   | |||||||
| @@ -12,7 +12,8 @@ from BaseClasses import Item, Location, Region, Entrance, MultiWorld, ItemClassi | |||||||
| from .ItemPool import generate_itempool, starting_weapons, dangerous_weapon_locations | from .ItemPool import generate_itempool, starting_weapons, dangerous_weapon_locations | ||||||
| from .Items import item_table, item_prices, item_game_ids | from .Items import item_table, item_prices, item_game_ids | ||||||
| from .Locations import location_table, level_locations, major_locations, shop_locations, all_level_locations, \ | from .Locations import location_table, level_locations, major_locations, shop_locations, all_level_locations, \ | ||||||
|     standard_level_locations, shop_price_location_ids, secret_money_ids, location_ids, food_locations |     standard_level_locations, shop_price_location_ids, secret_money_ids, location_ids, food_locations, \ | ||||||
|  |     take_any_locations, sword_cave_locations | ||||||
| from .Options import TlozOptions | from .Options import TlozOptions | ||||||
| from .Rom import TLoZDeltaPatch, get_base_rom_path, first_quest_dungeon_items_early, first_quest_dungeon_items_late | from .Rom import TLoZDeltaPatch, get_base_rom_path, first_quest_dungeon_items_early, first_quest_dungeon_items_late | ||||||
| from .Rules import set_rules | from .Rules import set_rules | ||||||
| @@ -87,6 +88,21 @@ class TLoZWorld(World): | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     location_name_groups = { | ||||||
|  |         "Shops": set(shop_locations), | ||||||
|  |         "Take Any": set(take_any_locations), | ||||||
|  |         "Sword Caves": set(sword_cave_locations), | ||||||
|  |         "Level 1": set(level_locations[0]), | ||||||
|  |         "Level 2": set(level_locations[1]), | ||||||
|  |         "Level 3": set(level_locations[2]), | ||||||
|  |         "Level 4": set(level_locations[3]), | ||||||
|  |         "Level 5": set(level_locations[4]), | ||||||
|  |         "Level 6": set(level_locations[5]), | ||||||
|  |         "Level 7": set(level_locations[6]), | ||||||
|  |         "Level 8": set(level_locations[7]), | ||||||
|  |         "Level 9": set(level_locations[8]) | ||||||
|  |     } | ||||||
|  |  | ||||||
|     for k, v in item_name_to_id.items(): |     for k, v in item_name_to_id.items(): | ||||||
|         item_name_to_id[k] = v + base_id |         item_name_to_id[k] = v + base_id | ||||||
|  |  | ||||||
| @@ -307,7 +323,7 @@ class TLoZWorld(World): | |||||||
|     def get_filler_item_name(self) -> str: |     def get_filler_item_name(self) -> str: | ||||||
|         if self.filler_items is None: |         if self.filler_items is None: | ||||||
|             self.filler_items = [item for item in item_table if item_table[item].classification == ItemClassification.filler] |             self.filler_items = [item for item in item_table if item_table[item].classification == ItemClassification.filler] | ||||||
|         return self.multiworld.random.choice(self.filler_items) |         return self.random.choice(self.filler_items) | ||||||
|  |  | ||||||
|     def fill_slot_data(self) -> Dict[str, Any]: |     def fill_slot_data(self) -> Dict[str, Any]: | ||||||
|         if self.options.ExpandedPool: |         if self.options.ExpandedPool: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 t3hf1gm3nt
					t3hf1gm3nt