aboutsummaryrefslogtreecommitdiffstats
path: root/src/libmime/mime_expressions.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2017-01-18 13:44:14 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2017-01-18 13:44:14 +0000
commit3a3a6f161bd5dd6c3452d103b7ac5e3b7a0932e6 (patch)
tree3c44dcb4f0fd0cd0eb351cec5de890122cd400a6 /src/libmime/mime_expressions.c
parent7d40df5184f0aa6facde77e088d0751d4c475c6a (diff)
downloadrspamd-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.c14
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);
}
}