2026-03-25 11:30:12 -06:00
|
|
|
#ifndef PARSER_H
|
|
|
|
|
#define PARSER_H
|
|
|
|
|
|
2026-03-13 07:58:38 -06:00
|
|
|
#include "lexer.h"
|
2026-04-13 06:40:31 -06:00
|
|
|
#include "arena.h"
|
2026-03-24 21:36:14 -06:00
|
|
|
#include <stdint.h>
|
2026-03-13 07:58:38 -06:00
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
ASTNode *head;
|
|
|
|
|
} AST;
|
|
|
|
|
|
2026-03-24 11:19:47 -06:00
|
|
|
typedef struct {
|
|
|
|
|
ASTNodeArray *arr;
|
|
|
|
|
size_t pos;
|
|
|
|
|
} ASTNodeSlice;
|
|
|
|
|
|
2026-04-13 07:57:36 -06:00
|
|
|
typedef struct {
|
2026-04-13 08:44:30 -06:00
|
|
|
Arena arena;
|
|
|
|
|
ASTNode *tree;
|
2026-04-13 07:57:36 -06:00
|
|
|
} ParseResult;
|
|
|
|
|
|
2026-03-24 21:36:14 -06:00
|
|
|
ASTNode ASTNodeSlice_peek(ASTNodeSlice *slice);
|
|
|
|
|
ASTNode ASTNodeSlice_next(ASTNodeSlice *slice);
|
2026-03-24 21:44:08 -06:00
|
|
|
bool ASTNodeSlice_is_valid(ASTNodeSlice *slice);
|
2026-03-24 21:04:36 -06:00
|
|
|
|
|
|
|
|
ASTNode *nud(ASTNodeSlice *slice);
|
|
|
|
|
ASTNode *led(ASTNodeSlice *slice, size_t right_precedence);
|
2026-03-13 07:58:38 -06:00
|
|
|
|
2026-03-24 21:36:14 -06:00
|
|
|
uint8_t node_lbp(ASTNode node);
|
|
|
|
|
uint8_t node_rbp(ASTNode node);
|
2026-03-25 06:59:52 -06:00
|
|
|
|
2026-04-13 07:57:36 -06:00
|
|
|
ParseResult parse(ASTNodeArray *arr);
|
|
|
|
|
ASTNode *parse_expr(ASTNodeSlice *slice, Arena *arena, uint8_t min_bp);
|
2026-03-25 06:59:52 -06:00
|
|
|
|
2026-03-25 11:30:12 -06:00
|
|
|
#endif // !PARSER_H
|