X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=sbr%2Faddrsbr.c;h=e5fc19d646ad71d51bf14dbe22c5503d5339c51b;hp=53e9be4362a0955d31893c7ac81de595d94b4340;hb=72795bfcbe9f7fee8927b1a4942c0230b0f857a8;hpb=5ba9c2f13fedf1d8d6ed907ef1f505616290efaa diff --git a/sbr/addrsbr.c b/sbr/addrsbr.c index 53e9be4..e5fc19d 100644 --- a/sbr/addrsbr.c +++ b/sbr/addrsbr.c @@ -103,7 +103,7 @@ getm(char *str, char *dfhost, int dftype, int wanthost, char *eresult) dftype = LOCALHOST; } - mp = (struct mailname *) calloc((size_t) 1, sizeof(*mp)); + mp = (struct mailname *) mh_xcalloc((size_t) 1, sizeof(*mp)); if (mp == NULL) { if (eresult) strcpy(eresult, "insufficient memory to represent address"); @@ -373,3 +373,28 @@ local_test: ; return 0; } + +/* + * Insert mailname after element and returns the + * number of parsed addresses. element is set to + * the last parsed addresse. + */ +size_t +getmboxes(char *line, struct mailname **element) +{ + struct mailname *mp, *next; + char *cp; + size_t i = 0; + + next = (*element)->m_next; + + while ((cp = getname(line))) { + mp = getm(cp, NULL, 0, AD_HOST, NULL); + (*element)->m_next = mp; + *element = mp; + i++; + } + + (*element)->m_next = next; + return i; +}