From: Florian Westphal Date: Mon, 2 Apr 2018 19:26:07 +0000 (+0200) Subject: evaluate: use recursive call for SET_REF handling X-Git-Tag: v0.8.4~46 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=aa732e3053e64b62318dd056aac140158c680f8a;p=thirdparty%2Fnftables.git evaluate: use recursive call for SET_REF handling We can now call the helper again, with set->init as new RHS expression. Signed-off-by: Florian Westphal --- diff --git a/src/evaluate.c b/src/evaluate.c index d03bfb06..efdbb5e5 100644 --- a/src/evaluate.c +++ b/src/evaluate.c @@ -1552,35 +1552,7 @@ static int __binop_transfer(struct eval_ctx *ctx, } break; case EXPR_SET_REF: - list_for_each_entry(i, &(*right)->set->init->expressions, list) { - switch (i->key->ops->type) { - case EXPR_VALUE: - case EXPR_RANGE: - case EXPR_SET_ELEM: - err = binop_can_transfer(ctx, left, i->key); - if (err <= 0) - return err; - break; - default: - break; - } - } - list_for_each_entry_safe(i, next, &(*right)->set->init->expressions, - list) { - list_del(&i->list); - switch (i->key->ops->type) { - case EXPR_VALUE: - case EXPR_RANGE: - case EXPR_SET_ELEM: - if (binop_transfer_one(ctx, left, &i->key) < 0) - return -1; - break; - default: - break; - } - list_add_tail(&i->list, &next->list); - } - break; + return __binop_transfer(ctx, left, &(*right)->set->init); default: return 0; }