blob: a764a0872ccfc6fa4df2cce86f808785d1ab0b91 (
plain)
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
70
71
72
|
package bjc.utils.gen;
import bjc.utils.funcdata.FunctionalMap;
import bjc.utils.funcdata.IList;
/**
* A weighted grammar where all the rules have a equal chance of occuring.
*
* @author ben
*
* @param <E>
* The type of grammar elements to use.
*/
public class RandomGrammar<E> extends WeightedGrammar<E> {
/**
* Create a new random grammar.
*/
public RandomGrammar() {
rules = new FunctionalMap<>();
}
/**
* Add cases to a specified rule.
*
* @param rule
* The name of the rule to add cases to.
* @param cases
* The cases to add for this rule.
*/
@SafeVarargs
public final void addCases(E rule, IList<E>... cases) {
for (IList<E> currentCase : cases) {
super.addCase(rule, 1, currentCase);
}
}
/**
* Create a rule with the specified name and cases.
*
* @param rule
* The name of the rule to add.
* @param cases
* The cases to add for this rule.
*/
@SafeVarargs
public final void makeRule(E rule, IList<E>... cases) {
super.addRule(rule);
for (IList<E> currentCase : cases) {
super.addCase(rule, 1, currentCase);
}
}
/**
* Create a rule with the specified name and cases.
*
* @param rule
* The name of the rule to add.
* @param cases
* The cases to add for this rule.
*/
public void makeRule(E rule,
IList<IList<E>> cases) {
if (cases == null) {
throw new NullPointerException("Cases must not be null");
}
super.addRule(rule);
cases.forEach(currentCase -> super.addCase(rule, 1, currentCase));
}
}
|