44 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			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, depth=0)
 | 
						|
    return required_regions
 | 
						|
 | 
						|
 | 
						|
@singledispatch
 | 
						|
def _find(rule: StardewRule, regions: Set[str], depth: int):
 | 
						|
    ...
 | 
						|
 | 
						|
 | 
						|
@_find.register
 | 
						|
def _(rule: AggregatingStardewRule, regions: Set[str], depth: int):
 | 
						|
    assert depth < 50, "Recursion depth exceeded"
 | 
						|
    for r in rule.original_rules:
 | 
						|
        _find(r, regions, depth + 1)
 | 
						|
 | 
						|
 | 
						|
@_find.register
 | 
						|
def _(rule: Count, regions: Set[str], depth: int):
 | 
						|
    assert depth < 50, "Recursion depth exceeded"
 | 
						|
    for r in rule.rules:
 | 
						|
        _find(r, regions, depth + 1)
 | 
						|
 | 
						|
 | 
						|
@_find.register
 | 
						|
def _(rule: Has, regions: Set[str], depth: int):
 | 
						|
    assert depth < 50, f"Recursion depth exceeded on {rule.item}"
 | 
						|
    r = rule.other_rules[rule.item]
 | 
						|
    _find(r, regions, depth + 1)
 | 
						|
 | 
						|
 | 
						|
@_find.register
 | 
						|
def _(rule: Reach, regions: Set[str], depth: int):
 | 
						|
    assert depth < 50, "Recursion depth exceeded"
 | 
						|
    if rule.resolution_hint == "Region":
 | 
						|
        regions.add(rule.spot)
 |