2024-12-03 21:57:44 +00:00
|
|
|
#include "ctx.h"
|
2024-12-06 09:53:09 +00:00
|
|
|
#include "iterate.h"
|
2024-12-03 21:57:44 +00:00
|
|
|
#include "node.h"
|
|
|
|
|
|
|
|
|
|
static void collect_children(
|
|
|
|
|
struct ivy_ast_node *node, struct ivy_ast_node_iterator *iterator)
|
|
|
|
|
{
|
|
|
|
|
struct ivy_ast_cascade_node *cascade = (struct ivy_ast_cascade_node *)node;
|
|
|
|
|
|
|
|
|
|
if (cascade->n_recipient) {
|
|
|
|
|
ast_node_iterator_enqueue_node(iterator, node, cascade->n_recipient);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
b_queue_iterator it = {0};
|
|
|
|
|
b_queue_foreach (&it, &cascade->n_msg) {
|
|
|
|
|
struct ivy_ast_node *arg
|
|
|
|
|
= b_unbox(struct ivy_ast_node, it.entry, n_entry);
|
|
|
|
|
ast_node_iterator_enqueue_node(iterator, node, arg);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
struct ast_node_type cascade_node_ops = {
|
|
|
|
|
.n_collect_children = collect_children,
|
|
|
|
|
.n_state_size = sizeof(struct parser_state),
|
|
|
|
|
.n_node_size = sizeof(struct ivy_ast_cascade_node),
|
|
|
|
|
};
|