X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=AST.icl;h=774e158ef5f9d774ad0dd355ce520243d009e6e7;hb=74b900cf6db033a51e177f7f85d835dae44217e5;hp=305e8f375050ce9d1cf87227f6161d6cc320dac1;hpb=f37f138cce001a8feedc2660bdbbe648c600a643;p=cc1516.git diff --git a/AST.icl b/AST.icl index 305e8f3..774e158 100644 --- a/AST.icl +++ b/AST.icl @@ -65,6 +65,7 @@ instance print Type where print BoolType = print "Bool" print CharType = print "Char" print VoidType = print "Void" + print (FuncType t) = ["(-> ":print t] ++ [")"] print (t1 ->> t2) = ["(":print t1 ++ [" -> ":print t2]] ++ [")"] instance print String where @@ -109,11 +110,12 @@ instance print Expr where print (FunExpr _ id as fs) = printFunCall id as fs print (EmptyListExpr _) = ["[]"] print (TupleExpr _ (e1, e2)) = ["(":print e1] ++ [",":print e2] ++ [")"] + print (LambdaExpr _ args e) = ["\\":args] ++ ["->": print e] instance toString Expr where toString e = concat $ print e printSelectors :: [FieldSelector] -> [String] -printSelectors x = case x of [] = [""]; _ = [".":printersperse "." x] +printSelectors fs = printersperse "." fs printFunCall :: String [Expr] [FieldSelector] -> [String] printFunCall s args fs = [s, "(":printersperse "," args] ++ [")"] ++