Mercurial > dovecot > original-hg > dovecot-1.2
changeset 8318:836c8c2b87f5 HEAD
rfc822_parse_quoted_string(): Handle folding whitespace.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Thu, 23 Oct 2008 18:58:22 +0300 |
parents | 62e134c25a5e |
children | 8553bb4c53ad |
files | src/lib-mail/rfc822-parser.c |
diffstat | 1 files changed, 19 insertions(+), 11 deletions(-) [+] |
line wrap: on
line diff
--- a/src/lib-mail/rfc822-parser.c Thu Oct 23 18:27:20 2008 +0300 +++ b/src/lib-mail/rfc822-parser.c Thu Oct 23 18:58:22 2008 +0300 @@ -207,26 +207,34 @@ int rfc822_parse_quoted_string(struct rfc822_parser_context *ctx, string_t *str) { const unsigned char *start; + size_t len; i_assert(*ctx->data == '"'); ctx->data++; for (start = ctx->data; ctx->data != ctx->end; ctx->data++) { - if (*ctx->data == '"') { + switch (*ctx->data) { + case '"': str_append_n(str, start, ctx->data - start); ctx->data++; return rfc822_skip_lwsp(ctx); - } - - if (*ctx->data != '\\') - continue; + case '\n': + /* folding whitespace, remove the (CR)LF */ + len = ctx->data - start; + if (len > 0 && start[len-1] == '\r') + len--; + str_append_n(str, start, len); + start = ctx->data + 1; + break; + case '\\': + ctx->data++; + if (ctx->data == ctx->end) + return -1; - ctx->data++; - if (ctx->data == ctx->end) - return -1; - - str_append_n(str, start, ctx->data - start); - start = ctx->data; + str_append_n(str, start, ctx->data - start); + start = ctx->data; + break; + } } /* missing '"' */