X-Git-Url: https://git.archive.openwrt.org/?p=project%2Fuci.git;a=blobdiff_plain;f=libuci.c;h=0dd81fe3ba0f19bd2c28757ddb9aa2a95e398668;hp=400acd8967de5ada548b46fd2d6776f79bd3a665;hb=92f4eac56f3cf1bf21c352193e3bf40723a6e87f;hpb=171170de64e0faff8d0e93581d9971439f474cbd diff --git a/libuci.c b/libuci.c index 400acd8..0dd81fe 100644 --- a/libuci.c +++ b/libuci.c @@ -25,13 +25,14 @@ #include "err.h" static const char *uci_errstr[] = { - [UCI_OK] = "Success", - [UCI_ERR_MEM] = "Out of memory", - [UCI_ERR_INVAL] = "Invalid argument", - [UCI_ERR_NOTFOUND] = "Entry not found", - [UCI_ERR_IO] = "I/O error", - [UCI_ERR_PARSE] = "Parse error", - [UCI_ERR_UNKNOWN] = "Unknown error", + [UCI_OK] = "Success", + [UCI_ERR_MEM] = "Out of memory", + [UCI_ERR_INVAL] = "Invalid argument", + [UCI_ERR_NOTFOUND] = "Entry not found", + [UCI_ERR_IO] = "I/O error", + [UCI_ERR_PARSE] = "Parse error", + [UCI_ERR_DUPLICATE] = "Duplicate entry", + [UCI_ERR_UNKNOWN] = "Unknown error", }; #include "util.c" @@ -46,6 +47,7 @@ struct uci_context *uci_alloc_context(void) ctx = (struct uci_context *) malloc(sizeof(struct uci_context)); memset(ctx, 0, sizeof(struct uci_context)); uci_list_init(&ctx->root); + ctx->flags = UCI_FLAG_STRICT; return ctx; } @@ -73,7 +75,7 @@ int uci_cleanup(struct uci_context *ctx) return 0; } -void uci_perror(struct uci_context *ctx, const char *str) +void uci_perror(struct uci_context *ctx, const char *prefix) { int err; @@ -85,15 +87,20 @@ void uci_perror(struct uci_context *ctx, const char *str) if ((err < 0) || (err >= UCI_ERR_LAST)) err = UCI_ERR_UNKNOWN; + if (prefix) + fprintf(stderr, "%s: ", prefix); + if (ctx->func) + fprintf(stderr, "%s: ", ctx->func); + switch (err) { case UCI_ERR_PARSE: if (ctx->pctx) { - 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); + fprintf(stderr, "%s (%s) at line %d, byte %d\n", uci_errstr[err], (ctx->pctx->reason ? ctx->pctx->reason : "unknown"), ctx->pctx->line, ctx->pctx->byte); break; } /* fall through */ default: - fprintf(stderr, "%s: %s\n", str, uci_errstr[err]); + fprintf(stderr, "%s\n", uci_errstr[err]); break; } }