Files
ivy/lang/ast/msgh.c

76 lines
1.7 KiB
C

#include "ctx.h"
#include "ivy/status.h"
#include "node.h"
#include <blue/object/string.h>
#include <ivy/lang/lex.h>
struct msgh_parser_state {
struct parser_state s_base;
bool s_oneline;
enum {
AREA_SELECTOR,
AREA_BODY,
} s_current_area;
unsigned int s_i;
unsigned int s_prev;
};
static enum ivy_status parse_ident(struct ivy_parser *ctx, struct ivy_token *tok)
{
struct msgh_parser_state *state
= parser_get_state(ctx, struct msgh_parser_state);
struct ivy_ast_msgh_node *msgh
= (struct ivy_ast_msgh_node *)state->s_base.s_node;
if (state->s_current_area == AREA_BODY) {
/* TODO expression parsing */
return IVY_ERR_NOT_SUPPORTED;
}
if (state->s_prev == IVY_SYM_HYPHEN) {
/* message name */
return IVY_OK;
}
return IVY_OK;
}
static enum ivy_status add_child(
struct ivy_ast_node *parent, struct ivy_ast_node *child)
{
struct ivy_ast_msgh_node *msgh = (struct ivy_ast_msgh_node *)parent;
if (child->n_type == IVY_AST_SELECTOR && !msgh->n_sel) {
msgh->n_sel = (struct ivy_ast_selector_node *)child;
return IVY_OK;
}
b_queue_push_back(&msgh->n_body, &child->n_entry);
return IVY_OK;
}
static void init_state(struct ivy_parser *ctx, struct parser_state *sp)
{
struct msgh_parser_state *state = (struct msgh_parser_state *)sp;
state->s_oneline = false;
state->s_i = 0;
state->s_current_area = AREA_SELECTOR;
state->s_prev = IVY_SYM_HYPHEN;
parser_push_state(ctx, IVY_AST_SELECTOR);
}
struct ast_node_type msgh_node_ops = {
.n_add_child = add_child,
.n_init_state = init_state,
.n_state_size = sizeof(struct msgh_parser_state),
.n_node_size = sizeof(struct ivy_ast_msgh_node),
.n_token_parsers = {
[IVY_TOK_IDENT] = parse_ident,
},
};