From: Pablo Neira Ayuso Date: Wed, 10 Jan 2024 17:18:50 +0000 (+0100) Subject: evaluate: skip anonymous set optimization for concatenations X-Git-Tag: v1.1.0~128 X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=6bc6673fc88c8a3e3dd5504b2d24a6d6bc2f8427;p=thirdparty%2Fnftables.git evaluate: skip anonymous set optimization for concatenations Concatenation is only supported with sets. Moreover, stripping of the set leads to broken ruleset listing, therefore, skip this optimization for the concatenations. Fixes: fa17b17ea74a ("evaluate: revisit anonymous set with single element optimization") Signed-off-by: Pablo Neira Ayuso --- diff --git a/src/evaluate.c b/src/evaluate.c index b13e7c02..78732c6e 100644 --- a/src/evaluate.c +++ b/src/evaluate.c @@ -2580,15 +2580,17 @@ static int expr_evaluate_relational(struct eval_ctx *ctx, struct expr **expr) return expr_binary_error(ctx->msgs, right, left, "Cannot be used with right hand side constant value"); - switch (rel->op) { - case OP_EQ: - case OP_IMPLICIT: - case OP_NEQ: - if (right->etype == EXPR_SET && right->size == 1) - optimize_singleton_set(rel, &right); - break; - default: - break; + if (left->etype != EXPR_CONCAT) { + switch (rel->op) { + case OP_EQ: + case OP_IMPLICIT: + case OP_NEQ: + if (right->etype == EXPR_SET && right->size == 1) + optimize_singleton_set(rel, &right); + break; + default: + break; + } } switch (rel->op) {