]>
diplodocus.org Git - nmh/blob - uip/ali.c
3 * ali.c -- list nmh mail aliases
5 * This code is Copyright (c) 2002, by the authors of nmh. See the
6 * COPYRIGHT file in the root directory of the nmh distribution for
7 * complete copyright information.
11 #include <h/addrsbr.h>
12 #include <h/aliasbr.h>
16 #define ALI_SWITCHES \
17 X("alias aliasfile", 0, ALIASW) \
18 X("noalias", -7, NALIASW) \
19 X("list", 0, LISTSW) \
20 X("nolist", 0, NLISTSW) \
21 X("user", 0, USERSW) \
22 X("nouser", 0, NUSERSW) \
23 X("version", 0, VERSIONSW) \
24 X("help", 0, HELPSW) \
26 #define X(sw, minchars, id) id,
27 DEFINE_SWITCH_ENUM(ALI
);
30 #define X(sw, minchars, id) { sw, minchars, id },
31 DEFINE_SWITCH_ARRAY(ALI
, switches
);
36 extern struct aka
*akahead
;
41 static void print_aka (char *, int, int);
42 static void print_usr (char *, int);
46 main (int argc
, char **argv
)
48 int i
, vecp
= 0, inverted
= 0, list
= 0;
50 char *cp
, **ap
, **argp
, buf
[BUFSIZ
];
51 /* Really only need to allocate for argc-1, but must allocate at least 1,
52 so go ahead and allocate for argc char pointers. */
53 char **vec
= mh_xmalloc (argc
* sizeof (char *)), **arguments
;
57 setlocale(LC_ALL
, "");
59 invo_name
= r1bindex (argv
[0], '/');
61 /* read user profile/context */
65 arguments
= getarguments (invo_name
, argc
, argv
, 1);
68 while ((cp
= *argp
++)) {
70 switch (smatch (++cp
, switches
)) {
72 ambigsw (cp
, switches
);
75 adios (NULL
, "-%s unknown", cp
);
78 snprintf (buf
, sizeof(buf
), "%s [switches] aliases ...",
80 print_help (buf
, switches
, 1);
83 print_version (invo_name
);
87 if (!(cp
= *argp
++) || *cp
== '-')
88 adios (NULL
, "missing argument to %s", argp
[-2]);
89 if ((i
= alias (cp
)) != AK_OK
)
90 adios (NULL
, "aliasing error in %s - %s", cp
, akerror (i
));
115 /* Should never happen, but try to protect against code changes
116 that could allow it. */
117 adios (NULL
, "too many arguments");
122 /* allow Aliasfile: profile entry */
123 if ((cp
= context_find ("Aliasfile"))) {
126 for (ap
= brkstring(dp
= getcpy(cp
), " ", "\n"); ap
&& *ap
; ap
++)
127 if ((i
= alias (*ap
)) != AK_OK
)
128 adios (NULL
, "aliasing error in %s - %s", *ap
, akerror (i
));
136 * If -user is specified
140 adios (NULL
, "usage: %s -user addresses ... (you forgot the addresses)",
143 for (i
= 0; i
< vecp
; i
++)
144 print_usr (vec
[i
], list
);
147 /* print specified aliases */
148 for (i
= 0; i
< vecp
; i
++)
149 print_aka (akvalue (vec
[i
]), list
, 0);
152 for (ak
= akahead
; ak
; ak
= ak
->ak_next
) {
153 printf ("%s: ", ak
->ak_name
);
154 pos
+= strlen (ak
->ak_name
) + 1;
155 print_aka (akresult (ak
), list
, pos
);
166 print_aka (char *p
, int list
, int margin
)
171 printf ("<empty>\n");
180 printf ("\n%*s", margin
, "");
206 print_usr (char *s
, int list
)
208 register char *cp
, *pp
, *vp
;
209 register struct aka
*ak
;
210 register struct mailname
*mp
, *np
;
212 if ((pp
= getname (s
)) == NULL
)
213 adios (NULL
, "no address in \"%s\"", s
);
214 if ((mp
= getm (pp
, NULL
, 0, NULL
, 0)) == NULL
)
215 adios (NULL
, "bad address \"%s\"", s
);
220 for (ak
= akahead
; ak
; ak
= ak
->ak_next
) {
222 while ((cp
= getname (pp
))) {
223 if ((np
= getm (cp
, NULL
, 0, NULL
, 0)) == NULL
)
225 if (!strcasecmp (mp
->m_host
? mp
->m_host
: "",
226 np
->m_host
? np
->m_host
: "") &&
227 !strcasecmp (mp
->m_mbox
? mp
->m_mbox
: "",
228 np
->m_mbox
? np
->m_mbox
: "")) {
229 vp
= vp
? add (ak
->ak_name
, add (",", vp
))
230 : getcpy (ak
->ak_name
);
241 print_aka (vp
? vp
: s
, list
, 0);