mirror of
https://github.com/MarioSpore/Grinch-AP.git
synced 2025-10-21 20:21:32 -06:00
Stardew Valley: Move progressive tool options handling in features (#4374)
* create tool progression feature and unwrap option * replace option usage with calling feature * add comment explaining why some logic is a weird place * replace item creation logic with feature * self review and add unit tests * rename test cuz I named them too long * add a test for the trash can useful stuff cuz I thought there was a bug but turns out it works * self review again * remove price_multiplier, turns out it's unused during generation * damn it 3.11 why are you like this * use blacksmith region when checking vanilla tools * fix rule * move can mine using in tool logic * remove changes to performance test * properly set the option I guess * properly set options 2 * that's what happen when you code too late
This commit is contained in:
68
worlds/stardew_valley/content/feature/tool_progression.py
Normal file
68
worlds/stardew_valley/content/feature/tool_progression.py
Normal file
@@ -0,0 +1,68 @@
|
||||
from abc import ABC
|
||||
from collections import Counter
|
||||
from collections.abc import Mapping
|
||||
from dataclasses import dataclass, field
|
||||
from functools import cache
|
||||
from types import MappingProxyType
|
||||
from typing import ClassVar
|
||||
|
||||
from ...strings.tool_names import Tool
|
||||
|
||||
|
||||
def to_progressive_item(tool: str) -> str:
|
||||
"""Return the name of the progressive item."""
|
||||
return f"Progressive {tool}"
|
||||
|
||||
|
||||
# The golden scythe is always randomized
|
||||
VANILLA_TOOL_DISTRIBUTION = MappingProxyType({
|
||||
Tool.scythe: 1,
|
||||
})
|
||||
|
||||
PROGRESSIVE_TOOL_DISTRIBUTION = MappingProxyType({
|
||||
Tool.axe: 4,
|
||||
Tool.hoe: 4,
|
||||
Tool.pickaxe: 4,
|
||||
Tool.pan: 4,
|
||||
Tool.trash_can: 4,
|
||||
Tool.watering_can: 4,
|
||||
Tool.fishing_rod: 4,
|
||||
})
|
||||
|
||||
# Masteries add another tier to the scythe and the fishing rod
|
||||
SKILL_MASTERIES_TOOL_DISTRIBUTION = MappingProxyType({
|
||||
Tool.scythe: 1,
|
||||
Tool.fishing_rod: 1,
|
||||
})
|
||||
|
||||
|
||||
@cache
|
||||
def get_tools_distribution(progressive_tools_enabled: bool, skill_masteries_enabled: bool) -> Mapping[str, int]:
|
||||
distribution = Counter(VANILLA_TOOL_DISTRIBUTION)
|
||||
|
||||
if progressive_tools_enabled:
|
||||
distribution += PROGRESSIVE_TOOL_DISTRIBUTION
|
||||
|
||||
if skill_masteries_enabled:
|
||||
distribution += SKILL_MASTERIES_TOOL_DISTRIBUTION
|
||||
|
||||
return MappingProxyType(distribution)
|
||||
|
||||
|
||||
@dataclass(frozen=True)
|
||||
class ToolProgressionFeature(ABC):
|
||||
is_progressive: ClassVar[bool]
|
||||
tool_distribution: Mapping[str, int]
|
||||
|
||||
to_progressive_item = staticmethod(to_progressive_item)
|
||||
|
||||
|
||||
@dataclass(frozen=True)
|
||||
class ToolProgressionVanilla(ToolProgressionFeature):
|
||||
is_progressive = False
|
||||
# FIXME change the default_factory to a simple default when python 3.11 is no longer supported
|
||||
tool_distribution: Mapping[str, int] = field(default_factory=lambda: VANILLA_TOOL_DISTRIBUTION)
|
||||
|
||||
|
||||
class ToolProgressionProgressive(ToolProgressionFeature):
|
||||
is_progressive = True
|
||||
Reference in New Issue
Block a user