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-04-24 09:06:47 -06:00
|
|
|
#include "arraylist.h"
|
2026-05-13 10:02:55 -06:00
|
|
|
#include <stdbool.h>
|
2026-03-24 21:36:14 -06:00
|
|
|
#include <stdint.h>
|
2026-03-13 07:58:38 -06:00
|
|
|
|
2026-05-13 10:02:55 -06:00
|
|
|
typedef enum {
|
|
|
|
|
NODE_INT,
|
|
|
|
|
NODE_BINARY_OP,
|
|
|
|
|
NODE_UNARY_OP,
|
2026-05-13 11:09:22 -06:00
|
|
|
NODE_PARENTHESIS,
|
2026-05-13 10:02:55 -06:00
|
|
|
} NodeType;
|
|
|
|
|
|
2026-05-13 11:09:22 -06:00
|
|
|
typedef struct Node {
|
2026-05-13 10:02:55 -06:00
|
|
|
NodeType type;
|
|
|
|
|
union {
|
|
|
|
|
int64_t num;
|
|
|
|
|
struct {
|
|
|
|
|
Operator op;
|
|
|
|
|
struct Node *left;
|
|
|
|
|
struct Node *right;
|
|
|
|
|
}binary;
|
|
|
|
|
struct {
|
|
|
|
|
Operator op;
|
|
|
|
|
struct Node *to;
|
|
|
|
|
}unary;
|
2026-05-13 11:09:22 -06:00
|
|
|
Operator par;
|
2026-05-13 10:02:55 -06:00
|
|
|
};
|
|
|
|
|
} Node;
|
2026-03-13 07:58:38 -06:00
|
|
|
|
2026-04-24 09:06:47 -06:00
|
|
|
typedef enum {
|
|
|
|
|
PARSER_OK = 0,
|
|
|
|
|
PARSER_UNEXPECTED_TOKEN,
|
|
|
|
|
PARSER_MISSING_OPERAND,
|
|
|
|
|
PARSER_UNMATCHED_PAREN,
|
|
|
|
|
PARSER_OUT_OF_MEMORY,
|
2026-05-13 12:13:07 -06:00
|
|
|
PARSER_INVALID_TOKENIZE,
|
2026-04-24 09:06:47 -06:00
|
|
|
} ParserErr;
|
2026-03-24 11:19:47 -06:00
|
|
|
|
2026-04-13 07:57:36 -06:00
|
|
|
typedef struct {
|
2026-04-24 09:06:47 -06:00
|
|
|
bool is_valid;
|
|
|
|
|
union {
|
|
|
|
|
ParserErr err;
|
|
|
|
|
struct {
|
|
|
|
|
Arena arena;
|
2026-05-13 10:02:55 -06:00
|
|
|
Node *tree;
|
2026-04-24 09:06:47 -06:00
|
|
|
};
|
|
|
|
|
};
|
2026-05-13 10:02:55 -06:00
|
|
|
} ParserResult;
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
bool is_valid;
|
|
|
|
|
union {
|
|
|
|
|
ParserErr err;
|
|
|
|
|
Node *node;
|
|
|
|
|
};
|
2026-05-13 12:19:17 -06:00
|
|
|
} TreeResult;
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
|
bool is_valid;
|
|
|
|
|
union {
|
|
|
|
|
ParserErr err;
|
|
|
|
|
Node node;
|
|
|
|
|
};
|
2026-05-13 10:02:55 -06:00
|
|
|
} NodeResult;
|
2026-04-13 07:57:36 -06:00
|
|
|
|
2026-05-13 10:02:55 -06:00
|
|
|
typedef struct {
|
|
|
|
|
bool is_valid;
|
|
|
|
|
union {
|
|
|
|
|
ParserErr err;
|
|
|
|
|
uint8_t num;
|
|
|
|
|
};
|
|
|
|
|
} ParserU8Result;
|
2026-03-13 07:58:38 -06:00
|
|
|
|
2026-05-13 11:09:22 -06:00
|
|
|
Node token_to_node(Token token);
|
|
|
|
|
|
2026-05-13 10:02:55 -06:00
|
|
|
ParserU8Result prefix_rbp(Node node);
|
|
|
|
|
ParserU8Result postfix_lbp(Node node);
|
|
|
|
|
ParserU8Result infix_lbp(Node node);
|
|
|
|
|
ParserU8Result infix_rbp(Node node);
|
2026-03-25 06:59:52 -06:00
|
|
|
|
2026-05-13 10:02:55 -06:00
|
|
|
ParserResult parse(TokenizeResult tokens);
|
2026-05-13 12:19:17 -06:00
|
|
|
TreeResult parse_expr(ArraySlice *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
|