145 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			145 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			Python
		
	
	
	
| from .Options import InscryptionOptions, Goal, EpitaphPiecesRandomization, PaintingChecksBalancing
 | |
| from .Items import act1_items, act2_items, act3_items, filler_items, base_id, InscryptionItem, ItemDict
 | |
| from .Locations import act1_locations, act2_locations, act3_locations, regions_to_locations
 | |
| from .Regions import inscryption_regions_all, inscryption_regions_act_1
 | |
| from typing import Dict, Any
 | |
| from . import Rules
 | |
| from BaseClasses import Region, Item, Tutorial, ItemClassification
 | |
| from worlds.AutoWorld import World, WebWorld
 | |
| 
 | |
| 
 | |
| class InscrypWeb(WebWorld):
 | |
|     theme = "dirt"
 | |
| 
 | |
|     guide_en = Tutorial(
 | |
|         "Multiworld Setup Guide",
 | |
|         "A guide to setting up the Inscryption Archipelago Multiworld",
 | |
|         "English",
 | |
|         "setup_en.md",
 | |
|         "setup/en",
 | |
|         ["DrBibop"]
 | |
|     )
 | |
| 
 | |
|     guide_fr = Tutorial(
 | |
|         "Multiworld Setup Guide",
 | |
|         "Un guide pour configurer Inscryption Archipelago Multiworld",
 | |
|         "Français",
 | |
|         "setup_fr.md",
 | |
|         "setup/fr",
 | |
|         ["Glowbuzz"]
 | |
|     )
 | |
| 
 | |
|     tutorials = [guide_en, guide_fr]
 | |
| 
 | |
|     bug_report_page = "https://github.com/DrBibop/Archipelago_Inscryption/issues"
 | |
| 
 | |
| 
 | |
| class InscryptionWorld(World):
 | |
|     """
 | |
|     Inscryption is an inky black card-based odyssey that blends the deckbuilding roguelike,
 | |
|     escape-room style puzzles, and psychological horror into a blood-laced smoothie.
 | |
|     Darker still are the secrets inscrybed upon the cards...
 | |
|     """
 | |
|     game = "Inscryption"
 | |
|     web = InscrypWeb()
 | |
|     options_dataclass = InscryptionOptions
 | |
|     options: InscryptionOptions
 | |
|     all_items = act1_items + act2_items + act3_items + filler_items
 | |
|     item_name_to_id = {item["name"]: i + base_id for i, item in enumerate(all_items)}
 | |
|     all_locations = act1_locations + act2_locations + act3_locations
 | |
|     location_name_to_id = {location: i + base_id for i, location in enumerate(all_locations)}
 | |
|     required_epitaph_pieces_count = 9
 | |
|     required_epitaph_pieces_name = "Epitaph Piece"
 | |
| 
 | |
|     def generate_early(self) -> None:
 | |
|         self.all_items = [item.copy() for item in self.all_items]
 | |
| 
 | |
|         if self.options.epitaph_pieces_randomization == EpitaphPiecesRandomization.option_all_pieces:
 | |
|             self.required_epitaph_pieces_name = "Epitaph Piece"
 | |
|             self.required_epitaph_pieces_count = 9
 | |
|         elif self.options.epitaph_pieces_randomization == EpitaphPiecesRandomization.option_in_groups:
 | |
|             self.required_epitaph_pieces_name = "Epitaph Pieces"
 | |
|             self.required_epitaph_pieces_count = 3
 | |
|         else:
 | |
|             self.required_epitaph_pieces_name = "Epitaph Pieces"
 | |
|             self.required_epitaph_pieces_count = 1
 | |
| 
 | |
|         if self.options.painting_checks_balancing == PaintingChecksBalancing.option_balanced:
 | |
|             self.all_items[6]["classification"] = ItemClassification.progression
 | |
|             self.all_items[11]["classification"] = ItemClassification.progression
 | |
| 
 | |
|         if self.options.painting_checks_balancing == PaintingChecksBalancing.option_force_filler \
 | |
|                 and self.options.goal == Goal.option_first_act:
 | |
|             self.all_items[3]["classification"] = ItemClassification.filler
 | |
| 
 | |
|         if self.options.epitaph_pieces_randomization != EpitaphPiecesRandomization.option_all_pieces:
 | |
|             self.all_items[len(act1_items) + 3]["count"] = self.required_epitaph_pieces_count
 | |
| 
 | |
|     def get_filler_item_name(self) -> str:
 | |
|         return self.random.choice(filler_items)["name"]
 | |
| 
 | |
|     def create_item(self, name: str) -> Item:
 | |
|         item_id = self.item_name_to_id[name]
 | |
|         item_data = self.all_items[item_id - base_id]
 | |
|         return InscryptionItem(name, item_data["classification"], item_id, self.player)
 | |
| 
 | |
|     def create_items(self) -> None:
 | |
|         nb_items_added = 0
 | |
|         useful_items = self.all_items.copy()
 | |
| 
 | |
|         if self.options.goal != Goal.option_first_act:
 | |
|             useful_items = [item for item in useful_items
 | |
|                             if not any(filler_item["name"] == item["name"] for filler_item in filler_items)]
 | |
|             if self.options.epitaph_pieces_randomization == EpitaphPiecesRandomization.option_all_pieces:
 | |
|                 useful_items.pop(len(act1_items) + 3)
 | |
|             else:
 | |
|                 useful_items.pop(len(act1_items) + 2)
 | |
|         else:
 | |
|             useful_items = [item for item in useful_items
 | |
|                             if any(act1_item["name"] == item["name"] for act1_item in act1_items)]
 | |
| 
 | |
|         for item in useful_items:
 | |
|             for _ in range(item["count"]):
 | |
|                 new_item = self.create_item(item["name"])
 | |
|                 self.multiworld.itempool.append(new_item)
 | |
|                 nb_items_added += 1
 | |
| 
 | |
|         filler_count = len(self.all_locations if self.options.goal != Goal.option_first_act else act1_locations)
 | |
|         filler_count -= nb_items_added
 | |
| 
 | |
|         for i in range(filler_count):
 | |
|             index = i % len(filler_items)
 | |
|             filler_item = filler_items[index]
 | |
|             new_item = self.create_item(filler_item["name"])
 | |
|             self.multiworld.itempool.append(new_item)
 | |
| 
 | |
|     def create_regions(self) -> None:
 | |
|         used_regions = inscryption_regions_all if self.options.goal != Goal.option_first_act \
 | |
|             else inscryption_regions_act_1
 | |
|         for region_name in used_regions.keys():
 | |
|             self.multiworld.regions.append(Region(region_name, self.player, self.multiworld))
 | |
| 
 | |
|         for region_name, region_connections in used_regions.items():
 | |
|             region = self.get_region(region_name)
 | |
|             region.add_exits(region_connections)
 | |
|             region.add_locations({
 | |
|                 location: self.location_name_to_id[location] for location in regions_to_locations[region_name]
 | |
|             })
 | |
| 
 | |
|     def set_rules(self) -> None:
 | |
|         Rules.InscryptionRules(self).set_all_rules()
 | |
| 
 | |
|     def fill_slot_data(self) -> Dict[str, Any]:
 | |
|         return self.options.as_dict(
 | |
|             "death_link",
 | |
|             "act1_death_link_behaviour",
 | |
|             "goal",
 | |
|             "randomize_codes",
 | |
|             "randomize_deck",
 | |
|             "randomize_sigils",
 | |
|             "optional_death_card",
 | |
|             "skip_tutorial",
 | |
|             "skip_epilogue",
 | |
|             "epitaph_pieces_randomization"
 | |
|         )
 |