diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2011-07-12 18:35:47 +0400 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2011-07-12 18:35:47 +0400 |
commit | c4105fc43199d51af271bc24d3345aa57906d973 (patch) | |
tree | 3b9fa1614afa3bd4df627bae022ec1f7ec5c684c /src/expressions.c | |
parent | f88f875cf8b89fb9f26a510c66ebf7004ea80d6c (diff) | |
download | rspamd-c4105fc43199d51af271bc24d3345aa57906d973.tar.gz rspamd-c4105fc43199d51af271bc24d3345aa57906d973.zip |
Cache data of parts distance function to speed up multiply rules with such function.
Diffstat (limited to 'src/expressions.c')
-rw-r--r-- | src/expressions.c | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/src/expressions.c b/src/expressions.c index fa6ce0fef..d330526de 100644 --- a/src/expressions.c +++ b/src/expressions.c @@ -1016,7 +1016,7 @@ rspamd_parts_distance (struct worker_task * task, GList * args, void *unused) struct expression_argument *arg; GMimeObject *parent; const GMimeContentType *ct; - + gint *pdiff; if (args == NULL) { debug_task ("no threshold is specified, assume it 100"); @@ -1032,10 +1032,23 @@ rspamd_parts_distance (struct worker_task * task, GList * args, void *unused) } } + if ((pdiff = memory_pool_get_variable (task->task_pool, "parts_distance")) != NULL) { + diff = *pdiff; + if (diff != -1 && diff <= threshold) { + return TRUE; + } + else { + return FALSE; + } + } + if (g_list_length (task->text_parts) == 2) { cur = g_list_first (task->text_parts); p1 = cur->data; cur = g_list_next (cur); + pdiff = memory_pool_alloc (task->task_pool, sizeof (gint)); + *pdiff = -1; + if (cur == NULL) { msg_info ("bad parts list"); return FALSE; @@ -1051,30 +1064,38 @@ rspamd_parts_distance (struct worker_task * task, GList * args, void *unused) if (ct == NULL || ! g_mime_content_type_is_type ((GMimeContentType *)ct, "multipart", "alternative")) { #endif debug_task ("two parts are not belong to multipart/alternative container, skip check"); + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); return FALSE; } } else { debug_task ("message contains two parts but they are in different multi-parts"); + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); return FALSE; } if (!p1->is_empty && !p2->is_empty) { diff = fuzzy_compare_parts (p1, p2); debug_task ("got likeliness between parts of %d%%, threshold is %d%%", diff, threshold); + *pdiff = diff; + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); if (diff <= threshold) { return TRUE; } } else if ((p1->is_empty && !p2->is_empty) || (!p1->is_empty && p2->is_empty)) { /* Empty and non empty parts are different */ + *pdiff = 0; + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); return TRUE; } } else { debug_task ("message has too many text parts, so do not try to compare them with each other"); + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); return FALSE; } + memory_pool_set_variable (task->task_pool, "parts_distance", pdiff, NULL); return FALSE; } |