40 lines
		
	
	
		
			847 B
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			847 B
		
	
	
	
		
			Python
		
	
	
	
| from functools import singledispatch
 | |
| from typing import Set
 | |
| 
 | |
| from . import StardewRule, Reach, Count, AggregatingStardewRule, Has
 | |
| 
 | |
| 
 | |
| def look_for_indirect_connection(rule: StardewRule) -> Set[str]:
 | |
|     required_regions = set()
 | |
|     _find(rule, required_regions)
 | |
|     return required_regions
 | |
| 
 | |
| 
 | |
| @singledispatch
 | |
| def _find(rule: StardewRule, regions: Set[str]):
 | |
|     ...
 | |
| 
 | |
| 
 | |
| @_find.register
 | |
| def _(rule: AggregatingStardewRule, regions: Set[str]):
 | |
|     for r in rule.original_rules:
 | |
|         _find(r, regions)
 | |
| 
 | |
| 
 | |
| @_find.register
 | |
| def _(rule: Count, regions: Set[str]):
 | |
|     for r in rule.rules:
 | |
|         _find(r, regions)
 | |
| 
 | |
| 
 | |
| @_find.register
 | |
| def _(rule: Has, regions: Set[str]):
 | |
|     r = rule.other_rules[rule.item]
 | |
|     _find(r, regions)
 | |
| 
 | |
| 
 | |
| @_find.register
 | |
| def _(rule: Reach, regions: Set[str]):
 | |
|     if rule.resolution_hint == "Region":
 | |
|         regions.add(rule.spot)
 |