X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/b7345052cafdcd4bef23b1a1822675bc5659accf..a8bb0c0d8fcfa7f5b43dee30ccfdf799bbbf8520:/uip/ap.c diff --git a/uip/ap.c b/uip/ap.c index 80ce8a3f..f0b0baa9 100644 --- a/uip/ap.c +++ b/uip/ap.c @@ -19,23 +19,20 @@ #define FORMAT "%<{error}%{error}: %{text}%|%(putstr(proper{text}))%>" -static struct swit switches[] = { -#define FORMSW 0 - { "form formatfile", 0 }, -#define FMTSW 1 - { "format string", 5 }, -#define NORMSW 2 - { "normalize", 0 }, -#define NNORMSW 3 - { "nonormalize", 0 }, -#define WIDTHSW 4 - { "width columns", 0 }, -#define VERSIONSW 5 - { "version", 0 }, -#define HELPSW 6 - { "help", 0 }, - { NULL, 0 } -}; +#define AP_SWITCHES \ + X("form formatfile", 0, FORMSW) \ + X("format string", 5, FMTSW) \ + X("width columns", 0, WIDTHSW) \ + X("version", 0, VERSIONSW) \ + X("help", 0, HELPSW) \ + +#define X(sw, minchars, id) id, +DEFINE_SWITCH_ENUM(AP); +#undef X + +#define X(sw, minchars, id) { sw, minchars, id }, +DEFINE_SWITCH_ARRAY(AP, switches); +#undef X static struct format *fmt; @@ -44,13 +41,13 @@ static int dat[5]; /* * static prototypes */ -static int process (char *, int, int); +static int process (char *, int); int main (int argc, char **argv) { - int addrp = 0, normalize = AD_HOST; + int addrp = 0; int width = 0, status = 0; char *cp, *form = NULL, *format = NULL, *nfs; char buf[BUFSIZ], **argp; @@ -103,13 +100,6 @@ main (int argc, char **argv) adios (NULL, "missing argument to %s", argp[-2]); width = atoi (cp); continue; - - case NORMSW: - normalize = AD_HOST; - continue; - case NNORMSW: - normalize = AD_NHST; - continue; } } if (addrp > NADDRS) @@ -132,7 +122,6 @@ main (int argc, char **argv) } if (width > WBUFSIZ) width = WBUFSIZ; - fmt_norm = normalize; fmt_compile (nfs, &fmt, 1); dat[0] = 0; @@ -142,7 +131,7 @@ main (int argc, char **argv) dat[4] = 0; for (addrp = 0; addrs[addrp]; addrp++) - status += process (addrs[addrp], width, normalize); + status += process (addrs[addrp], width); fmt_free (fmt, 1); done (status); @@ -157,7 +146,7 @@ struct pqpair { static int -process (char *arg, int length, int norm) +process (char *arg, int length) { int status = 0; register char *cp; @@ -171,7 +160,7 @@ process (char *arg, int length, int norm) while ((cp = getname (arg))) { if ((p = (struct pqpair *) calloc ((size_t) 1, sizeof(*p))) == NULL) adios (NULL, "unable to allocate pqpair memory"); - if ((mp = getm (cp, NULL, 0, norm, error)) == NULL) { + if ((mp = getm (cp, NULL, 0, error, sizeof(error))) == NULL) { p->pq_text = getcpy (cp); p->pq_error = getcpy (error); status++; @@ -199,7 +188,7 @@ process (char *arg, int length, int norm) p->pq_error = NULL; } - fmt_scan (fmt, buffer, sizeof buffer - 1, length, dat); + fmt_scan (fmt, buffer, sizeof buffer - 1, length, dat, NULL); fputs (buffer, stdout); if (p->pq_text)