X-Git-Url: https://git.martlubbers.net/?a=blobdiff_plain;f=src%2Fparse.dcl;h=baef54567d9bd2e19a8643509fe0664925ac8f4b;hb=051a7614b88beaea2912dd9f76d04d9a90ec2f99;hp=3f42eda5effdfebccc321bdfb277253888c3a852;hpb=b4636110ab65f233ed40d4390b62c7799df3c949;p=cc1516.git diff --git a/src/parse.dcl b/src/parse.dcl index 3f42eda..baef545 100644 --- a/src/parse.dcl +++ b/src/parse.dcl @@ -17,24 +17,31 @@ import lex | BoolType | CharType | VarType - :: Expr - = VarExpr String (Maybe FieldSelector) - | Op2Expr Expr Op2 Expr //TODO, iets met associativiteit wat niet weet hoe + = VarExpr VarDef + | Op2Expr Expr Op2 Expr | Op1Expr Op1 Expr | IntExpr Int | CharExpr Char | BoolExpr Bool + | FunExpr FunCall | EmptyListExpr | TupleExpr 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 - -//TODO - -:: FunDecl = Stub - -parse :: LexerOutput -> ParserOutput +:: FunDecl = FunDecl String [String] FunType [VarDecl] [Stmt] +:: FunType = FunType [Type] (Maybe Type) +:: FunCall = FunCall String [Expr] +:: Stmt + = IfStmt Expr [Stmt] [Stmt] + | WhileStmt Expr [Stmt] + | AssStmt VarDef Expr + | FunStmt FunCall + | ReturnStmt (Maybe Expr) + +instance toString AST + +parser :: LexerOutput -> ParserOutput