X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=AST.dcl;h=1592143f5acc8d2fc7ae199f08ab4730c407bcd1;hb=f081c2c5e248331eb6e2f090f4afe818fd8259eb;hp=340aec64dae6a127bf4510f0982a303f5cff6e3f;hpb=fe40818bbc1d327f0adfbbbfe7ecfbe15d4eb053;p=cc1516.git diff --git a/AST.dcl b/AST.dcl index 340aec6..1592143 100644 --- a/AST.dcl +++ b/AST.dcl @@ -1,43 +1,55 @@ definition module AST from Data.Maybe import :: Maybe -from StdOverloaded import class toString +from StdOverloaded import class toString, class ==, class zero, class < :: Pos = {line :: Int, col :: Int} - -:: AST = AST [VarDecl] [FunDecl] -:: VarDecl = VarDecl Type String Expr +:: AST = AST [FunDecl] +:: VarDecl = VarDecl Pos (Maybe Type) String Expr +:: TVar :== String :: Type = TupleType (Type, Type) | ListType Type - | IdType String + | IdType TVar | IntType | BoolType | CharType - | VarType + | VoidType + | (->>) infixl 7 Type Type :: Expr - = VarExpr VarDef - | Op2Expr Expr Op2 Expr - | Op1Expr Op1 Expr - | IntExpr Int - | CharExpr Char - | BoolExpr Bool - | FunExpr FunCall - | EmptyListExpr - | TupleExpr (Expr, Expr) + = VarExpr Pos VarDef + | Op2Expr Pos Expr Op2 Expr + | Op1Expr Pos Op1 Expr + | IntExpr Pos Int + | CharExpr Pos Char + | BoolExpr Pos Bool + | FunExpr Pos String [Expr] [FieldSelector] + | EmptyListExpr Pos + | TupleExpr Pos (Expr, Expr) :: VarDef = VarDef String [FieldSelector] :: FieldSelector = FieldHd | FieldTl | FieldFst | FieldSnd :: Op1 = UnNegation | UnMinus :: Op2 = BiPlus | BiMinus | BiTimes | BiDivide | BiMod | BiEquals | BiLesser | BiGreater | BiLesserEq | BiGreaterEq | BiUnEqual | BiAnd | BiOr | BiCons -:: FunDecl = FunDecl String [String] (Maybe FunType) [VarDecl] [Stmt] -:: FunType = FunType [Type] (Maybe Type) -:: FunCall = FunCall String [Expr] +:: FunDecl = FunDecl Pos String [String] (Maybe Type) [VarDecl] [Stmt] :: Stmt = IfStmt Expr [Stmt] [Stmt] | WhileStmt Expr [Stmt] | AssStmt VarDef Expr - | FunStmt FunCall + | FunStmt String [Expr] | ReturnStmt (Maybe Expr) +instance toString Pos +instance toString Type instance toString AST +instance toString FieldSelector +instance toString Op2 +instance toString Expr +instance toString VarDecl + +instance zero Pos +instance == Op1 +instance == Op2 +instance < Op1 +instance < Op2 +instance == Type