#include <stdio.h>
#include <stdlib.h>
+#include <stdint.h>
#include <string.h>
#include <assert.h>
#include <errno.h>
#include <ecoli_log.h>
#include <ecoli_node.h>
+EC_LOG_TYPE_REGISTER(node);
+
static struct ec_node_type_list node_type_list =
TAILQ_HEAD_INITIALIZER(node_type_list);
struct ec_node *node = NULL;
char buf[256]; // XXX
- ec_log(EC_LOG_DEBUG, "create node type=%s id=%s\n", type->name, id);
+ EC_LOG(EC_LOG_DEBUG, "create node type=%s id=%s\n",
+ type->name, id);
node = ec_calloc(1, type->size);
if (node == NULL)
type = ec_node_type_lookup(typename);
if (type == NULL) {
- ec_log(EC_LOG_ERR, "type=%s does not exist\n", typename);
+ EC_LOG(EC_LOG_ERR, "type=%s does not exist\n",
+ typename);
return NULL;
}
ec_free(node);
}
+size_t ec_node_get_max_parse_len(const struct ec_node *node)
+{
+ if (node->type->get_max_parse_len == NULL)
+ return SIZE_MAX;
+ return node->type->get_max_parse_len(node);
+}
+
struct ec_node *ec_node_clone(struct ec_node *node)
{
if (node != NULL)
const char *ec_node_id(const struct ec_node *node)
{
+ if (node->id == NULL)
+ return "None";
return node->id;
}
static void __ec_node_dump(FILE *out,
const struct ec_node *node, size_t indent)
{
+ const char *id, *typename, *desc;
struct ec_node *child;
+ size_t maxlen;
size_t i;
- const char *id = "None", *typename = "None";
- if (node->id != NULL)
- id = node->id;
+ maxlen = ec_node_get_max_parse_len(node);
+ id = ec_node_id(node);
typename = node->type->name;
+ desc = ec_node_desc(node);
/* XXX enhance */
for (i = 0; i < indent; i++) {
fprintf(out, "|");
}
- fprintf(out, "node_type=%s id=%s\n", typename, id);
+ fprintf(out, "node %p type=%s id=%s desc=%s ",
+ node, typename, id, desc);
+ if (maxlen == SIZE_MAX)
+ fprintf(out, "maxlen=no\n");
+ else
+ fprintf(out, "maxlen=%zu\n", maxlen);
TAILQ_FOREACH(child, &node->children, next)
__ec_node_dump(out, child, indent + 2);
}