diff options
| author | aarne <aarne@cs.chalmers.se> | 2007-09-04 14:15:43 +0000 |
|---|---|---|
| committer | aarne <aarne@cs.chalmers.se> | 2007-09-04 14:15:43 +0000 |
| commit | 713fb9122ccfdc41082835138cc6ec3e433807f4 (patch) | |
| tree | aef8fdb0cb190378e9fd97d09fb9e90bdf537f28 /examples/tutorial/calculator | |
| parent | e9985271e2d03e789e77b212526810aa2055ebe0 (diff) | |
CP
Diffstat (limited to 'examples/tutorial/calculator')
| -rw-r--r-- | examples/tutorial/calculator/CalculatorP.gf | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/examples/tutorial/calculator/CalculatorP.gf b/examples/tutorial/calculator/CalculatorP.gf new file mode 100644 index 000000000..57ac549c1 --- /dev/null +++ b/examples/tutorial/calculator/CalculatorP.gf @@ -0,0 +1,27 @@ +--# -path=.:prelude + +concrete CalculatorP of Calculator = open Prelude in { + + flags lexer=codevars ; unlexer=code ; + + lincat + Prog, Var = SS ; + Exp = SS ; + + lin + PEmpty = ss [] ; + PDecl exp prog = ss ("int" ++ prog.$0 ++ "=" ++ exp.s ++ ";" ++ prog.s) ; + PAss vr exp prog = ss (vr.s ++ "=" ++ exp.s ++ ";" ++ prog.s) ; + + EPlus = infix "+" ; + EMinus = infix "-" ; + ETimes = infix "*" ; + EDiv = infix "/" ; + + EInt i = i ; + EVar x = x ; + + oper + infix : Str -> SS -> SS -> SS = \f,x,y -> + ss ("(" ++ x.s ++ f ++ y.s ++ ")") ; +} |
