refactor: made parser work with arrayslices and new result types
This commit is contained in:
@@ -20,15 +20,6 @@ typedef enum {
|
||||
OP_DIV
|
||||
} Operator;
|
||||
|
||||
typedef enum {
|
||||
ARRAY_OK = 0,
|
||||
ARRAY_NULL,
|
||||
ARRAY_EMPTY,
|
||||
ARRAY_OUT_OF_BOUNDS,
|
||||
ARRAY_NULL_ARG,
|
||||
ARRAY_ALLOC,
|
||||
} ASTNodeArrayErr;
|
||||
|
||||
typedef enum {
|
||||
LEXER_OK = 0,
|
||||
LEXER_INT_OVERFLOW,
|
||||
@@ -76,20 +67,6 @@ typedef struct {
|
||||
int64_t number;
|
||||
};
|
||||
} I64Result;
|
||||
// I prefer ot have a dynamic array for storing the "tokens"
|
||||
typedef struct {
|
||||
size_t len;
|
||||
size_t cap;
|
||||
ASTNode *data;
|
||||
} ASTNodeArray;
|
||||
|
||||
ASTNodeArray ASTNodeArray_init(size_t size);
|
||||
void ASTNodeArray_free(ASTNodeArray *arr);
|
||||
ASTNodeArrayErr ASTNodeArray_push(ASTNodeArray *arr, ASTNode node);
|
||||
ASTNodeArrayErr ASTNodeArray_get(const ASTNodeArray *arr, size_t index, ASTNode *out);
|
||||
// Out in pop can be NULL so it doesn't return anything
|
||||
ASTNodeArrayErr ASTNodeArray_pop(ASTNodeArray *arr, size_t index, ASTNode *out);
|
||||
size_t ASTNodeArray_len(ASTNodeArray *arr);
|
||||
|
||||
// Lexer funtions as well as few functionality
|
||||
TokenizeResult tokenize(const char* input);
|
||||
|
||||
@@ -3,33 +3,39 @@
|
||||
|
||||
#include "lexer.h"
|
||||
#include "arena.h"
|
||||
#include "arraylist.h"
|
||||
#include <stdint.h>
|
||||
|
||||
typedef struct {
|
||||
ASTNode *head;
|
||||
} AST;
|
||||
|
||||
typedef struct {
|
||||
ASTNodeArray *arr;
|
||||
size_t pos;
|
||||
} ASTNodeSlice;
|
||||
typedef enum {
|
||||
PARSER_OK = 0,
|
||||
PARSER_UNEXPECTED_TOKEN,
|
||||
PARSER_MISSING_OPERAND,
|
||||
PARSER_UNMATCHED_PAREN,
|
||||
PARSER_OUT_OF_MEMORY,
|
||||
} ParserErr;
|
||||
|
||||
typedef struct {
|
||||
Arena arena;
|
||||
ASTNode *tree;
|
||||
bool is_valid;
|
||||
union {
|
||||
ParserErr err;
|
||||
struct {
|
||||
Arena arena;
|
||||
ASTNode *tree;
|
||||
};
|
||||
};
|
||||
} ParseResult;
|
||||
|
||||
ASTNode ASTNodeSlice_peek(ASTNodeSlice *slice);
|
||||
ASTNode ASTNodeSlice_next(ASTNodeSlice *slice);
|
||||
bool ASTNodeSlice_is_valid(ASTNodeSlice *slice);
|
||||
|
||||
ASTNode *nud(ASTNodeSlice *slice);
|
||||
ASTNode *led(ASTNodeSlice *slice, size_t right_precedence);
|
||||
ASTNode *nud(ArraySlice *slice);
|
||||
ASTNode *led(ArraySlice *slice, size_t right_precedence);
|
||||
|
||||
uint8_t node_lbp(ASTNode node);
|
||||
uint8_t node_rbp(ASTNode node);
|
||||
|
||||
ParseResult parse(ASTNodeArray *arr);
|
||||
ASTNode *parse_expr(ASTNodeSlice *slice, Arena *arena, uint8_t min_bp);
|
||||
ParseResult parse(TokenizeResult tokens);
|
||||
ASTNode *parse_expr(ArraySlice *slice, Arena *arena, uint8_t min_bp);
|
||||
|
||||
#endif // !PARSER_H
|
||||
|
||||
Reference in New Issue
Block a user