mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	 62657df3fb
			
		
	
	62657df3fb
	
	
	
		
			
			## What is this fixing or adding? Major content update for Stardew Valley ## How was this tested? One large-scale public Beta on the archipelago server, plus several smaller private asyncs and test runs You can go to https://github.com/agilbert1412/StardewArchipelago/releases to grab the mod (latest 4.x.x version), the supported mods and the apworld, to test this PR ## New Features: - Festival Checks [Easy mode or Hard Mode] - Special Orders [Both Board and Qi] - Willy's Boat - Ginger Island Parrots - TV Channels - Trap Items [Available in various difficulty levels] - Entrance Randomizer: Buildings and Chaos - New Fishsanity options: Exclude Legendaries, Exclude Hard fish, Only easy fish - Resource Pack overhaul [Resource packs are now more enjoyable and varied] - Goal: Greatest Walnut Hunter [Find every single Golden Walnut] - Goal: Perfection [Achieve Perfection] - Option: Profit Margin [Multiplier over all earnings] - Option: Friendsanity Heart Size [Reduce clutter from friendsanity hearts] - Option: Exclude Ginger Island - will exclude many locations and items to generate a playthrough that does not go to the island - Mod Support [Curated list of mods] ## New Contributors: @Witchybun for the mod support --------- Co-authored-by: Witchybun <embenham05@gmail.com> Co-authored-by: Exempt-Medic <60412657+Exempt-Medic@users.noreply.github.com> Co-authored-by: Fabian Dill <Berserker66@users.noreply.github.com>
		
			
				
	
	
		
			609 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			609 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from dataclasses import dataclass
 | |
| from typing import Dict, Union, Protocol, runtime_checkable, ClassVar
 | |
| 
 | |
| from Options import Option, Range, DeathLink, SpecialRange, Toggle, Choice, OptionSet
 | |
| from .mods.mod_data import ModNames
 | |
| 
 | |
| @runtime_checkable
 | |
| class StardewOption(Protocol):
 | |
|     internal_name: ClassVar[str]
 | |
| 
 | |
| 
 | |
| @dataclass
 | |
| class StardewOptions:
 | |
|     options: Dict[str, Union[bool, int, str]]
 | |
| 
 | |
|     def __getitem__(self, item: Union[str, StardewOption]) -> Union[bool, int, str]:
 | |
|         if isinstance(item, StardewOption):
 | |
|             item = item.internal_name
 | |
| 
 | |
|         return self.options.get(item, None)
 | |
| 
 | |
|     def __setitem__(self, key: Union[str, StardewOption], value: Union[bool, int, str]):
 | |
|         if isinstance(key, StardewOption):
 | |
|             key = key.internal_name
 | |
|         self.options[key] = value
 | |
| 
 | |
| 
 | |
| class Goal(Choice):
 | |
|     """What's your goal with this play-through?
 | |
|     Community Center: The world will be completed once you complete the Community Center.
 | |
|     Grandpa's Evaluation: The world will be completed once 4 candles are lit at Grandpa's Shrine.
 | |
|     Bottom of the Mines: The world will be completed once you reach level 120 in the mineshaft.
 | |
|     Cryptic Note: The world will be completed once you complete the quest "Cryptic Note" where Mr Qi asks you to reach floor 100 in the Skull Cavern.
 | |
|     Master Angler: The world will be completed once you have caught every fish in the game. Pairs well with Fishsanity.
 | |
|     Complete Collection: The world will be completed once you have completed the museum by donating every possible item. Pairs well with Museumsanity.
 | |
|     Full House: The world will be completed once you get married and have two kids. Pairs well with Friendsanity.
 | |
|     Greatest Walnut Hunter: The world will be completed once you find all 130 Golden Walnuts
 | |
|     Perfection: The world will be completed once you attain Perfection, based on the vanilla definition.
 | |
|     """
 | |
|     internal_name = "goal"
 | |
|     display_name = "Goal"
 | |
|     default = 0
 | |
|     option_community_center = 0
 | |
|     option_grandpa_evaluation = 1
 | |
|     option_bottom_of_the_mines = 2
 | |
|     option_cryptic_note = 3
 | |
|     option_master_angler = 4
 | |
