2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								# Archipelago API
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								This document tries to explain some internals required to implement a game for
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Archipelago's generation and server. Once a seed is generated, a client or mod is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								required to send and receive items between the game and server.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Client implementation is out of scope of this document. Please refer to an
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 01:15:35 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								existing game that provides a similar API to yours.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Refer to the following documents as well:
							 
						 
					
						
							
								
									
										
										
										
											2022-03-24 08:21:08 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								-  [network protocol.md ](https://github.com/ArchipelagoMW/Archipelago/blob/main/docs/network%20protocol.md ) 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								-  [adding games.md ](https://github.com/ArchipelagoMW/Archipelago/blob/main/docs/adding%20games.md ) 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Archipelago will be abbreviated as "AP" from now on.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Language
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								AP worlds are written in python3.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Clients that connect to the server to sync items can be in any language that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								allows using WebSockets.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Coding style
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								AP follows all the PEPs. When in doubt use an IDE with coding style
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								linter, for example PyCharm Community Edition.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								## Docstrings
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Docstrings are strings attached to an object in Python that describe what the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								object is supposed to be. Certain docstrings will be picked up and used by AP.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								They are assigned by writing a string without any assignment right below a
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								definition. The string must be a triple-quoted string.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2021-11-04 13:23:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.AutoWorld import World
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								class MyGameWorld(World):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """This is the description of My Game that will be displayed on the AP
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								       website."""
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Definitions
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-03-24 08:21:08 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This section will cover various classes and objects you can use for your world.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								While some of the attributes and methods are mentioned here not all of them are,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								but you can find them in `BaseClasses.py` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### World Class
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								A `World`  class is the class with all the specifics of a certain game to be
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								included. It will be instantiated for each player that rolls a seed for that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								game.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-03-24 08:21:08 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### WebWorld Class
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								A `WebWorld`  class contains specific attributes and methods that can be modified
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 14:37:05 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								for your world specifically on the webhost.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`settings_page`  which can be changed to a link instead of an AP generated settings page. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`theme`  to be used for your game specific AP pages. Available themes: 
						 
					
						
							
								
									
										
										
										
											2022-06-22 20:31:40 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								| dirt  | grass (default) | grassFlowers | ice  | jungle  | ocean | partyTime | stone |
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								|---|---|---|---|---|---|---|---|
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								| < img  src = "img/theme_dirt.JPG"  width = "100" >  | < img  src = "img/theme_grass.JPG"  width = "100" >  | < img  src = "img/theme_grassFlowers.JPG"  width = "100" >  | < img  src = "img/theme_ice.JPG"  width = "100" >  | < img  src = "img/theme_jungle.JPG"  width = "100" >  | < img  src = "img/theme_ocean.JPG"  width = "100" >  | < img  src = "img/theme_partyTime.JPG"  width = "100" >  | < img  src = "img/theme_stone.JPG"  width = "100" >  |
							 
						 
					
						
							
								
									
										
										
										
											2022-03-24 08:21:08 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 14:37:05 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`bug_report_page`  (optional) can be a link to a bug reporting page, most likely a GitHub issue page, that will be placed by the site to help direct users to report bugs. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-05-18 14:23:27 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`tutorials`  list of `Tutorial`  classes where each class represents a guide to be generated on the webhost. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`game_info_languages`  (optional) List of strings for defining the existing gameinfo pages your game supports. The documents must be 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								prefixed with the same string as defined here. Default already has 'en'.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### MultiWorld Object
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The `MultiWorld`  object references the whole multiworld (all items and locations
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								for all players) and is accessible through `self.world`  inside a `World`  object.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Player
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The player is just an integer in AP and is accessible through `self.player` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								inside a World object.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Player Options
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Players provide customized settings for their World in the form of yamls.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Those are accessible through `self.world.<option_name>[self.player]` . A dict
							 
						 
					
						
							
								
									
										
										
										
											2022-08-15 16:46:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								of valid options has to be provided in `self.option_definitions` . Options are automatically
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								added to the `World`  object for easy access.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### World Options
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Any AP installation can provide settings for a world, for example a ROM file,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								accessible through `Utils.get_options()['<world>_options']['<option>']` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Users can set those in their `host.yaml`  file.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Locations
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Locations are places where items can be located in your game. This may be chests
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								or boss drops for RPG-like games but could also be progress in a research tree.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Each location has a `name`  and an `id`  (a.k.a. "code" or "address"), is placed
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 00:47:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								in a Region, has access rules and a classification.
							 
						 
					
						
							
								
									
										
										
										
											2022-09-20 08:08:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The name needs to be unique in each game and must not be numeric (has to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								contain least 1 letter or symbol). The ID needs to be unique across all games
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and is best in the same range as the item IDs.
							 
						 
					
						
							
								
									
										
										
										
											2022-02-10 01:24:38 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								World-specific IDs are 1 to 2< sup > 53< / sup > -1, IDs ≤ 0 are global and reserved.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Special locations with ID `None`  can hold events.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 00:47:23 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Classification is one of `LocationProgressType.DEFAULT` , `PRIORITY`  or `EXCLUDED` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The Fill algorithm will fill priority first, giving higher chance of it being
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								required, and not place progression or useful items in excluded locations.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								### Items
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Items are all things that can "drop" for your game. This may be RPG items like
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								weapons, could as well be technologies you normally research in a research tree.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-06-19 15:19:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Each item has a `name` , an `id`  (can be known as "code"), and a classification.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The most important classification is `progression`  (formerly advancement).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Progression items are items which a player may require to progress in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								their world. Progression items will be assigned to locations with higher
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								priority and moved around to meet defined rules and accomplish progression
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								balancing.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-20 08:08:43 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The name needs to be unique in each game, meaning a duplicate item has the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								same ID. Name must not be numeric (has to contain at least 1 letter or symbol).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Special items with ID `None`  can mark events (read below).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-06-19 15:19:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Other classifications include
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  filler: a regular item or trash item 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  useful: generally quite useful, but not required for anything logical 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  trap: negative impact on the player 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  skip_balancing: add to progression to skip balancing; e.g. currency or tokens 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								### Events
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Events will mark some progress. You define an event location, an
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								event item, strap some rules to the location (i.e. hold certain
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								items) and manually place the event item at the event location.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Events can be used to either simplify the logic or to get better spoiler logs.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Events will show up in the spoiler playthrough but they do not represent actual
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								items or locations within the game.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There is one special case for events: Victory. To get the win condition to show
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								up in the spoiler log, you create an event item and place it at an event
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								location with the `access_rules`  for game completion. Once that's done, the
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								world's win condition can be as simple as checking for that item.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								By convention the victory event is called `"Victory"` . It can be placed at one
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								or more event locations based on player options.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Regions
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Regions are logical groups of locations that share some common access rules. If
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								location logic is written from scratch, using regions greatly simplifies the
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								definition and allow to somewhat easily implement things like entrance
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								randomizer in logic.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Regions have a list called `exits`  which are `Entrance`  objects representing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								transitions to other regions.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								There has to be one special region "Menu" from which the logic unfolds. AP
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								assumes that a player will always be able to return to the "Menu" region by
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								resetting the game ("Save and quit").
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Entrances
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								An `Entrance`  connects to a region, is assigned to region's exits and has rules
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								to define if it and thus the connected region is accessible.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								They can be static (regular logic) or be defined/connected during generation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								(entrance randomizer).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Access Rules
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								An access rule is a function that returns `True`  or `False`  for a `Location`  or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`Entrance`  based on the the current `state`  (items that can be collected). 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Item Rules
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								An item rule is a function that returns `True`  or `False`  for a `Location`  based
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								on a single item. It can be used to reject placement of an item there.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								## Implementation
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Your World
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:28:15 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								All code for your world implementation should be placed in a python package in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the `/worlds`  directory. The starting point for the package is `__init.py__` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Conventionally, your world class is placed in that file.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								World classes must inherit from the `World`  class in `/worlds/AutoWorld.py` ,
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								which can be imported as `worlds.AutoWorld.World`  from your package.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:28:15 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								AP will pick up your world automatically due to the `AutoWorld`  implementation.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Requirements
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								If your world needs specific python packages, they can be listed in
							 
						 
					
						
							
								
									
										
										
										
											2022-09-20 09:09:13 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`world/[world_name]/requirements.txt` . ModuleUpdate.py will automatically 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								pick up and install them.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								See [pip documentation ](https://pip.pypa.io/en/stable/cli/pip_install/#requirements-file-format ).
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Relative Imports
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								AP will only import the `__init__.py` . Depending on code size it makes sense to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								use multiple files and use relative imports to access them.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								e.g. `from .Options import mygame_options`  from your `__init__.py`  will load
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`world/[world_name]/Options.py`  and make its `mygame_options`  accesible. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								When imported names pile up it may be easier to use `from . import Options` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								and access the variable as `Options.mygame_options` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Imports from directories outside your world should use absolute imports.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Correct use of relative / absolute imports is required for zipped worlds to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								function, see [apworld specification.md ](apworld%20specification.md ).
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Your Item Type
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Each world uses its own subclass of `BaseClasses.Item` . The constuctor can be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								overridden to attach additional data to it, e.g. "price in shop".
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Since the constructor is only ever called from your code, you can add whatever
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								arguments you like to the constructor.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								In its simplest form we only set the game name and use the default constuctor
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from BaseClasses import Item
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameItem(Item):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    game: str = "My Game"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								By convention this class definition will either be placed in your `__init__.py` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								or your `Items.py` . For a more elaborate example see `worlds/oot/Items.py` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Your location type
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The same we have done for items above, we will do for locations
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2021-11-04 13:23:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from BaseClasses import Location
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameLocation(Location):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    game: str = "My Game"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 14:03:33 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # override constructor to automatically mark event locations as such
							 
						 
					
						
							
								
									
										
										
										
											2022-07-15 23:52:35 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def __init__ (self, player: int, name = "", code = None, parent = None):
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 14:03:33 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        super(MyGameLocation, self).__init__(player, name, code, parent)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self.event = code is None
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								in your `__init__.py`  or your `Locations.py` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Options
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								By convention options are defined in `Options.py`  and will be used when parsing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the players' yaml files.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Each option has its own class, inherits from a base option type, has a docstring 
							 
						 
					
						
							
								
									
										
										
										
											2022-02-02 23:33:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								to describe it and a `display_name`  property for display on the website and in
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 13:00:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								spoiler logs.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								The actual name as used in the yaml is defined in a `dict[str, Option]` , that is
							 
						 
					
						
							
								
									
										
										
										
											2022-08-15 16:46:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								assigned to the world under `self.option_definitions` .
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								Common option types are `Toggle` , `DefaultOnToggle` , `Choice` , `Range` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For more see `Options.py`  in AP's base directory.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Toggle, DefaultOnToggle
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Those don't need any additional properties defined. After parsing the option,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								its `value`  will either be True or False.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Range
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Define properties `range_start` , `range_end`  and `default` . Ranges will be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								displayed as sliders on the website and can be set to random in the yaml.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Choice
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Choices are like toggles, but have more options than just True and False.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Define a property `option_<name> = <number>`  per selectable value and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`default = <number>`  to set the default selection. Aliases can be set by 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								defining a property `alias_<name> = <same number>` .
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								option_off = 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								option_on = 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								option_some = 2
							 
						 
					
						
							
								
									
										
										
										
											2022-09-16 00:32:30 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								alias_disabled = 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								alias_enabled = 1
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								default = 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Sample
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Options.py
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-11-04 13:23:13 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from Options import Toggle, Range, Choice, Option
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								import typing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class Difficulty(Choice):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """Sets overall game difficulty."""
							 
						 
					
						
							
								
									
										
										
										
											2022-02-02 23:33:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    display_name = "Difficulty"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    option_easy = 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    option_normal = 1
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    option_hard = 2
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    alias_beginner = 0  # same as easy
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    alias_expert = 2  # same as hard
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    default = 1  # default to normal
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class FinalBossHP(Range):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """Sets the HP of the final boss"""
							 
						 
					
						
							
								
									
										
										
										
											2022-02-02 23:33:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    display_name = "Final Boss HP"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    range_start = 100
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    range_end = 10000
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    default = 2000
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class FixXYZGlitch(Toggle):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """Fixes ABC when you do XYZ"""
							 
						 
					
						
							
								
									
										
										
										
											2022-02-02 23:33:26 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    display_name = "Fix XYZ Glitch"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# By convention we call the options dict variable `<world>_options`.
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								mygame_options: typing.Dict[str, type(Option)] = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "difficulty": Difficulty,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "final_boss_hp": FinalBossHP,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "fix_xyz_glitch": FixXYZGlitch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# __init__.py
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.AutoWorld import World
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								from .Options import mygame_options  # import the options dict
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameWorld(World):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    #...
							 
						 
					
						
							
								
									
										
										
										
											2022-08-15 16:46:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    option_definitions = mygame_options  # assign the options dict to the world
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    #...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### A World Class Skeleton
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# world/mygame/__init__.py
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from .Options import mygame_options  # the options we defined earlier
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from .Items import mygame_items  # data used below to add items to the World
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from .Locations import mygame_locations  # same as above
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.AutoWorld import World
							 
						 
					
						
							
								
									
										
										
										
											2022-06-19 15:19:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from BaseClasses import Region, Location, Entrance, Item, RegionType, ItemClassification
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								from Utils import get_options, output_path
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameItem(Item):  # or from Items import MyGameItem
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    game = "My Game"  # name of the game/world this item is from
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameLocation(Location):  # or from Locations import MyGameLocation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    game = "My Game"  # name of the game/world this location is in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameWorld(World):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    """Insert description of the world/game here."""
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    game: str = "My Game"  # name of the game/world
							 
						 
					
						
							
								
									
										
										
										
											2022-08-15 16:46:59 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    option_definitions = mygame_options  # options the player can set
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 13:00:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    topology_present: bool = True  # show path to required location checks in spoiler
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 14:29:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # data_version is used to signal that items, locations or their names
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # changed. Set this to 0 during development so other games' clients do not
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # cache any texts, then increase by 1 for each release that makes changes.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    data_version = 0
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # ID of first item and location, could be hard-coded but code may be easier
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # to read with this as a propery.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    base_id = 1234
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Instead of dynamic numbering, IDs could be part of data.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # The following two dicts are required for the generation to know which
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # items exist. They could be generated from json or something else. They can
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # include events, but don't have to since events will be placed manually.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    item_name_to_id = {name: id for
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 14:29:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                       id, name in enumerate(mygame_items, base_id)}
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    location_name_to_id = {name: id for
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 14:29:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                           id, name in enumerate(mygame_locations, base_id)}
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 13:00:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Items can be grouped using their names to allow easy checking if any item
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # from that group has been collected. Group names can also be used for !hint
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    item_name_groups = {
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "weapons": {"sword", "lance"}
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Generation
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The world has to provide the following things for generation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  the properties mentioned above  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  additions to the item pool 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  additions to the regions list: at least one called "Menu" 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  locations placed inside those regions 
						 
					
						
							
								
									
										
										
										
											2022-12-11 02:59:17 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  a `def create_item(self, item: str) -> MyGameItem`  to create any item on demand 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  applying `self.multiworld.push_precollected`  for start inventory 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `required_client_version: Tuple(int, int, int)`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Optional client version as tuple of 3 ints to make sure the client is compatible to
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  this world (e.g. implements all required features) when connecting.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								In addition, the following methods can be implemented and are called in this order during generation
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								*  `stage_assert_generate(cls, multiworld)`  is a class method called at the start of 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  generation to check the existence of prerequisite files, usually a ROM for
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  games which require one.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `def generate_early(self)`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  called per player before any items or locations are created. You can set
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  properties on your world here. Already has access to player options and RNG.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `def create_regions(self)`  
						 
					
						
							
								
									
										
										
										
											2022-12-11 02:59:17 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  called to place player's regions and their locations into the MultiWorld's regions list. If it's
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  hard to separate, this can be done during `generate_early`  or `create_items`  as well.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `def create_items(self)`  
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  called to place player's items into the MultiWorld's itempool. After this step all regions and items have to be in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  the MultiWorld's regions and itempool, and these lists should not be modified afterwards.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `def set_rules(self)`  
						 
					
						
							
								
									
										
										
										
											2022-12-11 02:59:17 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  called to set access and item rules on locations and entrances. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  Locations have to be defined before this, or rule application can miss them.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `def generate_basic(self)`  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  called after the previous steps. Some placement and player specific
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  randomizations can be done here.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `pre_fill` , `fill_hook`  and `post_fill`  are called to modify item placement 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  before, during and after the regular fill process, before `generate_output` .
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								  If items need to be placed during pre_fill, these items can be determined
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  and created using `get_prefill_items` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								*  `def generate_output(self, output_directory: str)`  that creates the output 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  files if there is output to be generated. When this is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  called, `self.multiworld.get_locations(self.player)`  has all locations for the player, with
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  attribute `item`  pointing to the item.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  `location.item.player`  can be used to see if it's a local item.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								*  `fill_slot_data`  and `modify_multidata`  can be used to modify the data that 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  will be used by the server to host the MultiWorld.
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### generate_early
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2022-04-28 09:03:44 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def generate_early(self) -> None:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # read player settings to world instance
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.final_boss_hp = self.multiworld.final_boss_hp[self.player].value
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### create_item
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# we need a way to know if an item provides progress in the game ("key item")
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# this can be part of the items definition, or depend on recipe randomization
  
						 
					
						
							
								
									
										
										
										
											2021-10-09 13:00:50 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from .Items import is_progression  # this is just a dummy
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def create_item(self, item: str):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # This is called when AP wants to create an item by name (for plando) or
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # when you call it from your own code.
							 
						 
					
						
							
								
									
										
										
										
											2022-06-19 15:19:46 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    classification = ItemClassification.progression if is_progression(item) else \
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                     ItemClassification.filler
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return MyGameItem(item, classification, self.item_name_to_id[item],
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								                      self.player)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def create_event(self, event: str):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # while we are at it, we can also add a helper to create events
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    return MyGameItem(event, True, None, self.player)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### create_items
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2022-04-28 09:03:44 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def create_items(self) -> None:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # Add items to the Multiworld.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If there are two of the same item, the item has to be twice in the pool.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Which items are added to the pool may depend on player settings,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # e.g. custom win condition like triforce hunt.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 13:08:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Having an item in the start inventory won't remove it from the pool.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If an item can't have duplicates it has to be excluded manually.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 18:39:03 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # List of items to exclude, as a copy since it will be destroyed below
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    exclude = [item for item in self.multiworld.precollected_items[self.player]]
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 13:08:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for item in map(self.create_item, mygame_items):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if item in exclude:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            exclude.remove(item)  # this is destructive. create unique list above
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            self.multiworld.itempool.append(self.create_item("nothing"))
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 13:08:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        else:
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            self.multiworld.itempool.append(item)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 13:08:23 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # itempool and number of locations should match up.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If this is not the case we want to fill the itempool with junk.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    junk = 0  # calculate this based on player settings
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.itempool += [self.create_item("nothing") for _ in range(junk)]
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### create_regions
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2022-04-28 09:03:44 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def create_regions(self) -> None:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # Add regions to the multiworld. "Menu" is the required starting point.
							 
						 
					
						
							
								
									
										
										
										
											2023-02-13 18:06:43 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # Arguments to Region() are name, player, world, and optionally hint_text
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    r = Region("Menu", self.player, self.multiworld)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # Set Region.exits to a list of entrances that are reachable from region
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    r.exits = [Entrance(self.player, "New game", r)]  # or use r.exits.append
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # Append region to MultiWorld's regions
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.regions.append(r)  # or use += [r...]
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2023-02-13 18:06:43 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    r = Region("Main Area", self.player, self.multiworld)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # Add main area's locations to main area (all but final boss)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    r.locations = [MyGameLocation(self.player, location.name,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                   self.location_name_to_id[location.name], r)]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    r.exits = [Entrance(self.player, "Boss Door", r)]
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.regions.append(r)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2023-02-13 18:06:43 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    r = Region("Boss Room", self.player, self.multiworld)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # add event to Boss Room
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    r.locations = [MyGameLocation(self.player, "Final Boss", None, r)]
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.regions.append(r)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If entrances are not randomized, they should be connected here, otherwise
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # they can also be connected at a later stage.
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.get_entrance("New Game", self.player)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .connect(self.multiworld.get_region("Main Area", self.player))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    self.multiworld.get_entrance("Boss Door", self.player)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        .connect(self.multiworld.get_region("Boss Room", self.player))
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # If setting location access rules from data is easier here, set_rules can
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # possibly omitted.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### generate_basic
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2022-04-28 09:03:44 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def generate_basic(self) -> None:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # place "Victory" at "Final Boss" and set collection as win condition
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.get_location("Final Boss", self.player)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        .place_locked_item(self.create_event("Victory"))
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.completion_condition[self.player] =
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        lambda state: state.has("Victory", self.player)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # place item Herb into location Chest1 for some reason
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    item = self.create_item("Herb")
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    self.multiworld.get_location("Chest1", self.player).place_locked_item(item)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # in most cases it's better to do this at the same time the itempool is
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # filled to avoid accidental duplicates:
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # manually placed and still in the itempool
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Setting Rules
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.generic.Rules import add_rule, set_rule, forbid_item
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from Items import get_item_type
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-28 09:03:44 -07:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def set_rules(self) -> None:
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    # For some worlds this step can be omitted if either a Logic mixin 
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # (see below) is used, it's easier to apply the rules from data during
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # location generation or everything is in generate_basic
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # set a simple rule for an region
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    set_rule(self.multiworld.get_entrance("Boss Door", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has("Boss Key", self.player))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # combine rules to require two items
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    add_rule(self.multiworld.get_location("Chest2", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has("Sword", self.player))
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    add_rule(self.multiworld.get_location("Chest2", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has("Shield", self.player))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # or simply combine yourself
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    set_rule(self.multiworld.get_location("Chest2", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has("Sword", self.player) and
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                           state.has("Shield", self.player))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # require two of an item
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    set_rule(self.multiworld.get_location("Chest3", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has("Key", self.player, 2))
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # require one item from an item group
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    add_rule(self.multiworld.get_location("Chest3", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 11:06:41 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								             lambda state: state.has_group("weapons", self.player))
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # state also has .item_count() for items, .has_any() and.has_all() for sets
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # and .count_group() for groups
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # set_rule is likely to be a bit faster than add_rule
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # disallow placing a specific local item at a specific location
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    forbid_item(self.multiworld.get_location("Chest4", self.player), "Sword")
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # disallow placing items with a specific property
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    add_item_rule(self.multiworld.get_location("Chest5", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  lambda item: get_item_type(item) == "weapon")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # get_item_type needs to take player/world into account
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if MyGameItem has a type property, a more direct implementation would be
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    add_item_rule(self.multiworld.get_location("Chest5", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  lambda item: item.player != self.player or\
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                               item.my_type == "weapon")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # location.item_rule = ... is likely to be a bit faster
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Logic Mixin
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								While lambdas and events could do pretty much anything, by convention we
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								implement more complex logic in logic mixins, even if there is no need to add
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								properties to the `BaseClasses.CollectionState`  state object.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								When importing a file that defines a class that inherits from
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								`worlds.AutoWorld.LogicMixin`  the state object's class is automatically extended by 
						 
					
						
							
								
									
										
										
										
											2021-10-09 02:05:55 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								the mixin's members. These members should be prefixed with underscore following
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the name of the implementing world. This is due to sharing a namespace with all
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								other logic mixins.
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Typical uses are defining methods that are used instead of `state.has` 
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 18:00:22 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								in lambdas, e.g.`state.mygame_has(custom, player)`  or recurring checks
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								like `state.mygame_can_do_something(player)`  to simplify lambdas.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Private members, only accessible from mixins, should start with `_mygame_` ,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								public members with `mygame_` .
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								More advanced uses could be to add additional variables to the state object,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								override `World.collect(self, state, item)`  and `remove(self, state, item)` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								to update the state object, and check those added variables in added methods.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Please do this with caution and only when neccessary.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Sample
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# Logic.py
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.AutoWorld import LogicMixin
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								class MyGameLogic(LogicMixin):
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 18:00:22 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def mygame_has_key(self, player: int):
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # Arguments above are free to choose
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 18:00:22 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # MultiWorld can be accessed through self.world, explicitly passing in
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # MyGameWorld instance for easy options access is also a valid approach
							 
						 
					
						
							
								
									
										
										
										
											2022-07-15 23:52:35 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        return self.has("key", player)  # or whatever
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								# __init__.py
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-09-18 00:00:54 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from worlds.generic.Rules import set_rule
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import .Logic  # apply the mixin by importing its file
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameWorld(World):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # ...
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def set_rules(self):
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:39:16 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        set_rule(self.world.get_location("A Door", self.player),
							 
						 
					
						
							
								
									
										
										
										
											2022-09-25 18:00:22 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                 lamda state: state.mygame_has_key(self.player))
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 00:49:47 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Generate Output
  
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								from .Mod import generate_mod
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								def generate_output(self, output_directory: str):
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # How to generate the mod or ROM highly depends on the game
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if the mod is written in Lua, Jinja can be used to fill a template
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # if the mod reads a json file, `json.dump()`  can be used to generate that
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # code below is a dummy
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    data = {
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "seed": self.multiworld.seed_name,  # to verify the server's multiworld
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        "slot": self.multiworld.player_name[self.player],  # to connect to server
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "items": {location.name: location.item.name
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                  if location.item.player == self.player else "Remote"
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                  for location in self.multiworld.get_filled_locations(self.player)},
							 
						 
					
						
							
								
									
										
										
										
											2021-10-09 14:29:52 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # store start_inventory from player's .yaml
							 
						 
					
						
							
								
									
										
										
										
											2022-12-11 14:14:27 +01:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # make sure to mark as not remote_start_inventory when connecting if stored in rom/mod
							 
						 
					
						
							
								
									
										
										
										
											2021-10-10 18:39:03 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "starter_items": [item.name for item
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                          in self.multiworld.precollected_items[self.player]],
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "final_boss_hp": self.final_boss_hp,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # store option name "easy", "normal" or "hard" for difficuly
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "difficulty": self.multiworld.difficulty[self.player].current_key,
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # store option value True or False for fixing a glitch
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        "fix_xyz_glitch": self.multiworld.fix_xyz_glitch[self.player].value
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # point to a ROM specified by the installation
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    src = Utils.get_options()["mygame_options"]["rom_file"]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # or point to worlds/mygame/data/mod_template
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    src = os.path.join(os.path.dirname(__file__), "data", "mod_template")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # generate output path
							 
						 
					
						
							
								
									
										
										
										
											2022-10-31 21:41:21 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    mod_name = f"AP-{self.multiworld.seed_name}-P{self.player}-{self.multiworld.player_name[self.player]}"
							 
						 
					
						
							
								
									
										
										
										
											2021-10-08 00:25:20 +02:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    out_file = os.path.join(output_directory, mod_name + ".zip")
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # generate the file
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    generate_mod(src, out_file, data)
							 
						 
					
						
							
								
									
										
										
										
											2021-10-07 19:41:29 +02:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-02-19 16:16:56 -06:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								### Documentation
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Each world implementation should have a tutorial and a game info page. These are both rendered on the website by reading
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the `.md`  files in your world's `/docs`  directory.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Game Info
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								The game info page is for a short breakdown of what your game is and how it works in Archipelago. Any additional
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								information that may be useful to the player when learning your randomizer should also go here. The file name format
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								is `<language key>_<game name>.md` . While you can write these docs for multiple languages, currently only the english
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								version is displayed on the website.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								#### Tutorials
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Your game can have as many tutorials in as many languages as you like, with each one having a relevant `Tutorial` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								defined in the `WebWorld` . The file name you use aren't particularly important, but it should be descriptive of what
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the tutorial is covering, and the name of the file must match the relative URL provided in the `Tutorial` . Currently,
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								the JS that determines this ignores the provided file name and will search for `game/document_lang.md` , where
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								`game/document/lang`  is the provided URL. 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								### Tests
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Each world is expected to include unit tests that cover its logic, to ensure no logic bug regressions occur. This can be
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								done by creating a `/test`  package within your world package. The `__init__.py`  within this folder is where the world's
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TestBase should be defined. This can be inherited from the main TestBase, which will automatically set up a solo
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								multiworld for each test written using it. Within subsequent modules, classes should be defined which inherit the world
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								TestBase, and can then define options to test in the class body, and run tests in each test method.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example `__init__.py` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from test.TestBase import WorldTestBase
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class MyGameTestBase(WorldTestBase):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								  game = "My Game"
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Next using the rules defined in the above `set_rules`  we can test that the chests have the correct access rules.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Example `testChestAccess.py` 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```python
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								from . import MyGameTestBase
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								class TestChestAccess(MyGameTestBase):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def testSwordChests(self):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        """Test locations that require a sword"""
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        locations = ["Chest1", "Chest2"]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        items = [["Sword"]]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # this will test that each location can't be accessed without the "Sword", but can be accessed once obtained.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self.assertAccessDependency(locations, items)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def testAnyWeaponChests(self):
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        """Test locations that require any weapon"""
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        locations = [f"Chest{i}" for i in range(3, 6)]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        items = [["Sword"], ["Axe"], ["Spear"]]
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # this will test that chests 3-5 can't be accessed without any weapon, but can be with just one of them.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        self.assertAccessDependency(locations, items)
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								```