mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	Added sanity check to see if all locations can be assigned to regions
This commit is contained in:
		 Jarno Westhof
					Jarno Westhof
				
			
				
					committed by
					
						 Fabian Dill
						Fabian Dill
					
				
			
			
				
	
			
			
			 Fabian Dill
						Fabian Dill
					
				
			
						parent
						
							f003c7130f
						
					
				
				
					commit
					5a2e477dba
				
			| @@ -1,4 +1,4 @@ | ||||
| from typing import List, Dict, Tuple, Optional, Callable | ||||
| from typing import List, Set, Dict, Tuple, Optional, Callable | ||||
| from BaseClasses import MultiWorld, Region, Entrance, Location, RegionType | ||||
| from .Options import is_option_enabled | ||||
| from .Locations import LocationData | ||||
| @@ -6,7 +6,7 @@ from .Locations import LocationData | ||||
| def create_regions(world: MultiWorld, player: int, locations: Tuple[LocationData, ...], location_cache: List[Location], pyramid_keys_unlock: str): | ||||
|     locations_per_region = get_locations_per_region(locations) | ||||
|  | ||||
|     world.regions += [ | ||||
|     regions = [ | ||||
|         create_region(world, player, locations_per_region, location_cache, 'Menu'), | ||||
|         create_region(world, player, locations_per_region, location_cache, 'Tutorial'), | ||||
|         create_region(world, player, locations_per_region, location_cache, 'Lake desolation'), | ||||
| @@ -45,6 +45,10 @@ def create_regions(world: MultiWorld, player: int, locations: Tuple[LocationData | ||||
|         create_region(world, player, locations_per_region, location_cache, 'Space time continuum') | ||||
|     ] | ||||
|  | ||||
|     throwIfAnyLocationIsNotAssignedToARegion(regions, locations_per_region.keys()) | ||||
|  | ||||
|     world.regions += regions | ||||
|  | ||||
|     connectStartingRegion(world, player) | ||||
|  | ||||
|     names: Dict[str, int] = {} | ||||
| @@ -150,6 +154,16 @@ def create_regions(world: MultiWorld, player: int, locations: Tuple[LocationData | ||||
|     connect(world, player, names, 'Space time continuum', 'Caves of Banishment (upper)', lambda state: pyramid_keys_unlock == "GateCavesOfBanishment") | ||||
|  | ||||
|  | ||||
| def throwIfAnyLocationIsNotAssignedToARegion(regions: List[Region], regionNames: Set[str]): | ||||
|     existingRegions = set() | ||||
|  | ||||
|     for region in regions: | ||||
|         existingRegions.add(region.name) | ||||
|  | ||||
|     if (regionNames - existingRegions): | ||||
|         raise Exception("Tiemspinner: the following regions are used in locations: {}, but no such region exists".format(regionNames - existingRegions)) | ||||
|  | ||||
|  | ||||
| def create_location(player: int, location_data: LocationData, region: Region, location_cache: List[Location]) -> Location: | ||||
|     location = Location(player, location_data.name, location_data.code, region) | ||||
|     location.access_rule = location_data.rule | ||||
|   | ||||
		Reference in New Issue
	
	Block a user