[PATCH v2 1/7] lib-mail: message_address_write: Fix generating empty group list
Pali Rohár
pali.rohar at gmail.com
Sun Jun 5 13:48:14 UTC 2016
Empty group list ends with ": " not with ", ".
Test case:
{ { name = NULL, mailbox = "group", domain = NULL }, { name = NULL, mailbox = NULL, domain = NULL } }
converts to:
group:;
---
src/lib-mail/message-address.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)
diff --git a/src/lib-mail/message-address.c b/src/lib-mail/message-address.c
index 36cb483..efa91fd 100644
--- a/src/lib-mail/message-address.c
+++ b/src/lib-mail/message-address.c
@@ -340,6 +340,7 @@ message_address_parse(pool_t pool, const unsigned char *data, size_t size,
void message_address_write(string_t *str, const struct message_address *addr)
{
+ const char *tmp;
bool first = TRUE, in_group = FALSE;
/* a) mailbox at domain
@@ -365,7 +366,12 @@ void message_address_write(string_t *str, const struct message_address *addr)
i_assert(addr->mailbox == NULL);
/* cut out the ", " */
- str_truncate(str, str_len(str)-2);
+ tmp = str_c(str)+str_len(str)-2;
+ i_assert((tmp[0] == ',' || tmp[0] == ':') && tmp[1] == ' ');
+ if (tmp[0] == ',' && tmp[1] == ' ')
+ str_truncate(str, str_len(str)-2);
+ else if (tmp[0] == ':' && tmp[1] == ' ')
+ str_truncate(str, str_len(str)-1);
str_append_c(str, ';');
}
--
1.7.9.5
More information about the dovecot
mailing list