From: Szabolcs Nagy Date: Sat, 18 Apr 2015 14:31:07 +0000 (+0000) Subject: regex: clean up position accounting for literal nodes X-Git-Tag: v1.1.13~21 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=a8cc2253843e30dfbdf0bb2954439d9f2b2e8704;p=oweals%2Fmusl.git regex: clean up position accounting for literal nodes This should not change the meaning of the code, just make the intent clearer: advancing position is tied to adding a new literal. --- diff --git a/src/regex/regcomp.c b/src/regex/regcomp.c index 330de467..ac207c89 100644 --- a/src/regex/regcomp.c +++ b/src/regex/regcomp.c @@ -834,22 +834,20 @@ static reg_errcode_t parse_atom(tre_parse_ctx_t *ctx, const char *s) return REG_EBRACE; s++; } - node = tre_ast_new_literal(ctx->mem, v, v, ctx->position); - ctx->position++; + node = tre_ast_new_literal(ctx->mem, v, v, ctx->position++); s--; break; default: if (!ere && (unsigned)*s-'1' < 9) { /* back reference */ int val = *s - '0'; - node = tre_ast_new_literal(ctx->mem, BACKREF, val, ctx->position); + node = tre_ast_new_literal(ctx->mem, BACKREF, val, ctx->position++); ctx->max_backref = MAX(val, ctx->max_backref); } else { /* extension: accept unknown escaped char as a literal */ goto parse_literal; } - ctx->position++; } s++; break;