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
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