From: Vsevolod Stakhov Date: Sat, 16 Jan 2016 22:16:19 +0000 (+0000) Subject: Fix memory leak X-Git-Tag: 1.1.0~16 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=9f9354400bef0a810d3b1117e08c8149dfcb8489;p=thirdparty%2Frspamd.git Fix memory leak --- diff --git a/src/libserver/task.c b/src/libserver/task.c index 657fcdc118..c612179219 100644 --- a/src/libserver/task.c +++ b/src/libserver/task.c @@ -464,16 +464,19 @@ rspamd_task_process (struct rspamd_task *task, guint stages) case RSPAMD_TASK_STAGE_LEARN_PRE: case RSPAMD_TASK_STAGE_LEARN_POST: if (task->flags & (RSPAMD_TASK_FLAG_LEARN_SPAM|RSPAMD_TASK_FLAG_LEARN_HAM)) { - if (!rspamd_stat_learn (task, - task->flags & RSPAMD_TASK_FLAG_LEARN_SPAM, - task->cfg->lua_state, task->classifier, - st, &stat_error)) { + if (task->err == NULL) { + if (!rspamd_stat_learn (task, + task->flags & RSPAMD_TASK_FLAG_LEARN_SPAM, + task->cfg->lua_state, task->classifier, + st, &stat_error)) { + + if (!(task->flags & RSPAMD_TASK_FLAG_LEARN_AUTO)) { + task->err = stat_error; + } - if (!(task->flags & RSPAMD_TASK_FLAG_LEARN_AUTO)) { - task->err = stat_error; + msg_err_task ("learn error: %e", stat_error); + task->processed_stages |= RSPAMD_TASK_STAGE_DONE; } - msg_err_task ("learn error: %e", stat_error); - task->processed_stages |= RSPAMD_TASK_STAGE_DONE; } } break;