P15GEN2\59518
2024-05-29 d4210c7c4b04abde20037ea8aa0f54ef8a2649aa
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package foundation.route;
 
import java.util.HashMap;
import java.util.Map;
 
public class FilterNode<T> {
 
    private Map<String, FilterNode<T>> nodes;
    private String path;
    private T item;
    private boolean matchAll;
    
    
    public FilterNode(String path, T item) {
        nodes = new HashMap<String, FilterNode<T>>();
        this.path = path;
    }
    
    public T match(String[] segments, int idx) {
        if (matchAll) {
            return item;
        }
        
        if (idx == -1) {
            return item;
        }
        
        String segment = segments[idx];
        FilterNode<T> node = nodes.get(segment);
        
        if (node == null) {
            return null;
        }
        
        return node.match(segments, idx - 1);
    }
    
    public void add(String[] segments, int idx, T item) {
        if (idx == -1) {
            return;
        }
        
        String segment = segments[idx];
        
        if ("*".equals(segment)) {
            matchAll = true;
            return;
        }
        
        FilterNode<T> node = nodes.get(segment);
        
        if (node == null) {
            node = new FilterNode<T>(segment, item);
            nodes.put(segment, node);
        }
        
        node.add(segments, idx - 1, item);
    }
 
    public T getItem() {
        return item;
    }
 
    @Override
    public String toString() {
        return path;
    }
    
}