]> git.cameronkatri.com Git - mandoc.git/blobdiff - main.c
Prefix messages about bad command line options and arguments
[mandoc.git] / main.c
diff --git a/main.c b/main.c
index b05ddc937d403ac111a9976383cbe0705c709abc..2323cd8daba83076aae9e11604dbe3c8139b5bb0 100644 (file)
--- a/main.c
+++ b/main.c
@@ -1,4 +1,4 @@
-/*     $Id: main.c,v 1.170 2014/03/19 21:51:20 schwarze Exp $ */
+/*     $Id: main.c,v 1.176 2014/06/21 16:18:25 schwarze Exp $ */
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010, 2011, 2012, 2014 Ingo Schwarze <schwarze@openbsd.org>
 /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2010, 2011, 2012, 2014 Ingo Schwarze <schwarze@openbsd.org>
@@ -28,6 +28,7 @@
 #include <unistd.h>
 
 #include "mandoc.h"
 #include <unistd.h>
 
 #include "mandoc.h"
+#include "mandoc_aux.h"
 #include "main.h"
 #include "mdoc.h"
 #include "man.h"
 #include "main.h"
 #include "mdoc.h"
 #include "man.h"
@@ -59,9 +60,9 @@ struct        curparse {
        struct mparse    *mp;
        enum mandoclevel  wlevel;       /* ignore messages below this */
        int               wstop;        /* stop after a file with a warning */
        struct mparse    *mp;
        enum mandoclevel  wlevel;       /* ignore messages below this */
        int               wstop;        /* stop after a file with a warning */
-       enum outt         outtype;      /* which output to use */
+       enum outt         outtype;      /* which output to use */
        out_mdoc          outmdoc;      /* mdoc output ptr */
        out_mdoc          outmdoc;      /* mdoc output ptr */
-       out_man           outman;       /* man output ptr */
+       out_man           outman;       /* man output ptr */
        out_free          outfree;      /* free output ptr */
        void             *outdata;      /* data for output */
        char              outopts[BUFSIZ]; /* buf of output opts */
        out_free          outfree;      /* free output ptr */
        void             *outdata;      /* data for output */
        char              outopts[BUFSIZ]; /* buf of output opts */
@@ -70,7 +71,7 @@ struct        curparse {
 static int               moptions(int *, char *);
 static void              mmsg(enum mandocerr, enum mandoclevel,
                                const char *, int, int, const char *);
 static int               moptions(int *, char *);
 static void              mmsg(enum mandocerr, enum mandoclevel,
                                const char *, int, int, const char *);
-static void              parse(struct curparse *, int, 
+static void              parse(struct curparse *, int,
                                const char *, enum mandoclevel *);
 static int               toptions(struct curparse *, char *);
 static void              usage(void) __attribute__((noreturn));
                                const char *, enum mandoclevel *);
 static int               toptions(struct curparse *, char *);
 static void              usage(void) __attribute__((noreturn));
@@ -79,6 +80,7 @@ static        int               woptions(struct curparse *, char *);
 
 static const char       *progname;
 
 
 static const char       *progname;
 
+
 int
 main(int argc, char *argv[])
 {
 int
 main(int argc, char *argv[])
 {
@@ -101,39 +103,40 @@ main(int argc, char *argv[])
        curp.wlevel  = MANDOCLEVEL_FATAL;
        defos = NULL;
 
        curp.wlevel  = MANDOCLEVEL_FATAL;
        defos = NULL;
 
-       /* LINTED */
        while (-1 != (c = getopt(argc, argv, "I:m:O:T:VW:")))
                switch (c) {
        while (-1 != (c = getopt(argc, argv, "I:m:O:T:VW:")))
                switch (c) {
-               case ('I'):
+               case 'I':
                        if (strncmp(optarg, "os=", 3)) {
                        if (strncmp(optarg, "os=", 3)) {
-                               fprintf(stderr, "-I%s: Bad argument\n",
-                                               optarg);
+                               fprintf(stderr,
+                                   "%s: -I%s: Bad argument\n",
+                                   progname, optarg);
                                return((int)MANDOCLEVEL_BADARG);
                        }
                        if (defos) {
                                return((int)MANDOCLEVEL_BADARG);
                        }
                        if (defos) {
-                               fprintf(stderr, "-I%s: Duplicate argument\n",
-                                               optarg);
+                               fprintf(stderr,
+                                   "%s: -I%s: Duplicate argument\n",
+                                   progname, optarg);
                                return((int)MANDOCLEVEL_BADARG);
                        }
                        defos = mandoc_strdup(optarg + 3);
                        break;
                                return((int)MANDOCLEVEL_BADARG);
                        }
                        defos = mandoc_strdup(optarg + 3);
                        break;
-               case ('m'):
+               case 'm':
                        if ( ! moptions(&options, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
                        if ( ! moptions(&options, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
-               case ('O'):
+               case 'O':
                        (void)strlcat(curp.outopts, optarg, BUFSIZ);
                        (void)strlcat(curp.outopts, ",", BUFSIZ);
                        break;
                        (void)strlcat(curp.outopts, optarg, BUFSIZ);
                        (void)strlcat(curp.outopts, ",", BUFSIZ);
                        break;
-               case ('T'):
+               case 'T':
                        if ( ! toptions(&curp, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
                        if ( ! toptions(&curp, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
-               case ('W'):
+               case 'W':
                        if ( ! woptions(&curp, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
                        if ( ! woptions(&curp, optarg))
                                return((int)MANDOCLEVEL_BADARG);
                        break;
-               case ('V'):
+               case 'V':
                        version();
                        /* NOTREACHED */
                default:
                        version();
                        /* NOTREACHED */
                default:
@@ -192,15 +195,15 @@ usage(void)
                        "[-Ooption] "
                        "[-Toutput] "
                        "[-Wlevel]\n"
                        "[-Ooption] "
                        "[-Toutput] "
                        "[-Wlevel]\n"
-                       "\t      [file ...]\n", 
+                       "\t      [file ...]\n",
                        progname);
 
        exit((int)MANDOCLEVEL_BADARG);
 }
 
 static void
                        progname);
 
        exit((int)MANDOCLEVEL_BADARG);
 }
 
 static void
-parse(struct curparse *curp, int fd, 
-               const char *file, enum mandoclevel *level)
+parse(struct curparse *curp, int fd, const char *file,
+       enum mandoclevel *level)
 {
        enum mandoclevel  rc;
        struct mdoc      *mdoc;
 {
        enum mandoclevel  rc;
        struct mdoc      *mdoc;
@@ -230,31 +233,31 @@ parse(struct curparse *curp, int fd,
 
        if ( ! (curp->outman && curp->outmdoc)) {
                switch (curp->outtype) {
 
        if ( ! (curp->outman && curp->outmdoc)) {
                switch (curp->outtype) {
-               case (OUTT_XHTML):
+               case OUTT_XHTML:
                        curp->outdata = xhtml_alloc(curp->outopts);
                        curp->outfree = html_free;
                        break;
                        curp->outdata = xhtml_alloc(curp->outopts);
                        curp->outfree = html_free;
                        break;
-               case (OUTT_HTML):
+               case OUTT_HTML:
                        curp->outdata = html_alloc(curp->outopts);
                        curp->outfree = html_free;
                        break;
                        curp->outdata = html_alloc(curp->outopts);
                        curp->outfree = html_free;
                        break;
-               case (OUTT_UTF8):
+               case OUTT_UTF8:
                        curp->outdata = utf8_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
                        curp->outdata = utf8_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
-               case (OUTT_LOCALE):
+               case OUTT_LOCALE:
                        curp->outdata = locale_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
                        curp->outdata = locale_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
-               case (OUTT_ASCII):
+               case OUTT_ASCII:
                        curp->outdata = ascii_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
                        curp->outdata = ascii_alloc(curp->outopts);
                        curp->outfree = ascii_free;
                        break;
-               case (OUTT_PDF):
+               case OUTT_PDF:
                        curp->outdata = pdf_alloc(curp->outopts);
                        curp->outfree = pspdf_free;
                        break;
                        curp->outdata = pdf_alloc(curp->outopts);
                        curp->outfree = pspdf_free;
                        break;
-               case (OUTT_PS):
+               case OUTT_PS:
                        curp->outdata = ps_alloc(curp->outopts);
                        curp->outfree = pspdf_free;
                        break;
                        curp->outdata = ps_alloc(curp->outopts);
                        curp->outfree = pspdf_free;
                        break;
@@ -263,29 +266,29 @@ parse(struct curparse *curp, int fd,
                }
 
                switch (curp->outtype) {
                }
 
                switch (curp->outtype) {
-               case (OUTT_HTML):
+               case OUTT_HTML:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (OUTT_XHTML):
+               case OUTT_XHTML:
                        curp->outman = html_man;
                        curp->outmdoc = html_mdoc;
                        break;
                        curp->outman = html_man;
                        curp->outmdoc = html_mdoc;
                        break;
-               case (OUTT_TREE):
+               case OUTT_TREE:
                        curp->outman = tree_man;
                        curp->outmdoc = tree_mdoc;
                        break;
                        curp->outman = tree_man;
                        curp->outmdoc = tree_mdoc;
                        break;
-               case (OUTT_MAN):
+               case OUTT_MAN:
                        curp->outmdoc = man_mdoc;
                        curp->outman = man_man;
                        break;
                        curp->outmdoc = man_mdoc;
                        curp->outman = man_man;
                        break;
-               case (OUTT_PDF):
+               case OUTT_PDF:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (OUTT_ASCII):
+               case OUTT_ASCII:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (OUTT_UTF8):
+               case OUTT_UTF8:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (OUTT_LOCALE):
+               case OUTT_LOCALE:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (OUTT_PS):
+               case OUTT_PS:
                        curp->outman = terminal_man;
                        curp->outmdoc = terminal_mdoc;
                        break;
                        curp->outman = terminal_man;
                        curp->outmdoc = terminal_mdoc;
                        break;
@@ -294,7 +297,7 @@ parse(struct curparse *curp, int fd,
                }
        }
 
                }
        }
 
-       mparse_result(curp->mp, &mdoc, &man);
+       mparse_result(curp->mp, &mdoc, &man, NULL);
 
        /* Execute the out device, if it exists. */
 
 
        /* Execute the out device, if it exists. */
 
@@ -322,7 +325,8 @@ moptions(int *options, char *arg)
        else if (0 == strcmp(arg, "an"))
                *options |= MPARSE_MAN;
        else {
        else if (0 == strcmp(arg, "an"))
                *options |= MPARSE_MAN;
        else {
-               fprintf(stderr, "%s: Bad argument\n", arg);
+               fprintf(stderr, "%s: -m%s: Bad argument\n",
+                   progname, arg);
                return(0);
        }
 
                return(0);
        }
 
@@ -355,7 +359,8 @@ toptions(struct curparse *curp, char *arg)
        else if (0 == strcmp(arg, "pdf"))
                curp->outtype = OUTT_PDF;
        else {
        else if (0 == strcmp(arg, "pdf"))
                curp->outtype = OUTT_PDF;
        else {
-               fprintf(stderr, "%s: Bad argument\n", arg);
+               fprintf(stderr, "%s: -T%s: Bad argument\n",
+                   progname, arg);
                return(0);
        }
 
                return(0);
        }
 
@@ -366,7 +371,7 @@ static int
 woptions(struct curparse *curp, char *arg)
 {
        char            *v, *o;
 woptions(struct curparse *curp, char *arg)
 {
        char            *v, *o;
-       const char      *toks[6]; 
+       const char      *toks[6];
 
        toks[0] = "stop";
        toks[1] = "all";
 
        toks[0] = "stop";
        toks[1] = "all";
@@ -378,22 +383,23 @@ woptions(struct curparse *curp, char *arg)
        while (*arg) {
                o = arg;
                switch (getsubopt(&arg, UNCONST(toks), &v)) {
        while (*arg) {
                o = arg;
                switch (getsubopt(&arg, UNCONST(toks), &v)) {
-               case (0):
+               case 0:
                        curp->wstop = 1;
                        break;
                        curp->wstop = 1;
                        break;
-               case (1):
+               case 1:
                        /* FALLTHROUGH */
                        /* FALLTHROUGH */
-               case (2):
+               case 2:
                        curp->wlevel = MANDOCLEVEL_WARNING;
                        break;
                        curp->wlevel = MANDOCLEVEL_WARNING;
                        break;
-               case (3):
+               case 3:
                        curp->wlevel = MANDOCLEVEL_ERROR;
                        break;
                        curp->wlevel = MANDOCLEVEL_ERROR;
                        break;
-               case (4):
+               case 4:
                        curp->wlevel = MANDOCLEVEL_FATAL;
                        break;
                default:
                        curp->wlevel = MANDOCLEVEL_FATAL;
                        break;
                default:
-                       fprintf(stderr, "-W%s: Bad argument\n", o);
+                       fprintf(stderr, "%s: -W%s: Bad argument\n",
+                           progname, o);
                        return(0);
                }
        }
                        return(0);
                }
        }
@@ -402,14 +408,17 @@ woptions(struct curparse *curp, char *arg)
 }
 
 static void
 }
 
 static void
-mmsg(enum mandocerr t, enum mandoclevel lvl, 
+mmsg(enum mandocerr t, enum mandoclevel lvl,
                const char *file, int line, int col, const char *msg)
 {
 
                const char *file, int line, int col, const char *msg)
 {
 
-       fprintf(stderr, "%s:%d:%d: %s: %s", 
-                       file, line, col + 1, 
-                       mparse_strlevel(lvl),
-                       mparse_strerror(t));
+       fprintf(stderr, "%s: %s:", progname, file);
+
+       if (line)
+               fprintf(stderr, "%d:%d:", line, col + 1);
+
+       fprintf(stderr, " %s: %s", mparse_strlevel(lvl),
+           mparse_strerror(t));
 
        if (msg)
                fprintf(stderr, ": %s", msg);
 
        if (msg)
                fprintf(stderr, ": %s", msg);