summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-26 15:13:08 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2015-03-26 15:13:08 +0000
commitf7e2dfac62c5ecee3103f037e9f2be01094a3f70 (patch)
tree875be016d8ae74c684ac028f58ccddc6e1376320
parentb5f65acbd6a62aa60431e3b8b19aeb6d3b56821a (diff)
downloadrspamd-f7e2dfac62c5ecee3103f037e9f2be01094a3f70.tar.gz
rspamd-f7e2dfac62c5ecee3103f037e9f2be01094a3f70.zip
Add helper functions.
-rw-r--r--src/libutil/expression.c30
1 files changed, 23 insertions, 7 deletions
diff --git a/src/libutil/expression.c b/src/libutil/expression.c
index b7604615e..a46f46d16 100644
--- a/src/libutil/expression.c
+++ b/src/libutil/expression.c
@@ -68,6 +68,7 @@ struct rspamd_expression {
const struct rspamd_atom_subr *subr;
GArray *expressions;
GArray *expression_stack;
+ GNode *ast;
};
static GQuark
@@ -77,29 +78,42 @@ rspamd_expr_quark (void)
}
static void
-rspamd_expr_stack_push (struct rspamd_expression *expr,
+rspamd_expr_stack_elt_push (GArray *stack,
gpointer elt)
{
- g_array_append_val (expr->expression_stack, elt);
+ g_array_append_val (stack, elt);
}
static gpointer
-rspamd_expr_stack_pop (struct rspamd_expression *expr)
+rspamd_expr_stack_elt_pop (GArray *stack)
{
gpointer e;
gint idx;
- if (expr->expression_stack->len == 0) {
+ if (stack->len == 0) {
return NULL;
}
- idx = expr->expression_stack->len - 1;
- e = g_array_index (expr->expression_stack, gpointer, idx);
- g_array_remove_index_fast (expr->expression_stack, idx);
+ idx = stack->len - 1;
+ e = g_array_index (stack, gpointer, idx);
+ g_array_remove_index_fast (stack, idx);
return e;
}
+static void
+rspamd_expr_stack_push (struct rspamd_expression *expr,
+ gpointer elt)
+{
+ rspamd_expr_stack_elt_push (expr->expression_stack, elt);
+}
+
+static gpointer
+rspamd_expr_stack_pop (struct rspamd_expression *expr)
+{
+ return rspamd_expr_stack_elt_pop (expr->expression_stack);
+}
+
/*
* Return operation priority
*/
@@ -294,6 +308,7 @@ rspamd_expression_destroy (struct rspamd_expression *expr)
g_array_free (expr->expressions, TRUE);
g_array_free (expr->expression_stack, TRUE);
+ g_node_destroy (expr->ast);
}
}
@@ -333,6 +348,7 @@ rspamd_parse_expression (const gchar *line, gsize len,
e = g_slice_alloc (sizeof (*e));
e->expressions = g_array_new (FALSE, FALSE,
sizeof (struct rspamd_expression_elt));
+ e->ast = NULL;
e->expression_stack = g_array_sized_new (FALSE, FALSE, sizeof (gpointer), 32);
e->subr = subr;