17 | 17 |
Sequence.
|
18 | 18 |
|
19 | 19 |
Goal ::= "f" "o" "o";
|
20 | |
===> Grammar [("Goal",Alt [Seq [Terminal 'f',Terminal 'o',Terminal 'o']])]
|
|
20 |
===> Grammar [("Goal",[],Alt [Seq [Terminal 'f',Terminal 'o',Terminal 'o']])]
|
21 | 21 |
|
22 | 22 |
Multi-character terminal.
|
23 | 23 |
|
24 | 24 |
Goal ::= "foo";
|
25 | |
===> Grammar [("Goal",Alt [Seq [Seq [Terminal 'f',Terminal 'o',Terminal 'o']]])]
|
|
25 |
===> Grammar [("Goal",[],Alt [Seq [Seq [Terminal 'f',Terminal 'o',Terminal 'o']]])]
|
26 | 26 |
|
27 | 27 |
Alternation and recursion.
|
28 | 28 |
|
29 | 29 |
Goal ::= "(" Goal ")" | "0";
|
30 | |
===> Grammar [("Goal",Alt [Seq [Terminal '(',NonTerminal "Goal",Terminal ')'],Seq [Terminal '0']])]
|
|
30 |
===> Grammar [("Goal",[],Alt [Seq [Terminal '(',NonTerminal "Goal",Terminal ')'],Seq [Terminal '0']])]
|
31 | 31 |
|
32 | 32 |
Repetition.
|
33 | 33 |
|
34 | 34 |
Goal ::= "(" {"0"} ")";
|
35 | |
===> Grammar [("Goal",Alt [Seq [Terminal '(',Loop (Alt [Seq [Terminal '0']]) [],Terminal ')']])]
|
|
35 |
===> Grammar [("Goal",[],Alt [Seq [Terminal '(',Loop (Alt [Seq [Terminal '0']]) [],Terminal ')']])]
|
36 | 36 |
|
37 | 37 |
Constraints.
|
38 | 38 |
|
|
41 | 41 |
<. b = 0 .> { "b" <. b += 1 .> } <. b = n .>
|
42 | 42 |
<. c = 0 .> { "c" <. c += 1 .> } <. c = n .>
|
43 | 43 |
;
|
44 | |
===> Grammar [("Goal",Alt [Seq [Constraint (Arb (Var "n")),Constraint (UnifyConst (Var "a") 0),Loop (Alt [Seq [Terminal 'a',Constraint (Inc (Var "a") 1)]]) [],Constraint (UnifyVar (Var "a") (Var "n")),Constraint (UnifyConst (Var "b") 0),Loop (Alt [Seq [Terminal 'b',Constraint (Inc (Var "b") 1)]]) [],Constraint (UnifyVar (Var "b") (Var "n")),Constraint (UnifyConst (Var "c") 0),Loop (Alt [Seq [Terminal 'c',Constraint (Inc (Var "c") 1)]]) [],Constraint (UnifyVar (Var "c") (Var "n"))]])]
|
|
44 |
===> Grammar [("Goal",[],Alt [Seq [Constraint (Arb (Var "n")),Constraint (UnifyConst (Var "a") 0),Loop (Alt [Seq [Terminal 'a',Constraint (Inc (Var "a") 1)]]) [],Constraint (UnifyVar (Var "a") (Var "n")),Constraint (UnifyConst (Var "b") 0),Loop (Alt [Seq [Terminal 'b',Constraint (Inc (Var "b") 1)]]) [],Constraint (UnifyVar (Var "b") (Var "n")),Constraint (UnifyConst (Var "c") 0),Loop (Alt [Seq [Terminal 'c',Constraint (Inc (Var "c") 1)]]) [],Constraint (UnifyVar (Var "c") (Var "n"))]])]
|
45 | 45 |
|
46 | 46 |
### Preprocessing
|
47 | 47 |
|
|
50 | 50 |
Sequence.
|
51 | 51 |
|
52 | 52 |
Goal ::= "f" "o" "o";
|
53 | |
===> Grammar [("Goal",Alt [Seq [Terminal 'f',Terminal 'o',Terminal 'o']])]
|
|
53 |
===> Grammar [("Goal",[],Alt [Seq [Terminal 'f',Terminal 'o',Terminal 'o']])]
|
54 | 54 |
|
55 | 55 |
Alternation and recursion.
|
56 | 56 |
|
57 | 57 |
Goal ::= "(" Goal ")" | "0";
|
58 | |
===> Grammar [("Goal",Alt [Seq [Terminal '(',NonTerminal "Goal",Terminal ')'],Seq [Terminal '0']])]
|
|
58 |
===> Grammar [("Goal",[],Alt [Seq [Terminal '(',NonTerminal "Goal",Terminal ')'],Seq [Terminal '0']])]
|
59 | 59 |
|
60 | 60 |
Repetition.
|
61 | 61 |
|
62 | 62 |
Goal ::= "(" {"0"} ")";
|
63 | |
===> Grammar [("Goal",Alt [Seq [Terminal '(',Loop (Alt [Seq [Terminal '0']]) [],Terminal ')']])]
|
|
63 |
===> Grammar [("Goal",[],Alt [Seq [Terminal '(',Loop (Alt [Seq [Terminal '0']]) [],Terminal ')']])]
|
64 | 64 |
|
65 | 65 |
Goal ::= <. arb n .>
|
66 | 66 |
<. a = 0 .> { "a" <. a += 1 .> } <. a = n .>
|
67 | 67 |
<. b = 0 .> { "b" <. b += 1 .> } <. b = n .>
|
68 | 68 |
<. c = 0 .> { "c" <. c += 1 .> } <. c = n .>
|
69 | 69 |
;
|
70 | |
===> Grammar [("Goal",Alt [Seq [Constraint (Arb (Var "n")),Constraint (UnifyConst (Var "a") 0),Loop (Alt [Seq [Terminal 'a',Constraint (Inc (Var "a") 1)]]) [UnifyVar (Var "a") (Var "n"),UnifyConst (Var "b") 0],Loop (Alt [Seq [Terminal 'b',Constraint (Inc (Var "b") 1)]]) [UnifyVar (Var "b") (Var "n"),UnifyConst (Var "c") 0],Loop (Alt [Seq [Terminal 'c',Constraint (Inc (Var "c") 1)]]) [UnifyVar (Var "c") (Var "n")]]])]
|
|
70 |
===> Grammar [("Goal",[],Alt [Seq [Constraint (Arb (Var "n")),Constraint (UnifyConst (Var "a") 0),Loop (Alt [Seq [Terminal 'a',Constraint (Inc (Var "a") 1)]]) [UnifyVar (Var "a") (Var "n"),UnifyConst (Var "b") 0],Loop (Alt [Seq [Terminal 'b',Constraint (Inc (Var "b") 1)]]) [UnifyVar (Var "b") (Var "n"),UnifyConst (Var "c") 0],Loop (Alt [Seq [Terminal 'c',Constraint (Inc (Var "c") 1)]]) [UnifyVar (Var "c") (Var "n")]]])]
|