mirror of
				https://github.com/MarioSpore/Grinch-AP.git
				synced 2025-10-21 20:21:32 -06:00 
			
		
		
		
	 ee9bcb84b7
			
		
	
	ee9bcb84b7
	
	
	
		
			
			* 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
		
			
				
	
	
		
			102 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| from typing import Union
 | |
| 
 | |
| from Utils import cache_self1
 | |
| from .base_logic import BaseLogicMixin, BaseLogic
 | |
| from .combat_logic import CombatLogicMixin
 | |
| from .cooking_logic import CookingLogicMixin
 | |
| from .has_logic import HasLogicMixin
 | |
| from .received_logic import ReceivedLogicMixin
 | |
| from .region_logic import RegionLogicMixin
 | |
| from .skill_logic import SkillLogicMixin
 | |
| from .tool_logic import ToolLogicMixin
 | |
| from .. import options
 | |
| from ..stardew_rule import StardewRule, True_
 | |
| from ..strings.performance_names import Performance
 | |
| from ..strings.region_names import Region
 | |
| from ..strings.skill_names import Skill
 | |
| from ..strings.tool_names import ToolMaterial
 | |
| 
 | |
| 
 | |
| class MineLogicMixin(BaseLogicMixin):
 | |
|     def __init__(self, *args, **kwargs):
 | |
|         super().__init__(*args, **kwargs)
 | |
|         self.mine = MineLogic(*args, **kwargs)
 | |
| 
 | |
| 
 | |
| class MineLogic(BaseLogic[Union[HasLogicMixin, MineLogicMixin, RegionLogicMixin, ReceivedLogicMixin, CombatLogicMixin, ToolLogicMixin,
 | |
| SkillLogicMixin, CookingLogicMixin]]):
 | |
|     # Regions
 | |
|     def can_mine_in_the_mines_floor_1_40(self) -> StardewRule:
 | |
|         return self.logic.region.can_reach(Region.mines_floor_5)
 | |
| 
 | |
|     def can_mine_in_the_mines_floor_41_80(self) -> StardewRule:
 | |
|         return self.logic.region.can_reach(Region.mines_floor_45)
 | |
| 
 | |
|     def can_mine_in_the_mines_floor_81_120(self) -> StardewRule:
 | |
|         return self.logic.region.can_reach(Region.mines_floor_85)
 | |
| 
 | |
|     def can_mine_in_the_skull_cavern(self) -> StardewRule:
 | |
|         return (self.logic.mine.can_progress_in_the_mines_from_floor(120) &
 | |
|                 self.logic.region.can_reach(Region.skull_cavern))
 | |
| 
 | |
|     @cache_self1
 | |
|     def get_weapon_rule_for_floor_tier(self, tier: int):
 | |
|         if tier >= 4:
 | |
|             return self.logic.combat.can_fight_at_level(Performance.galaxy)
 | |
|         if tier >= 3:
 | |
|             return self.logic.combat.can_fight_at_level(Performance.great)
 | |
|         if tier >= 2:
 | |
|             return self.logic.combat.can_fight_at_level(Performance.good)
 | |
|         if tier >= 1:
 | |
|             return self.logic.combat.can_fight_at_level(Performance.decent)
 | |
|         return self.logic.combat.can_fight_at_level(Performance.basic)
 | |
| 
 | |
|     @cache_self1
 | |
|     def can_progress_in_the_mines_from_floor(self, floor: int) -> StardewRule:
 | |
|         tier = floor // 40
 | |
|         rules = []
 | |
| 
 | |
|         weapon_rule = self.logic.mine.get_weapon_rule_for_floor_tier(tier)
 | |
|         rules.append(weapon_rule)
 | |
| 
 | |
|         tool_rule = self.logic.tool.can_mine_using(ToolMaterial.tiers[tier])
 | |
|         rules.append(tool_rule)
 | |
| 
 | |
|         # No alternative for vanilla because we assume that you will grind the levels in the mines.
 | |
|         if self.content.features.skill_progression.is_progressive:
 | |
|             skill_level = min(10, max(0, tier * 2))
 | |
|             rules.append(self.logic.skill.has_level(Skill.combat, skill_level))
 | |
|             rules.append(self.logic.skill.has_level(Skill.mining, skill_level))
 | |
| 
 | |
|         if tier >= 4:
 | |
|             rules.append(self.logic.cooking.can_cook())
 | |
| 
 | |
|         return self.logic.and_(*rules)
 | |
| 
 | |
|     @cache_self1
 | |
|     def has_mine_elevator_to_floor(self, floor: int) -> StardewRule:
 | |
|         if floor < 0:
 | |
|             floor = 0
 | |
|         if self.options.elevator_progression != options.ElevatorProgression.option_vanilla:
 | |
|             return self.logic.received("Progressive Mine Elevator", floor // 5)
 | |
|         return True_()
 | |
| 
 | |
|     @cache_self1
 | |
|     def can_progress_in_the_skull_cavern_from_floor(self, floor: int) -> StardewRule:
 | |
|         tier = floor // 50
 | |
|         rules = []
 | |
| 
 | |
|         weapon_rule = self.logic.combat.has_great_weapon
 | |
|         rules.append(weapon_rule)
 | |
| 
 | |
|         tool_rule = self.logic.tool.can_mine_using(ToolMaterial.tiers[min(4, max(0, tier + 2))])
 | |
|         rules.append(tool_rule)
 | |
| 
 | |
|         # No alternative for vanilla because we assume that you will grind the levels in the mines.
 | |
|         if self.content.features.skill_progression.is_progressive:
 | |
|             skill_level = min(10, max(0, tier * 2 + 6))
 | |
|             rules.extend((self.logic.skill.has_level(Skill.combat, skill_level),
 | |
|                           self.logic.skill.has_level(Skill.mining, skill_level)))
 | |
| 
 | |
|         return self.logic.and_(*rules)
 |