summaryrefslogtreecommitdiffstats
path: root/src/message.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2011-02-24 16:51:10 +0300
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2011-02-24 16:51:10 +0300
commitbf1dbf9b0ff37fc7638aa09f035f5f98094c84e9 (patch)
tree58567df06ca330f8ec5886554bbafe8cf5252929 /src/message.c
parent44d9cd1d59b340e8111ae57dafd06f65734b12d1 (diff)
downloadrspamd-bf1dbf9b0ff37fc7638aa09f035f5f98094c84e9.tar.gz
rspamd-bf1dbf9b0ff37fc7638aa09f035f5f98094c84e9.zip
Fix FSM for headers parsing.
Diffstat (limited to 'src/message.c')
-rw-r--r--src/message.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/src/message.c b/src/message.c
index 2056e87ca..28880b8da 100644
--- a/src/message.c
+++ b/src/message.c
@@ -497,6 +497,7 @@ process_raw_headers (struct worker_task *task)
tmp = memory_pool_alloc (task->task_pool, l + 1);
rspamd_strlcpy (tmp, c, l + 1);
new->name = tmp;
+ new->empty_separator = TRUE;
p ++;
state = 2;
c = p;
@@ -517,14 +518,14 @@ process_raw_headers (struct worker_task *task)
new->empty_separator = FALSE;
p ++;
}
- else if (*p == ' '){
+ else if (*p == ' ') {
new->empty_separator = FALSE;
p ++;
}
else if (*p == '\n' || *p == '\r') {
/* Process folding */
state = 99;
- l = p - c - 1;
+ l = p - c;
if (l > 0) {
tmp = memory_pool_alloc (task->task_pool, l + 1);
rspamd_strlcpy (tmp, c, l + 1);
@@ -536,7 +537,7 @@ process_raw_headers (struct worker_task *task)
}
else {
/* Process value */
- l = p - c - 1;
+ l = p - c;
if (l > 0) {
tmp = memory_pool_alloc (task->task_pool, l + 1);
rspamd_strlcpy (tmp, c, l + 1);
@@ -560,7 +561,7 @@ process_raw_headers (struct worker_task *task)
case 4:
/* Copy header's value */
l = p - c;
- tmp = memory_pool_alloc (task->task_pool, l);
+ tmp = memory_pool_alloc (task->task_pool, l + 1);
tp = tmp;
t_state = 0;
while (l --) {
@@ -568,6 +569,7 @@ process_raw_headers (struct worker_task *task)
/* Before folding */
if (*c == '\n' || *c == '\r') {
t_state = 1;
+ c ++;
}
else {
*tp ++ = *c ++;