From c394d8787defccf5f127f75f7f999d0a8ddff514 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Tue, 5 Feb 2008 00:33:59 +0100 Subject: [PATCH] improve the argument parser --- uci.h | 5 +++-- util.c | 24 ++++++++++++++++++------ 2 files changed, 21 insertions(+), 8 deletions(-) diff --git a/uci.h b/uci.h index 8a89b71..9f03a6f 100644 --- a/uci.h +++ b/uci.h @@ -263,10 +263,11 @@ extern int uci_revert(struct uci_context *ctx, struct uci_package **p, char *sec /** * uci_parse_argument: parse a shell-style argument, with an arbitrary quoting style * @ctx: uci context - * @str: pointer to the input string (will be changed to the end of the parsed string) + * @stream: input stream + * @str: pointer to the current line (use NULL for parsing the next line) * @result: pointer for the result */ -extern int uci_parse_argument(struct uci_context *ctx, char **str, char **result); +extern int uci_parse_argument(struct uci_context *ctx, FILE *stream, char **str, char **result); /* UCI data structures */ enum uci_type { diff --git a/util.c b/util.c index 0ac33c7..4713c74 100644 --- a/util.c +++ b/util.c @@ -146,10 +146,7 @@ static void uci_parse_error(struct uci_context *ctx, char *pos, char *reason) struct uci_parse_context *pctx = ctx->pctx; pctx->reason = reason; - if ((pos < pctx->buf) || (pos > pctx->buf + pctx->bufsz)) - pctx->byte = 0; - else - pctx->byte = pos - pctx->buf; + pctx->byte = pos - pctx->buf; UCI_THROW(ctx, UCI_ERR_PARSE); } @@ -351,13 +348,28 @@ done: return val; } -int uci_parse_argument(struct uci_context *ctx, char **str, char **result) +int uci_parse_argument(struct uci_context *ctx, FILE *stream, char **str, char **result) { UCI_HANDLE_ERR(ctx); - UCI_ASSERT(ctx, (str != NULL) && (*str != NULL)); + UCI_ASSERT(ctx, str != NULL); UCI_ASSERT(ctx, result != NULL); + if (ctx->pctx) { + if (ctx->pctx->file != stream) { + ctx->internal = true; + uci_cleanup(ctx); + } + } else { + uci_alloc_parse_context(ctx); + ctx->pctx->file = stream; + } + if (!*str) { + uci_getln(ctx, 0); + *str = ctx->pctx->buf; + } + *result = next_arg(ctx, str, false, false); + return 0; } -- 2.25.1