diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-01-18 13:44:14 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-01-18 13:44:14 +0000 |
commit | 3a3a6f161bd5dd6c3452d103b7ac5e3b7a0932e6 (patch) | |
tree | 3c44dcb4f0fd0cd0eb351cec5de890122cd400a6 /src/libmime/mime_expressions.c | |
parent | 7d40df5184f0aa6facde77e088d0751d4c475c6a (diff) | |
download | rspamd-3a3a6f161bd5dd6c3452d103b7ac5e3b7a0932e6.tar.gz rspamd-3a3a6f161bd5dd6c3452d103b7ac5e3b7a0932e6.zip |
[Fix] Multiple memory corruption fixes
Diffstat (limited to 'src/libmime/mime_expressions.c')
-rw-r--r-- | src/libmime/mime_expressions.c | 14 |
1 files changed, 0 insertions, 14 deletions
diff --git a/src/libmime/mime_expressions.c b/src/libmime/mime_expressions.c index ad5be8c0c..8a5672459 100644 --- a/src/libmime/mime_expressions.c +++ b/src/libmime/mime_expressions.c @@ -481,7 +481,6 @@ rspamd_mime_expr_parse_function_atom (rspamd_mempool_t *pool, const gchar *input res->name = rspamd_mempool_alloc (pool, obrace - input + 1); rspamd_strlcpy (res->name, input, obrace - input + 1); res->args = g_array_new (FALSE, FALSE, sizeof (struct expression_argument)); - rspamd_mempool_add_destructor (pool, rspamd_array_free_hard, res->args); p = obrace + 1; c = p; @@ -528,9 +527,6 @@ rspamd_mime_expr_parse_function_atom (rspamd_mempool_t *pool, const gchar *input arg.type = EXPRESSION_ARGUMENT_NORMAL; arg.data = databuf; } - else { - g_free (databuf); - } g_array_append_val (res->args, arg); state = got_comma; @@ -873,20 +869,10 @@ static void rspamd_mime_expr_destroy (rspamd_expression_atom_t *atom) { struct rspamd_mime_atom *mime_atom = atom->data; - guint i; - struct expression_argument *arg; if (mime_atom) { if (mime_atom->type == MIME_ATOM_INTERNAL_FUNCTION) { /* Need to cleanup arguments */ - for (i = 0; i < mime_atom->d.func->args->len; i ++) { - arg = &g_array_index (mime_atom->d.func->args, - struct expression_argument, i); - - if (arg->type == EXPRESSION_ARGUMENT_NORMAL) { - g_free (arg->data); - } - } g_array_free (mime_atom->d.func->args, TRUE); } } |