diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-03-19 13:33:37 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-03-19 13:47:55 +0000 |
commit | 919ac543a6903875f0aa7791163e87267a92f881 (patch) | |
tree | 4dbb61a36e373545e555ca1d2fbf69e8ee107d42 | |
parent | 98f30961257856c469c4674d966513edabd20286 (diff) | |
download | rspamd-919ac543a6903875f0aa7791163e87267a92f881.tar.gz rspamd-919ac543a6903875f0aa7791163e87267a92f881.zip |
Fix + expressions optimizations.
-rw-r--r-- | src/libutil/expression.c | 25 |
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: |