|     option_complete_collection = 5
 | |
|     option_full_house = 6
 | |
|     option_greatest_walnut_hunter = 7
 | |
|     # option_junimo_kart =
 | |
|     # option_prairie_king =
 | |
|     # option_fector_challenge =
 | |
|     # option_craft_master =
 | |
|     # option_mystery_of_the_stardrops =
 | |
|     # option_protector_of_the_valley =
 | |
|     # option_full_shipment =
 | |
|     # option_legend =
 | |
|     # option_beloved_farmer =
 | |
|     # option_master_of_the_five_ways =
 | |
|     option_perfection = 25
 | |
| 
 | |
|     @classmethod
 | |
|     def get_option_name(cls, value) -> str:
 | |
|         if value == cls.option_grandpa_evaluation:
 | |
|             return "Grandpa's Evaluation"
 | |
| 
 | |
|         return super().get_option_name(value)
 | |
| 
 | |
| 
 | |
| class StartingMoney(SpecialRange):
 | |
|     """Amount of gold when arriving at the farm.
 | |
|     Set to -1 or unlimited for infinite money in this playthrough"""
 | |
|     internal_name = "starting_money"
 | |
|     display_name = "Starting Gold"
 | |
|     range_start = -1
 | |
|     range_end = 50000
 | |
|     default = 5000
 | |
| 
 | |
