X-Git-Url: http://git.archive.openwrt.org/?p=project%2Fuci.git;a=blobdiff_plain;f=libuci.c;h=ada75c04cb2aef36e325d1b3aab86140f95dd4dc;hp=262ca698c5f68753ecd68a4e6a156e1e50e295ec;hb=508525c69e08a96031ed24f2d09e3bc2d1d33fca;hpb=f57d582f15c0ead3b600cb999ca298390957f597 diff --git a/libuci.c b/libuci.c index 262ca69..ada75c0 100644 --- a/libuci.c +++ b/libuci.c @@ -94,6 +94,18 @@ struct uci_context *uci_alloc(void) return ctx; } +void uci_free(struct uci_context *ctx) +{ + struct uci_config *cfg; + + uci_cleanup(ctx); + uci_foreach_entry(config, &ctx->root, cfg) { + uci_drop_config(cfg); + } + free(ctx); + return; +} + int uci_cleanup(struct uci_context *ctx) { UCI_HANDLE_ERR(ctx); @@ -116,7 +128,7 @@ void uci_perror(struct uci_context *ctx, const char *str) switch (err) { case UCI_ERR_PARSE: if (ctx->pctx) { - fprintf(stderr, "%s: %s at line %d, byte %d\n", str, uci_errstr[err], ctx->pctx->line, ctx->pctx->byte); + fprintf(stderr, "%s: %s (%s) at line %d, byte %d\n", str, uci_errstr[err], (ctx->pctx->reason ? ctx->pctx->reason : "unknown"), ctx->pctx->line, ctx->pctx->byte); break; } /* fall through */