From df4604f27bbd8ed42ea2c7026c7e4845aafd1a8b Mon Sep 17 00:00:00 2001 From: A404M Date: Tue, 18 Feb 2025 23:42:10 +0330 Subject: add while fix some memory leaks --- src/compiler/parser.h | 7 +++++++ 1 file changed, 7 insertions(+) (limited to 'src/compiler/parser.h') diff --git a/src/compiler/parser.h b/src/compiler/parser.h index 3af47e7..6fe6d6f 100644 --- a/src/compiler/parser.h +++ b/src/compiler/parser.h @@ -34,6 +34,7 @@ typedef enum ParserToken { PARSER_TOKEN_KEYWORD_PRINT_U64, PARSER_TOKEN_KEYWORD_RETURN, PARSER_TOKEN_KEYWORD_IF, + PARSER_TOKEN_KEYWORD_WHILE, PARSER_TOKEN_CONSTANT, PARSER_TOKEN_VARIABLE, @@ -131,6 +132,11 @@ typedef struct ParserNodeIfMetadata { ParserNode *elseBody; } ParserNodeIfMetadata; +typedef struct ParserNodeWhileMetadata { + ParserNode *condition; + ParserNode *body; +} ParserNodeWhileMetadata; + void parserNodePrint(const ParserNode *node, int indent); void parserNodeDelete(ParserNode *node); @@ -175,6 +181,7 @@ ParserNode *parserBinaryOrLeftOperator(LexerNode *node, LexerNode *begin, ParserToken token, LexerToken laterToken); ParserNode *parserIf(LexerNode *node, LexerNode *end, ParserNode *parent); +ParserNode *parserWhile(LexerNode *node, LexerNode *end, ParserNode *parent); bool isAllArguments(const ParserNodeArray *nodes); -- cgit v1.2.3