aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-19 13:33:37 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-19 13:47:55 +0000
commit919ac543a6903875f0aa7791163e87267a92f881 (patch)
tree4dbb61a36e373545e555ca1d2fbf69e8ee107d42
parent98f30961257856c469c4674d966513edabd20286 (diff)
downloadrspamd-919ac543a6903875f0aa7791163e87267a92f881.tar.gz
rspamd-919ac543a6903875f0aa7791163e87267a92f881.zip
Fix + expressions optimizations.
-rw-r--r--src/libutil/expression.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/src/libutil/expression.c b/src/libutil/expression.c
index 2b52e2923..ca3983df5 100644
--- a/src/libutil/expression.c
+++ b/src/libutil/expression.c
@@ -322,7 +322,7 @@ rspamd_parse_expression (const gchar *line, gsize len,
len = strlen (line);
}
- num_re = rspamd_regexp_cache_create (NULL, "/^\\d+(\\s+|$)/", NULL, NULL);
+ num_re = rspamd_regexp_cache_create (NULL, "/^\\d+(\\s+|[)]|$)/", NULL, NULL);
p = line;
c = line;
@@ -670,43 +670,54 @@ rspamd_process_expression (struct rspamd_expression *expr, gpointer data)
case OP_LT:
if (cur_value >= lim->p.lim.val) {
ev->value = 0;
- rspamd_expr_stack_push (expr, ev);
done = TRUE;
}
break;
case OP_LE:
if (cur_value > lim->p.lim.val) {
ev->value = 0;
- rspamd_expr_stack_push (expr, ev);
done = TRUE;
}
break;
case OP_GT:
if (cur_value > lim->p.lim.val) {
ev->value = 1;
- rspamd_expr_stack_push (expr, ev);
done = TRUE;
}
break;
case OP_GE:
if (cur_value >= lim->p.lim.val) {
ev->value = 1;
- rspamd_expr_stack_push (expr, ev);
done = TRUE;
}
break;
default:
- rspamd_expr_stack_push (expr, ev);
+ g_assert (0);
break;
}
+
/* If we done, then we go forward and skip remaining items */
if (done) {
- i = cmp_pos + 1;
+ /* Remove extra elements left on the stack */
+ for (j = i; j < cmp_pos; j ++) {
+ check = &g_array_index (expr->expressions,
+ struct rspamd_expression_elt, j);
+ if (check->type == ELT_OP && check->p.op == OP_PLUS) {
+ rspamd_expr_stack_pop (expr);
+ }
+ }
+
+ /* Push the final result */
+ rspamd_expr_stack_push (expr, ev);
+ i = cmp_pos;
done = FALSE;
lim = NULL;
cur_value = 0;
cmp_op = NULL;
}
+ else {
+ rspamd_expr_stack_push (expr, ev);
+ }
break;
}
case OP_LT: