if (i->parser->method != CONF_METHOD_LOCAL_FILE)
continue;
- pb_log("\ttrying parser '%s'\n", i->parser->name);
+ pb_debug("\ttrying parser '%s'\n", i->parser->name);
ctx->parser = i->parser;
iterate_parser_files(ctx, ctx->parser);
}
if (i->parser->method != method)
continue;
- pb_log("\ttrying parser '%s'\n", i->parser->name);
+ pb_debug("\ttrying parser '%s'\n", i->parser->name);
ctx->parser = i->parser;
i->parser->parse(ctx, buf, len);
}
}
}
+static void *parsers_ctx;
+
void __register_parser(struct parser *parser)
{
- struct p_item* i = talloc(NULL, struct p_item);
+ struct p_item *i;
+
+ if (!parsers_ctx)
+ parsers_ctx = talloc_new(NULL);
+ i = talloc(parsers_ctx, struct p_item);
i->parser = parser;
list_add(&parsers, &i->list);
}
+static __attribute__((destructor)) void cleanup_parsers(void)
+{
+ talloc_free(parsers_ctx);
+}
+
void parser_init(void)
{
}