diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-03-27 13:47:00 +0300 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2009-03-27 13:47:00 +0300 |
commit | fdccb337ed73f14b204721cf464ca03a7eca49b6 (patch) | |
tree | 6efd3483f969be2e63d6f285d281adbab82fff0f | |
parent | 251d13cc56cdf625bafac9db008d85abe0fa893c (diff) | |
download | rspamd-fdccb337ed73f14b204721cf464ca03a7eca49b6.tar.gz rspamd-fdccb337ed73f14b204721cf464ca03a7eca49b6.zip |
* Fix 2 memory leaks
* Fix uptime command output
-rw-r--r-- | src/controller.c | 1 | ||||
-rw-r--r-- | src/expressions.c | 160 | ||||
-rw-r--r-- | src/mem_pool.c | 1 | ||||
-rw-r--r-- | src/worker.c | 3 |
4 files changed, 96 insertions, 69 deletions
diff --git a/src/controller.c b/src/controller.c index d82cc726e..5a444b275 100644 --- a/src/controller.c +++ b/src/controller.c @@ -237,6 +237,7 @@ process_command (struct controller_command *cmd, char **cmd_args, struct control else { hours = uptime / 3600; minutes = uptime / 60 - hours * 3600; + uptime -= hours * 3600 + minutes * 60; r = snprintf (out_buf, sizeof (out_buf), "%d hour%s %d minite%s %d second%s" CRLF, hours, hours > 1 ? "s" : " ", minutes, minutes > 1 ? "s" : " ", diff --git a/src/expressions.c b/src/expressions.c index b115eba72..683e13dd8 100644 --- a/src/expressions.c +++ b/src/expressions.c @@ -689,6 +689,7 @@ rspamd_content_type_compare_param (struct worker_task *task, GList *args) const char *param_data; struct rspamd_regexp *re; struct expression_argument *arg; + GMimeObject *part; const GMimeContentType *ct; if (args == NULL) { @@ -705,31 +706,36 @@ rspamd_content_type_compare_param (struct worker_task *task, GList *args) arg = args->data; param_pattern = arg->data; - ct = g_mime_object_get_content_type (GMIME_OBJECT (g_mime_message_get_mime_part (task->message))); - if ((param_data = g_mime_content_type_get_parameter (ct, param_name)) == NULL) { - return FALSE; - } - - if (*param_pattern == '/') { - /* This is regexp, so compile and create g_regexp object */ - if ((re = re_cache_check (param_pattern)) == NULL) { - re = parse_regexp (task->task_pool, param_pattern); - if (re == NULL) { - msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); - return FALSE; - } - re_cache_add (param_pattern, re); + part = g_mime_message_get_mime_part (task->message); + if (part) { + ct = g_mime_object_get_content_type (part); + g_object_unref (part); + + if ((param_data = g_mime_content_type_get_parameter (ct, param_name)) == NULL) { + return FALSE; } - if (g_regex_match (re->regexp, param_data, 0, NULL) == TRUE) { - return TRUE; + if (*param_pattern == '/') { + /* This is regexp, so compile and create g_regexp object */ + if ((re = re_cache_check (param_pattern)) == NULL) { + re = parse_regexp (task->task_pool, param_pattern); + if (re == NULL) { + msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); + return FALSE; + } + re_cache_add (param_pattern, re); + } + if (g_regex_match (re->regexp, param_data, 0, NULL) == TRUE) { + return TRUE; + } } - } - else { - /* Just do strcasecmp */ - if (g_ascii_strcasecmp (param_data, param_pattern) == 0) { - return TRUE; + else { + /* Just do strcasecmp */ + if (g_ascii_strcasecmp (param_data, param_pattern) == 0) { + return TRUE; + } } } + return FALSE; } @@ -740,6 +746,7 @@ rspamd_content_type_has_param (struct worker_task *task, GList *args) char *param_name; const char *param_data; struct expression_argument *arg; + GMimeObject *part; const GMimeContentType *ct; if (args == NULL) { @@ -748,9 +755,14 @@ rspamd_content_type_has_param (struct worker_task *task, GList *args) } arg = args->data; param_name = arg->data; - ct = g_mime_object_get_content_type (GMIME_OBJECT (g_mime_message_get_mime_part (task->message))); - if ((param_data = g_mime_content_type_get_parameter (ct, param_name)) == NULL) { - return FALSE; + part = g_mime_message_get_mime_part (task->message); + if (part) { + ct = g_mime_object_get_content_type (part); + g_object_unref (part); + + if ((param_data = g_mime_content_type_get_parameter (ct, param_name)) == NULL) { + return FALSE; + } } return TRUE; @@ -771,7 +783,8 @@ rspamd_content_type_is_subtype (struct worker_task *task, GList *args) char *param_pattern; struct rspamd_regexp *re; struct expression_argument *arg; - localContentType *ct; + GMimeObject *part; + const localContentType *ct; if (args == NULL) { msg_warn ("rspamd_content_type_compare_param: no parameters to function"); @@ -780,30 +793,34 @@ rspamd_content_type_is_subtype (struct worker_task *task, GList *args) arg = args->data; param_pattern = arg->data; - ct = (localContentType *)g_mime_object_get_content_type (GMIME_OBJECT (g_mime_message_get_mime_part (task->message))); + part = g_mime_message_get_mime_part (task->message); + if (part) { + ct = (const localContentType *)g_mime_object_get_content_type (part); + g_object_unref (part); - if (ct == NULL) { - return FALSE; - } - - if (*param_pattern == '/') { - /* This is regexp, so compile and create g_regexp object */ - if ((re = re_cache_check (param_pattern)) == NULL) { - re = parse_regexp (task->task_pool, param_pattern); - if (re == NULL) { - msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); - return FALSE; - } - re_cache_add (param_pattern, re); + if (ct == NULL) { + return FALSE; } - if (g_regex_match (re->regexp, ct->subtype, 0, NULL) == TRUE) { - return TRUE; + + if (*param_pattern == '/') { + /* This is regexp, so compile and create g_regexp object */ + if ((re = re_cache_check (param_pattern)) == NULL) { + re = parse_regexp (task->task_pool, param_pattern); + if (re == NULL) { + msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); + return FALSE; + } + re_cache_add (param_pattern, re); + } + if (g_regex_match (re->regexp, ct->subtype, 0, NULL) == TRUE) { + return TRUE; + } } - } - else { - /* Just do strcasecmp */ - if (g_ascii_strcasecmp (ct->subtype, param_pattern) == 0) { - return TRUE; + else { + /* Just do strcasecmp */ + if (g_ascii_strcasecmp (ct->subtype, param_pattern) == 0) { + return TRUE; + } } } @@ -815,7 +832,8 @@ rspamd_content_type_is_type (struct worker_task *task, GList *args) { char *param_pattern; struct rspamd_regexp *re; - localContentType *ct; + GMimeObject *part; + const localContentType *ct; struct expression_argument *arg; if (args == NULL) { @@ -825,30 +843,36 @@ rspamd_content_type_is_type (struct worker_task *task, GList *args) arg = args->data; param_pattern = arg->data; - ct = (localContentType *)g_mime_object_get_content_type (GMIME_OBJECT (g_mime_message_get_mime_part (task->message))); + param_pattern = arg->data; - if (ct == NULL) { - return FALSE; - } - - if (*param_pattern == '/') { - /* This is regexp, so compile and create g_regexp object */ - if ((re = re_cache_check (param_pattern)) == NULL) { - re = parse_regexp (task->task_pool, param_pattern); - if (re == NULL) { - msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); - return FALSE; - } - re_cache_add (param_pattern, re); + part = g_mime_message_get_mime_part (task->message); + if (part) { + ct = (const localContentType *)g_mime_object_get_content_type (part); + g_object_unref (part); + + if (ct == NULL) { + return FALSE; } - if (g_regex_match (re->regexp, ct->type, 0, NULL) == TRUE) { - return TRUE; + + if (*param_pattern == '/') { + /* This is regexp, so compile and create g_regexp object */ + if ((re = re_cache_check (param_pattern)) == NULL) { + re = parse_regexp (task->task_pool, param_pattern); + if (re == NULL) { + msg_warn ("rspamd_content_type_compare_param: cannot compile regexp for function"); + return FALSE; + } + re_cache_add (param_pattern, re); + } + if (g_regex_match (re->regexp, ct->type, 0, NULL) == TRUE) { + return TRUE; + } } - } - else { - /* Just do strcasecmp */ - if (g_ascii_strcasecmp (ct->type, param_pattern) == 0) { - return TRUE; + else { + /* Just do strcasecmp */ + if (g_ascii_strcasecmp (ct->type, param_pattern) == 0) { + return TRUE; + } } } diff --git a/src/mem_pool.c b/src/mem_pool.c index ab96483f0..956a62422 100644 --- a/src/mem_pool.c +++ b/src/mem_pool.c @@ -23,7 +23,6 @@ */ #include "config.h" - #include "mem_pool.h" /* Sleep time for spin lock in nanoseconds */ diff --git a/src/worker.c b/src/worker.c index cf716ee0d..02fcc8707 100644 --- a/src/worker.c +++ b/src/worker.c @@ -110,6 +110,9 @@ free_task (struct worker_task *task, gboolean is_soft) g_byte_array_free (p->content, TRUE); g_list_free_1 (part); } + if (task->text_parts) { + g_list_free (task->text_parts); + } memory_pool_delete (task->task_pool); if (is_soft) { /* Plan dispatcher shutdown */ |