-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathParser.java
More file actions
45 lines (41 loc) · 1.8 KB
/
Parser.java
File metadata and controls
45 lines (41 loc) · 1.8 KB
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
import java.util.List;
import java.util.ArrayList;
import java.util.Arrays;
public final class Parser {
private static final List<Reduction> reductionsList = new ArrayList<Reduction>() {{
//VARIABLE to TERM
add(Reduction.build(Arrays.asList(Type.VARIABLE), (list) -> Term.build(list.get(0))));
//OPEN,EXPRESSION,CLOSE to TERM
add(Reduction.build(Arrays.asList(Type.OPEN,Type.EXPRESSION,Type.CLOSE), (list) -> Term.build(list.get(1))));
//NOT,TERM to EXPRESSION
add(Reduction.build(Arrays.asList(Type.NOT,Type.TERM), (list) -> Expression.build(false,list.get(1))));
//TERM to EXPRESSION
add(Reduction.build(Arrays.asList(Type.TERM), (list) -> Expression.build(true,list.get(0))));
//EXPRESSION,AND,EXPRESSION to EXPRESSION
add(Reduction.build(Arrays.asList(Type.EXPRESSION,Type.AND,Type.EXPRESSION),
(list) -> Expression.build(true,list.get(0),list.get(2))));
//EXPRESSION,OR,EXPRESSION to EXPRESSION
add(Reduction.build(Arrays.asList(Type.EXPRESSION,Type.OR,Type.EXPRESSION),
(list) -> Expression.build(false,list.get(0),list.get(2))));
}};
public static final State parse(BooleanList input){
WorkingList workingList = new WorkingList();
for(ListSymbol symbol:input){
workingList.add(symbol);
reduce(workingList);
}
return State.build(workingList.getList());
}
private static final WorkingList reduce(WorkingList workingList){
for(Reduction reduction: reductionsList){
if(workingList.canApplyReduction(reduction)){
//recurses on reduced WorkingList
return reduce(workingList.applyReduction(reduction));
} else{
//the reduction doesn't match, so do nothing
}
}
//if this line is reached, then no more reductions can be applied, so we return the reduced list
return workingList;
}
}