diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-10-09 14:58:44 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-10-09 14:58:44 +0100 |
commit | abaa90892c4256e78655644e2e8bfb8b663a0fa0 (patch) | |
tree | 2a0a7dae1ce4d90d17cbd8bef439def6e99348ad /src | |
parent | 62b3a7c5e9ea60844802c8f1fd6bcd6e4f5ea81a (diff) | |
download | rspamd-abaa90892c4256e78655644e2e8bfb8b663a0fa0.tar.gz rspamd-abaa90892c4256e78655644e2e8bfb8b663a0fa0.zip |
[Minor] Fixes for the previous project
Diffstat (limited to 'src')
-rw-r--r-- | src/libserver/composites.c | 32 | ||||
-rw-r--r-- | src/libutil/expression.c | 3 |
2 files changed, 31 insertions, 4 deletions
diff --git a/src/libserver/composites.c b/src/libserver/composites.c index d553ce7ef..308383605 100644 --- a/src/libserver/composites.c +++ b/src/libserver/composites.c @@ -21,6 +21,8 @@ #include "filter.h" #include "composites.h" +#include <math.h> + #define msg_err_composites(...) rspamd_default_log_function (G_LOG_LEVEL_CRITICAL, \ "composites", task->task_pool->tag.uid, \ G_STRFUNC, \ @@ -180,6 +182,7 @@ rspamd_composite_process_symbol_removal (rspamd_expression_atom_t *atom, { gchar t; struct symbol_remove_data *rd, *nrd; + struct rspamd_task *task = cd->task; if (ms == NULL) { return; @@ -239,9 +242,13 @@ rspamd_composite_process_symbol_removal (rspamd_expression_atom_t *atom, if (rd == NULL) { DL_APPEND (rd, nrd); g_hash_table_insert (cd->symbols_to_remove, (gpointer)ms->name, rd); + msg_debug_composites ("added symbol %s to removal: %d policy, from composite %s", + ms->name, nrd->action, cd->composite->sym); } else { DL_APPEND (rd, nrd); + msg_debug_composites ("append symbol %s to removal: %d policy, from composite %s", + ms->name, nrd->action, cd->composite->sym); } } @@ -258,7 +265,7 @@ rspamd_composite_expr_process (struct rspamd_expr_process_data *process_data, struct rspamd_task *task = cd->task; GHashTableIter it; gpointer k, v; - gdouble rc = 0; + gdouble rc = 0, max = 0; if (isset (cd->checked, cd->composite->id * 2)) { /* We have already checked this composite, so just return its value */ @@ -302,9 +309,15 @@ rspamd_composite_expr_process (struct rspamd_expr_process_data *process_data, cd, ms, beg); + + if (fabs (rc) > max) { + max = fabs (rc); + } } } } + + rc = max; } else if (strncmp (sym, "g+:", 3) == 0) { /* Group, positive symbols only */ @@ -326,13 +339,19 @@ rspamd_composite_expr_process (struct rspamd_expr_process_data *process_data, cd, ms, beg); + + if (fabs (rc) > max) { + max = fabs (rc); + } } } } + + rc = max; } } else if (strncmp (sym, "g-:", 3) == 0) { - /* Group, positive symbols only */ + /* Group, negative symbols only */ gr = g_hash_table_lookup (cd->task->cfg->groups, sym + 3); if (gr != NULL) { @@ -349,9 +368,15 @@ rspamd_composite_expr_process (struct rspamd_expr_process_data *process_data, cd, ms, beg); + + if (fabs (rc) > max) { + max = fabs (rc); + } } } } + + rc = max; } } else { @@ -365,6 +390,9 @@ rspamd_composite_expr_process (struct rspamd_expr_process_data *process_data, } } + msg_debug_composites ("final result for composite %s is %.2f", + cd->composite->sym, rc); + return rc; } diff --git a/src/libutil/expression.c b/src/libutil/expression.c index 463e3165a..bf5bb467c 100644 --- a/src/libutil/expression.c +++ b/src/libutil/expression.c @@ -619,8 +619,7 @@ rspamd_parse_expression (const gchar *line, gsize len, if (p + 1 < end) { gchar t = *(p + 1); - if (g_ascii_isspace (t) || g_ascii_isalnum (t) || - rspamd_expr_is_operation_symbol (t)) { + if (t != ':') { state = PARSE_OP; continue; } |