]>
diplodocus.org Git - nmh/blob - sbr/fmt_addr.c
1 /* fmt_addr.c -- format an address field (from fmt_scan)
3 * This code is Copyright (c) 2002, by the authors of nmh. See the
4 * COPYRIGHT file in the root directory of the nmh distribution for
5 * complete copyright information.
10 #include <h/fmt_scan.h>
13 static char *buf
; /* our current working buffer */
14 static char *bufend
; /* end of working buffer */
15 static char *last_dst
; /* buf ptr at end of last call */
16 static unsigned int bufsiz
; /* current size of buf */
18 #define BUFINCR 512 /* how much to expand buf when if fills */
20 #define CPY(s) { cp = (s); while ((*dst++ = *cp++)) ; --dst; }
22 /* check if there's enough room in buf for str. add more mem if needed */
23 #define CHECKMEM(str) \
24 if ((len = strlen (str)) >= bufend - dst) {\
26 int n = last_dst - buf;\
27 bufsiz += ((dst + len - bufend) / BUFINCR + 1) * BUFINCR;\
28 buf = mh_xrealloc (buf, bufsiz);\
31 bufend = buf + bufsiz;\
35 /* fmt_scan will call this routine if the user includes the function
36 * "(formataddr {component})" in a format string. "orig" is the
37 * original contents of the string register. "str" is the address
38 * string to be formatted and concatenated onto orig. This routine
39 * returns a pointer to the concatenated address string.
41 * We try to not do a lot of malloc/copy/free's (which is why we
42 * don't call "getcpy") but still place no upper limit on the
43 * length of the result string.
45 * This routine is placed in a separate library so it can be
46 * overridden by particular programs (e.g., "replsbr").
50 formataddr (char *orig
, char *str
)
57 struct mailname
*mp
= NULL
;
59 /* if we don't have a buffer yet, get one */
61 buf
= mh_xmalloc (BUFINCR
);
62 last_dst
= buf
; /* XXX */
63 bufsiz
= BUFINCR
- 6; /* leave some slop */
64 bufend
= buf
+ bufsiz
;
67 * If "orig" points to our buffer we can just pick up where we
68 * left off. Otherwise we have to copy orig into our buffer.
72 else if (!orig
|| !*orig
) {
76 dst
= last_dst
; /* XXX */
81 /* concatenate all the new addresses onto 'buf' */
82 for (isgroup
= 0; (cp
= getname (str
)); ) {
83 if ((mp
= getm (cp
, NULL
, 0, NULL
, 0)) == NULL
)
86 if (isgroup
&& (mp
->m_gname
|| !mp
->m_ingrp
)) {
90 /* if we get here we're going to add an address */
96 CHECKMEM (mp
->m_gname
);
114 char *concataddr (char *orig
, char *str
)
116 return formataddr(orig
, str
);