|     special_range_names = {
 | |
|         "unlimited": -1,
 | |
|         "vanilla": 500,
 | |
|         "extra": 2000,
 | |
|         "rich": 5000,
 | |
|         "very rich": 20000,
 | |
|         "filthy rich": 50000,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class ProfitMargin(SpecialRange):
 | |
|     """Multiplier over all gold earned in-game by the player."""
 | |
|     internal_name = "profit_margin"
 | |
|     display_name = "Profit Margin"
 | |
|     range_start = 25
 | |
|     range_end = 400
 | |
|     # step = 25
 | |
|     default = 100
 | |
| 
 | |
|     special_range_names = {
 | |
|         "quarter": 25,
 | |
|         "half": 50,
 | |
|         "normal": 100,
 | |
|         "double": 200,
 | |
|         "triple": 300,
 | |
|         "quadruple": 400,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class BundleRandomization(Choice):
 | |
|     """What items are needed for the community center bundles?
 | |
|     Vanilla: Standard bundles from the vanilla game
 | |
|     Thematic: Every bundle will require random items compatible with their original theme
 | |
|     Shuffled: Every bundle will require random items and follow no particular structure"""
 | |
|     internal_name = "bundle_randomization"
 | |
|     display_name = "Bundle Randomization"
 | |
|     default = 1
 | |
|     option_vanilla = 0
 | |
|     option_thematic = 1
 | |
|     option_shuffled = 2
 | |
| 
 | |
| 
 | |
| class BundlePrice(Choice):
 | |
|     """How many items are needed for the community center bundles?
 | |
|     Very Cheap: Every bundle will require 2 items fewer than usual
 | |
|     Cheap: Every bundle will require 1 item fewer than usual
 | |
|     Normal: Every bundle will require the vanilla number of items
 | |
|     Expensive: Every bundle will require 1 extra item when applicable"""
 | |
|     internal_name = "bundle_price"
 | |
|     display_name = "Bundle Price"
 | |
|     default = 2
 | |
|     option_very_cheap = 0
 | |
|     option_cheap = 1
 | |
|     option_normal = 2
 | |
|     option_expensive = 3
 | |
| 
 | |
| 
 | |
| class EntranceRandomization(Choice):
 | |
|     """Should area entrances be randomized?
 | |
|     Disabled: No entrance randomization is done
 | |
|     Pelican Town: Only buildings in the main town area are randomized among each other
 | |
|     Non Progression: Only buildings that are always available are randomized with each other
 | |
|     Buildings: All Entrances that Allow you to enter a building using a door are randomized with each other
 | |
|     Chaos: Same as above, but the entrances get reshuffled every single day!
 | |
|     """
 | |
|     # Everything: All buildings and areas are randomized with each other
 | |
|     # Chaos, same as everything: but the buildings are shuffled again every in-game day. You can't learn it!
 | |
|     # Buildings One-way: Entrance pairs are disconnected, they aren't two-way!
 | |
|     # Everything One-way: Entrance pairs are disconnected, and every entrance is in the shuffle
 | |
|     # Chaos One-way: Entrance pairs are disconnected, and they change every day!
 | |
| 
 | |
|     internal_name = "entrance_randomization"
 | |
|     display_name = "Entrance Randomization"
 | |
|     default = 0
 | |
|     option_disabled = 0
 | |
|     option_pelican_town = 1
 | |
|     option_non_progression = 2
 | |
|     option_buildings = 3
 | |
|     # option_everything = 4
 | |
|     option_chaos = 5
 | |
|     # option_buildings_one_way = 6
 | |
|     # option_everything_one_way = 7
 | |
|     # option_chaos_one_way = 8
 | |
| 
 | |
| 
 | |
| class SeasonRandomization(Choice):
 | |
|     """Should seasons be randomized?
 | |
|     All settings allow you to choose which season you want to play next (from those unlocked) at the end of a season.
 | |
|     Disabled: You will start in Spring with all seasons unlocked.
 | |
|     Randomized: The seasons will be unlocked randomly as Archipelago items.
 | |
|     Randomized Not Winter: The seasons are randomized, but you're guaranteed not to start with winter.
 | |
|     Progressive: You will start in Spring and unlock the seasons in their original order.
 | |
|     """
 | |
|     internal_name = "season_randomization"
 | |
|     display_name = "Season Randomization"
 | |
|     default = 1
 | |
|     option_disabled = 0
 | |
|     option_randomized = 1
 | |
|     option_randomized_not_winter = 2
 | |
|     option_progressive = 3
 | |
| 
 | |
| 
 | |
| class Cropsanity(Choice):
 | |
|     """Formerly named "Seed Shuffle"
 | |
|     Pierre now sells a random amount of seasonal seeds and Joja sells them without season requirements, but only in huge packs.
 | |
|     Disabled: All the seeds are unlocked from the start, there are no location checks for growing and harvesting crops
 | |
|     Shuffled: Seeds are unlocked as archipelago item, for each seed there is a location check for growing and harvesting that crop
 | |
|     """
 | |
|     internal_name = "cropsanity"
 | |
|     display_name = "Cropsanity"
 | |
|     default = 1
 | |
|     option_disabled = 0
 | |
|     option_shuffled = 1
 | |
| 
 | |
| 
 | |
| class BackpackProgression(Choice):
 | |
|     """How is the backpack progression handled?
 | |
|     Vanilla: You can buy them at Pierre's General Store.
 | |
|     Progressive: You will randomly find Progressive Backpack upgrades.
 | |
|     Early Progressive: You can expect your first Backpack in sphere 1.
 | |
|     """
 | |
|     internal_name = "backpack_progression"
 | |
|     display_name = "Backpack Progression"
 | |
|     default = 2
 | |
|     option_vanilla = 0
 | |
|     option_progressive = 1
 | |
|     option_early_progressive = 2
 | |
| 
 | |
| 
 | |
| class ToolProgression(Choice):
 | |
|     """How is the tool progression handled?
 | |
|     Vanilla: Clint will upgrade your tools with ore.
 | |
|     Progressive: You will randomly find Progressive Tool upgrades."""
 | |
|     internal_name = "tool_progression"
 | |
|     display_name = "Tool Progression"
 | |
|     default = 1
 | |
|     option_vanilla = 0
 | |
|     option_progressive = 1
 | |
| 
 | |
| 
 | |
| class ElevatorProgression(Choice):
 | |
|     """How is Elevator progression handled?
 | |
|     Vanilla: You will unlock new elevator floors for yourself.
 | |
|     Progressive: You will randomly find Progressive Mine Elevators to go deeper. Locations are sent for reaching
 | |
|         every elevator level.
 | |
|     Progressive from previous floor: Same as progressive, but you must reach elevator floors on your own,
 | |
|         you cannot use the elevator to check elevator locations"""
 | |
|     internal_name = "elevator_progression"
 | |
|     display_name = "Elevator Progression"
 | |
|     default = 2
 | |
|     option_vanilla = 0
 | |
|     option_progressive = 1
 | |
|     option_progressive_from_previous_floor = 2
 | |
| 
 | |
| 
 | |
| class SkillProgression(Choice):
 | |
|     """How is the skill progression handled?
 | |
|     Vanilla: You will level up and get the normal reward at each level.
 | |
|     Progressive: The xp will be earned internally, locations will be sent when you earn a level. Your real
 | |
|         levels will be scattered around the multiworld."""
 | |
|     internal_name = "skill_progression"
 | |
|     display_name = "Skill Progression"
 | |
|     default = 1
 | |
|     option_vanilla = 0
 | |
|     option_progressive = 1
 | |
| 
 | |
| 
 | |
| class BuildingProgression(Choice):
 | |
|     """How is the building progression handled?
 | |
|     Vanilla: You will buy each building normally.
 | |
|     Progressive: You will receive the buildings and will be able to build the first one of each type for free,
 | |
|         once it is received. If you want more of the same building, it will cost the vanilla price.
 | |
|     Progressive early shipping bin: You can expect your shipping bin in sphere 1.
 | |
|     """
 | |
|     internal_name = "building_progression"
 | |
|     display_name = "Building Progression"
 | |
|     default = 2
 | |
|     option_vanilla = 0
 | |
|     option_progressive = 1
 | |
|     option_progressive_early_shipping_bin = 2
 | |
| 
 | |
| 
 | |
| class FestivalLocations(Choice):
 | |
|     """Locations for attending and participating in festivals
 | |
|     With Disabled, you do not need to attend festivals
 | |
|     With Easy, there are checks for participating in festivals
 | |
|     With Hard, the festival checks are only granted when the player performs well in the festival
 | |
|     """
 | |
|     internal_name = "festival_locations"
 | |
|     display_name = "Festival Locations"
 | |
|     default = 1
 | |
|     option_disabled = 0
 | |
|     option_easy = 1
 | |
|     option_hard = 2
 | |
| 
 | |
| 
 | |
| class ArcadeMachineLocations(Choice):
 | |
|     """How are the Arcade Machines handled?
 | |
|     Disabled: The arcade machines are not included in the Archipelago shuffling.
 | |
|     Victories: Each Arcade Machine will contain one check on victory
 | |
|     Victories Easy: The arcade machines are both made considerably easier to be more accessible for the average
 | |
|         player.
 | |
|     Full Shuffling: The arcade machines will contain multiple checks each, and different buffs that make the game
 | |
|         easier are in the item pool. Junimo Kart has one check at the end of each level.
 | |
|         Journey of the Prairie King has one check after each boss, plus one check for each vendor equipment.
 | |
|     """
 | |
|     internal_name = "arcade_machine_locations"
 | |
|     display_name = "Arcade Machine Locations"
 | |
|     default = 3
 | |
|     option_disabled = 0
 | |
|     option_victories = 1
 | |
|     option_victories_easy = 2
 | |
|     option_full_shuffling = 3
 | |
| 
 | |
| 
 | |
| class SpecialOrderLocations(Choice):
 | |
|     """How are the Special Orders handled?
 | |
|     Disabled: The special orders are not included in the Archipelago shuffling.
 | |
|     Board Only: The Special Orders on the board in town are location checks
 | |
|     Board and Qi: The Special Orders from Qi's walnut room are checks, as well as the board in town
 | |
|     """
 | |
|     internal_name = "special_order_locations"
 | |
|     display_name = "Special Order Locations"
 | |
|     default = 1
 | |
|     option_disabled = 0
 | |
|     option_board_only = 1
 | |
|     option_board_qi = 2
 | |
| 
 | |
| 
 | |
| class HelpWantedLocations(SpecialRange):
 | |
|     """How many "Help Wanted" quests need to be completed as Archipelago Locations
 | |
|     Out of every 7 quests, 4 will be item deliveries, and then 1 of each for: Fishing, Gathering and Slaying Monsters.
 | |
|     Choosing a multiple of 7 is recommended."""
 | |
|     internal_name = "help_wanted_locations"
 | |
|     default = 7
 | |
|     range_start = 0
 | |
|     range_end = 56
 | |
|     # step = 7
 | |
|     display_name = "Number of Help Wanted locations"
 | |
| 
 | |
|     special_range_names = {
 | |
|         "none": 0,
 | |
|         "minimum": 7,
 | |
|         "normal": 14,
 | |
|         "lots": 28,
 | |
|         "maximum": 56,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class Fishsanity(Choice):
 | |
|     """Locations for catching fish?
 | |
|     None: There are no locations for catching fish
 | |
|     Legendaries: Each of the 5 legendary fish are checks
 | |
|     Special: A curated selection of strong fish are checks
 | |
|     Randomized: A random selection of fish are checks
 | |
|     All: Every single fish in the game is a location that contains an item. Pairs well with the Master Angler Goal
 | |
|     Exclude Legendaries: Every fish except legendaries
 | |
|     Exclude Hard Fish: Every fish under difficulty 80
 | |
|     Only Easy Fish: Every fish under difficulty 50
 | |
|     """
 | |
|     internal_name = "fishsanity"
 | |
|     display_name = "Fishsanity"
 | |
|     default = 0
 | |
|     option_none = 0
 | |
|     option_legendaries = 1
 | |
|     option_special = 2
 | |
|     option_randomized = 3
 | |
|     alias_random_selection = option_randomized
 | |
|     option_all = 4
 | |
|     option_exclude_legendaries = 5
 | |
|     option_exclude_hard_fish = 6
 | |
|     option_only_easy_fish = 7
 | |
| 
 | |
| 
 | |
| class Museumsanity(Choice):
 | |
|     """Locations for museum donations?
 | |
|     None: There are no locations for donating artifacts and minerals to the museum
 | |
|     Milestones: The donation milestones from the vanilla game are checks
 | |
|     Randomized: A random selection of minerals and artifacts are checks
 | |
|     All: Every single donation will be a check
 | |
|     """
 | |
|     internal_name = "museumsanity"
 | |
|     display_name = "Museumsanity"
 | |
|     default = 1
 | |
|     option_none = 0
 | |
|     option_milestones = 1
 | |
|     option_randomized = 2
 | |
|     option_all = 3
 | |
| 
 | |
| 
 | |
| class Friendsanity(Choice):
 | |
|     """Locations for friendships?
 | |
|     None: There are no checks for befriending villagers
 | |
|     Bachelors: Each heart of a bachelor is a check
 | |
|     Starting NPCs: Each heart for npcs that are immediately available is a check
 | |
|     All: Every heart with every NPC is a check, including Leo, Kent, Sandy, etc
 | |
|     All With Marriage: Marriage candidates must also be dated, married, and befriended up to 14 hearts.
 | |
|     """
 | |
|     internal_name = "friendsanity"
 | |
|     display_name = "Friendsanity"
 | |
|     default = 0
 | |
|     option_none = 0
 | |
|     # option_marry_one_person = 1
 | |
|     option_bachelors = 2
 | |
|     option_starting_npcs = 3
 | |
|     option_all = 4
 | |
|     option_all_with_marriage = 5
 | |
| 
 | |
| 
 | |
| # Conditional Setting - Friendsanity not None
 | |
| class FriendsanityHeartSize(Range):
 | |
|     """If using friendsanity, how many hearts are received per item, and how many hearts must be earned to send a check
 | |
|     A higher value will lead to fewer heart items in the item pool, reducing bloat"""
 | |
|     internal_name = "friendsanity_heart_size"
 | |
|     display_name = "Friendsanity Heart Size"
 | |
|     range_start = 1
 | |
|     range_end = 8
 | |
|     default = 4
 | |
|     # step = 1
 | |
| 
 | |
| 
 | |
| class NumberOfMovementBuffs(Range):
 | |
|     """Number of movement speed buffs to the player that exist as items in the pool.
 | |
|     Each movement speed buff is a +25% multiplier that stacks additively"""
 | |
|     internal_name = "movement_buff_number"
 | |
|     display_name = "Number of Movement Buffs"
 | |
|     range_start = 0
 | |
|     range_end = 12
 | |
|     default = 4
 | |
|     # step = 1
 | |
| 
 | |
| 
 | |
| class NumberOfLuckBuffs(Range):
 | |
|     """Number of luck buffs to the player that exist as items in the pool.
 | |
|     Each luck buff is a bonus to daily luck of 0.025"""
 | |
|     internal_name = "luck_buff_number"
 | |
|     display_name = "Number of Luck Buffs"
 | |
|     range_start = 0
 | |
|     range_end = 12
 | |
|     default = 4
 | |
|     # step = 1
 | |
| 
 | |
| 
 | |
| class ExcludeGingerIsland(Toggle):
 | |
|     """Exclude Ginger Island?
 | |
|     This option will forcefully exclude everything related to Ginger Island from the slot.
 | |
|     If you pick a goal that requires Ginger Island, you cannot exclude it and it will get included anyway"""
 | |
|     internal_name = "exclude_ginger_island"
 | |
|     display_name = "Exclude Ginger Island"
 | |
|     default = 0
 | |
| 
 | |
| 
 | |
| class TrapItems(Choice):
 | |
|     """When rolling filler items, including resource packs, the game can also roll trap items.
 | |
|     This setting is for choosing if traps will be in the item pool, and if so, how punishing they will be.
 | |
|     """
 | |
|     internal_name = "trap_items"
 | |
|     display_name = "Trap Items"
 | |
|     default = 2
 | |
|     option_no_traps = 0
 | |
|     option_easy = 1
 | |
|     option_medium = 2
 | |
|     option_hard = 3
 | |
|     option_hell = 4
 | |
|     option_nightmare = 5
 | |
| 
 | |
| 
 | |
| class MultipleDaySleepEnabled(Toggle):
 | |
|     """Enable the ability to sleep automatically for multiple days straight?"""
 | |
|     internal_name = "multiple_day_sleep_enabled"
 | |
|     display_name = "Multiple Day Sleep Enabled"
 | |
|     default = 1
 | |
| 
 | |
| 
 | |
| class MultipleDaySleepCost(SpecialRange):
 | |
|     """How much gold it will cost to use MultiSleep. You will have to pay that amount for each day skipped."""
 | |
|     internal_name = "multiple_day_sleep_cost"
 | |
|     display_name = "Multiple Day Sleep Cost"
 | |
|     range_start = 0
 | |
|     range_end = 200
 | |
|     # step = 25
 | |
| 
 | |
|     special_range_names = {
 | |
|         "free": 0,
 | |
|         "cheap": 25,
 | |
|         "medium": 50,
 | |
|         "expensive": 100,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class ExperienceMultiplier(SpecialRange):
 | |
|     """How fast you want to earn skill experience. A lower setting mean less experience.
 | |
|     A higher setting means more experience."""
 | |
|     internal_name = "experience_multiplier"
 | |
|     display_name = "Experience Multiplier"
 | |
|     range_start = 25
 | |
|     range_end = 800
 | |
|     # step = 25
 | |
|     default = 200
 | |
| 
 | |
|     special_range_names = {
 | |
|         "half": 50,
 | |
|         "vanilla": 100,
 | |
|         "double": 200,
 | |
|         "triple": 300,
 | |
|         "quadruple": 400,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class FriendshipMultiplier(SpecialRange):
 | |
|     """How fast you want to earn friendship points with villagers.
 | |
|     A lower setting mean less friendship per action.
 | |
|     A higher setting means more friendship per action."""
 | |
|     internal_name = "friendship_multiplier"
 | |
|     display_name = "Friendship Multiplier"
 | |
|     range_start = 25
 | |
|     range_end = 800
 | |
|     # step = 25
 | |
|     default = 200
 | |
| 
 | |
|     special_range_names = {
 | |
|         "half": 50,
 | |
|         "vanilla": 100,
 | |
|         "double": 200,
 | |
|         "triple": 300,
 | |
|         "quadruple": 400,
 | |
|     }
 | |
| 
 | |
| 
 | |
| class DebrisMultiplier(Choice):
 | |
|     """How much debris will spawn on the player's farm?
 | |
|     Vanilla: debris spawns normally
 | |
|     Half: debris will spawn at half the normal rate
 | |
|     Quarter: debris will spawn at one quarter of the normal rate
 | |
|     None: No debris will spawn on the farm, ever
 | |
|     Start Clear: debris will spawn at the normal rate, but the farm will be completely clear when starting the game
 | |
|     """
 | |
|     internal_name = "debris_multiplier"
 | |
|     display_name = "Debris Multiplier"
 | |
|     default = 1
 | |
|     option_vanilla = 0
 | |
|     option_half = 1
 | |
|     option_quarter = 2
 | |
|     option_none = 3
 | |
|     option_start_clear = 4
 | |
| 
 | |
| 
 | |
| class QuickStart(Toggle):
 | |
|     """Do you want the quick start package? You will get a few items to help early game automation,
 | |
|     so you can use the multiple day sleep at its maximum."""
 | |
|     internal_name = "quick_start"
 | |
|     display_name = "Quick Start"
 | |
|     default = 1
 | |
| 
 | |
| 
 | |
| class Gifting(Toggle):
 | |
|     """Do you want to enable gifting items to and from other Stardew Valley worlds?"""
 | |
|     internal_name = "gifting"
 | |
|     display_name = "Gifting"
 | |
|     default = 1
 | |
| 
 | |
| 
 | |
| class Mods(OptionSet):
 | |
|     """List of mods that will be considered for shuffling."""
 | |
|     internal_name = "mods"
 | |
|     display_name = "Mods"
 | |
|     valid_keys = {
 | |
|         ModNames.deepwoods, ModNames.tractor, ModNames.big_backpack,
 | |
|         ModNames.luck_skill, ModNames.magic, ModNames.socializing_skill, ModNames.archaeology,
 | |
|         ModNames.cooking_skill, ModNames.binning_skill, ModNames.juna,
 | |
|         ModNames.jasper, ModNames.alec, ModNames.yoba, ModNames.eugene,
 | |
|         ModNames.wellwick, ModNames.ginger, ModNames.shiko, ModNames.delores,
 | |
|         ModNames.ayeisha, ModNames.riley, ModNames.skull_cavern_elevator
 | |
|     }
 | |
| 
 | |
| 
 | |
| stardew_valley_option_classes = [
 | |
|     Goal,
 | |
|     StartingMoney,
 | |
|     ProfitMargin,
 | |
|     BundleRandomization,
 | |
|     BundlePrice,
 | |
|     EntranceRandomization,
 | |
|     SeasonRandomization,
 | |
|     Cropsanity,
 | |
|     BackpackProgression,
 | |
|     ToolProgression,
 | |
|     SkillProgression,
 | |
|     BuildingProgression,
 | |
|     FestivalLocations,
 | |
|     ElevatorProgression,
 | |
|     ArcadeMachineLocations,
 | |
|     SpecialOrderLocations,
 | |
|     HelpWantedLocations,
 | |
|     Fishsanity,
 | |
|     Museumsanity,
 | |
|     Friendsanity,
 | |
|     FriendsanityHeartSize,
 | |
|     NumberOfMovementBuffs,
 | |
|     NumberOfLuckBuffs,
 | |
|     ExcludeGingerIsland,
 | |
|     TrapItems,
 | |
|     MultipleDaySleepEnabled,
 | |
|     MultipleDaySleepCost,
 | |
|     ExperienceMultiplier,
 | |
|     FriendshipMultiplier,
 | |
|     DebrisMultiplier,
 | |
|     QuickStart,
 | |
|     Gifting,
 | |
|     Mods,
 | |
| ]
 | |
| stardew_valley_options: Dict[str, type(Option)] = {option.internal_name: option for option in
 | |
|                                                    stardew_valley_option_classes}
 | |
| default_options = {option.internal_name: option.default for option in stardew_valley_options.values()}
 | |
| stardew_valley_options["death_link"] = DeathLink
 | |
| 
 | |
| 
 | |
| def fetch_options(world, player: int) -> StardewOptions:
 | |
|     return StardewOptions({option: get_option_value(world, player, option) for option in stardew_valley_options})
 | |
| 
 | |
| 
 | |
| def get_option_value(world, player: int, name: str) -> Union[bool, int]:
 | |
|     assert name in stardew_valley_options, f"{name} is not a valid option for Stardew Valley."
 | |
| 
 | |
|     value = getattr(world, name)
 | |
| 
 | |
|     if issubclass(stardew_valley_options[name], Toggle):
 | |
|         return bool(value[player].value)
 | |
|     return value[player].value
 |