[BACK]Return to main.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/main.c between version 1.102 and 1.103

version 1.102, 2010/08/08 14:45:59 version 1.103, 2010/08/20 01:02:07
Line 79  enum outt {
Line 79  enum outt {
 struct  curparse {  struct  curparse {
         const char       *file;         /* Current parse. */          const char       *file;         /* Current parse. */
         int               fd;           /* Current parse. */          int               fd;           /* Current parse. */
         int               wflags;          enum mandoclevel  wlevel;       /* Ignore messages below this. */
         /* FIXME: set by max error */          int               wstop;        /* Stop after a file with a warning. */
 #define WARN_WALL        (1 << 0)       /* All-warnings mask. */  
 #define WARN_WERR        (1 << 2)       /* Warnings->errors. */  
         int               fflags;  
 #define FL_IGN_SCOPE     (1 << 0)       /* Ignore scope errors. */  
 #define FL_NIGN_ESCAPE   (1 << 1)       /* Don't ignore bad escapes. */  
 #define FL_NIGN_MACRO    (1 << 2)       /* Don't ignore bad macros. */  
 #define FL_IGN_ERRORS    (1 << 4)       /* Ignore failed parse. */  
 #define FL_STRICT         FL_NIGN_ESCAPE | \  
                           FL_NIGN_MACRO /* ignore nothing */  
         enum intt         inttype;      /* which parser to use */          enum intt         inttype;      /* which parser to use */
         struct man       *man;          /* man parser */          struct man       *man;          /* man parser */
         struct mdoc      *mdoc;         /* mdoc parser */          struct mdoc      *mdoc;         /* mdoc parser */
Line 103  struct curparse {
Line 94  struct curparse {
         char              outopts[BUFSIZ]; /* buf of output opts */          char              outopts[BUFSIZ]; /* buf of output opts */
 };  };
   
   static  const char * const      mandoclevels[MANDOCLEVEL_MAX] = {
           "SUCCESS",
           "RESERVED",
           "WARNING",
           "ERROR",
           "FATAL",
           "BADARG",
           "SYSERR"
   };
   
   static  const enum mandocerr    mandoclimits[MANDOCLEVEL_MAX] = {
           MANDOCERR_OK,
           MANDOCERR_WARNING,
           MANDOCERR_WARNING,
           MANDOCERR_ERROR,
           MANDOCERR_FATAL,
           MANDOCERR_MAX,
           MANDOCERR_MAX
   };
   
 static  const char * const      mandocerrs[MANDOCERR_MAX] = {  static  const char * const      mandocerrs[MANDOCERR_MAX] = {
         "ok",          "ok",
   
Line 179  static const char * const mandocerrs[MANDOCERR_MAX] = 
Line 190  static const char * const mandocerrs[MANDOCERR_MAX] = 
         "no document body",          "no document body",
         "no document prologue",          "no document prologue",
         "utsname system call failed",          "utsname system call failed",
         "memory exhausted",          "static buffer exhausted",
 };  };
   
 static  void              fdesc(struct curparse *);  static  void              fdesc(struct curparse *);
 static  void              ffile(const char *, struct curparse *);  static  void              ffile(const char *, struct curparse *);
 static  int               foptions(int *, char *);  
 static  struct man       *man_init(struct curparse *);  
 static  struct mdoc      *mdoc_init(struct curparse *);  
 static  struct roff      *roff_init(struct curparse *);  
 static  int               moptions(enum intt *, char *);  static  int               moptions(enum intt *, char *);
 static  int               mmsg(enum mandocerr, void *,  static  int               mmsg(enum mandocerr, void *,
                                 int, int, const char *);                                  int, int, const char *);
 static  int               pset(const char *, int, struct curparse *,  static  void              pset(const char *, int, struct curparse *,
                                 struct man **, struct mdoc **);                                  struct man **, struct mdoc **);
 static  int               toptions(struct curparse *, char *);  static  int               toptions(struct curparse *, char *);
 static  void              usage(void) __attribute__((noreturn));  static  void              usage(void) __attribute__((noreturn));
 static  void              version(void) __attribute__((noreturn));  static  void              version(void) __attribute__((noreturn));
 static  int               woptions(int *, char *);  static  int               woptions(struct curparse *, char *);
   
 static  const char       *progname;  static  const char       *progname;
 static  int               with_fatal;  static  enum mandoclevel  exit_status = MANDOCLEVEL_OK;
 static  int               with_error;  
   
 int  int
 main(int argc, char *argv[])  main(int argc, char *argv[])
Line 218  main(int argc, char *argv[])
Line 224  main(int argc, char *argv[])
   
         curp.inttype = INTT_AUTO;          curp.inttype = INTT_AUTO;
         curp.outtype = OUTT_ASCII;          curp.outtype = OUTT_ASCII;
           curp.wlevel  = MANDOCLEVEL_FATAL;
   
         /* LINTED */          /* LINTED */
         while (-1 != (c = getopt(argc, argv, "f:m:O:T:VW:")))          while (-1 != (c = getopt(argc, argv, "m:O:T:VW:")))
                 switch (c) {                  switch (c) {
                 case ('f'):  
                         if ( ! foptions(&curp.fflags, optarg))  
                                 return(EXIT_FAILURE);  
                         break;  
                 case ('m'):                  case ('m'):
                         if ( ! moptions(&curp.inttype, optarg))                          if ( ! moptions(&curp.inttype, optarg))
                                 return(EXIT_FAILURE);                                  return(MANDOCLEVEL_BADARG);
                         break;                          break;
                 case ('O'):                  case ('O'):
                         (void)strlcat(curp.outopts, optarg, BUFSIZ);                          (void)strlcat(curp.outopts, optarg, BUFSIZ);
Line 236  main(int argc, char *argv[])
Line 239  main(int argc, char *argv[])
                         break;                          break;
                 case ('T'):                  case ('T'):
                         if ( ! toptions(&curp, optarg))                          if ( ! toptions(&curp, optarg))
                                 return(EXIT_FAILURE);                                  return(MANDOCLEVEL_BADARG);
                         break;                          break;
                 case ('W'):                  case ('W'):
                         if ( ! woptions(&curp.wflags, optarg))                          if ( ! woptions(&curp, optarg))
                                 return(EXIT_FAILURE);                                  return(MANDOCLEVEL_BADARG);
                         break;                          break;
                 case ('V'):                  case ('V'):
                         version();                          version();
Line 262  main(int argc, char *argv[])
Line 265  main(int argc, char *argv[])
   
         while (*argv) {          while (*argv) {
                 ffile(*argv, &curp);                  ffile(*argv, &curp);
                   if (MANDOCLEVEL_OK != exit_status && curp.wstop)
                 if (with_fatal && !(curp.fflags & FL_IGN_ERRORS))  
                         break;                          break;
                 ++argv;                  ++argv;
         }          }
Line 277  main(int argc, char *argv[])
Line 279  main(int argc, char *argv[])
         if (curp.roff)          if (curp.roff)
                 roff_free(curp.roff);                  roff_free(curp.roff);
   
         return((with_fatal || with_error) ?          return(exit_status);
                         EXIT_FAILURE :  EXIT_SUCCESS);  
 }  }
   
   
Line 287  version(void)
Line 288  version(void)
 {  {
   
         (void)printf("%s %s\n", progname, VERSION);          (void)printf("%s %s\n", progname, VERSION);
         exit(EXIT_SUCCESS);          exit(MANDOCLEVEL_OK);
 }  }
   
   
Line 298  usage(void)
Line 299  usage(void)
         (void)fprintf(stderr, "usage: %s [-V] [-foption] "          (void)fprintf(stderr, "usage: %s [-V] [-foption] "
                         "[-mformat] [-Ooption] [-Toutput] "                          "[-mformat] [-Ooption] [-Toutput] "
                         "[-Werr] [file...]\n", progname);                          "[-Werr] [file...]\n", progname);
         exit(EXIT_FAILURE);          exit(MANDOCLEVEL_BADARG);
 }  }
   
   
 static struct man *  
 man_init(struct curparse *curp)  
 {  
         int              pflags;  
   
         /* Defaults from mandoc.1. */  
   
         pflags = MAN_IGN_MACRO | MAN_IGN_ESCAPE;  
   
         if (curp->fflags & FL_NIGN_MACRO)  
                 pflags &= ~MAN_IGN_MACRO;  
         if (curp->fflags & FL_NIGN_ESCAPE)  
                 pflags &= ~MAN_IGN_ESCAPE;  
   
         return(man_alloc(&curp->regs, curp, pflags, mmsg));  
 }  
   
   
 static struct roff *  
 roff_init(struct curparse *curp)  
 {  
   
         return(roff_alloc(&curp->regs, mmsg, curp));  
 }  
   
   
 static struct mdoc *  
 mdoc_init(struct curparse *curp)  
 {  
         int              pflags;  
   
         /* Defaults from mandoc.1. */  
   
         pflags = MDOC_IGN_MACRO | MDOC_IGN_ESCAPE;  
   
         if (curp->fflags & FL_IGN_SCOPE)  
                 pflags |= MDOC_IGN_SCOPE;  
         if (curp->fflags & FL_NIGN_ESCAPE)  
                 pflags &= ~MDOC_IGN_ESCAPE;  
         if (curp->fflags & FL_NIGN_MACRO)  
                 pflags &= ~MDOC_IGN_MACRO;  
   
         return(mdoc_alloc(&curp->regs, curp, pflags, mmsg));  
 }  
   
   
 static void  static void
 ffile(const char *file, struct curparse *curp)  ffile(const char *file, struct curparse *curp)
 {  {
Line 355  ffile(const char *file, struct curparse *curp)
Line 310  ffile(const char *file, struct curparse *curp)
         curp->file = file;          curp->file = file;
         if (-1 == (curp->fd = open(curp->file, O_RDONLY, 0))) {          if (-1 == (curp->fd = open(curp->file, O_RDONLY, 0))) {
                 perror(curp->file);                  perror(curp->file);
                 with_fatal = 1;                  exit_status = MANDOCLEVEL_SYSERR;
                 return;                  return;
         }          }
   
Line 366  ffile(const char *file, struct curparse *curp)
Line 321  ffile(const char *file, struct curparse *curp)
 }  }
   
   
 static int  static void
 resize_buf(struct buf *buf, size_t initial)  resize_buf(struct buf *buf, size_t initial)
 {  {
         void *tmp;  
         size_t sz;  
   
         if (buf->sz == 0)          buf->sz = buf->sz ? 2 * buf->sz : initial;
                 sz = initial;          buf->buf = realloc(buf->buf, buf->sz);
         else          if (NULL == buf->buf) {
                 sz = 2 * buf->sz;  
         tmp = realloc(buf->buf, sz);  
         if (NULL == tmp) {  
                 perror(NULL);                  perror(NULL);
                 return(0);                  exit(MANDOCLEVEL_SYSERR);
         }          }
         buf->buf = tmp;  
         buf->sz = sz;  
         return(1);  
 }  }
   
   
Line 396  read_whole_file(struct curparse *curp, struct buf *fb,
Line 343  read_whole_file(struct curparse *curp, struct buf *fb,
   
         if (-1 == fstat(curp->fd, &st)) {          if (-1 == fstat(curp->fd, &st)) {
                 perror(curp->file);                  perror(curp->file);
                 with_fatal = 1;  
                 return(0);                  return(0);
         }          }
   
Line 411  read_whole_file(struct curparse *curp, struct buf *fb,
Line 357  read_whole_file(struct curparse *curp, struct buf *fb,
                 if (st.st_size >= (1U << 31)) {                  if (st.st_size >= (1U << 31)) {
                         fprintf(stderr, "%s: input too large\n",                          fprintf(stderr, "%s: input too large\n",
                                         curp->file);                                          curp->file);
                         with_fatal = 1;  
                         return(0);                          return(0);
                 }                  }
                 *with_mmap = 1;                  *with_mmap = 1;
Line 438  read_whole_file(struct curparse *curp, struct buf *fb,
Line 383  read_whole_file(struct curparse *curp, struct buf *fb,
                                                 curp->file);                                                  curp->file);
                                 break;                                  break;
                         }                          }
                         if (! resize_buf(fb, 65536))                          resize_buf(fb, 65536);
                                 break;  
                 }                  }
                 ssz = read(curp->fd, fb->buf + (int)off, fb->sz - off);                  ssz = read(curp->fd, fb->buf + (int)off, fb->sz - off);
                 if (ssz == 0) {                  if (ssz == 0) {
Line 455  read_whole_file(struct curparse *curp, struct buf *fb,
Line 399  read_whole_file(struct curparse *curp, struct buf *fb,
   
         free(fb->buf);          free(fb->buf);
         fb->buf = NULL;          fb->buf = NULL;
         with_fatal = 1;  
         return(0);          return(0);
 }  }
   
Line 482  fdesc(struct curparse *curp)
Line 425  fdesc(struct curparse *curp)
          * memory mapped.  ln is a line buffer and grows on-demand.           * memory mapped.  ln is a line buffer and grows on-demand.
          */           */
   
         if ( ! read_whole_file(curp, &blk, &with_mmap))          if ( ! read_whole_file(curp, &blk, &with_mmap)) {
                   exit_status = MANDOCLEVEL_SYSERR;
                 return;                  return;
           }
   
         if (NULL == curp->roff)          if (NULL == curp->roff)
                 curp->roff = roff_init(curp);                  curp->roff = roff_alloc(&curp->regs, curp, mmsg);
         if (NULL == (roff = curp->roff))          assert(curp->roff);
                 goto bailout;          roff = curp->roff;
   
         for (i = 0, lnn = 1; i < (int)blk.sz;) {          for (i = 0, lnn = 1; i < (int)blk.sz;) {
                 pos = 0;                  pos = 0;
Line 511  fdesc(struct curparse *curp)
Line 456  fdesc(struct curparse *curp)
   
                         c = (unsigned char) blk.buf[i];                          c = (unsigned char) blk.buf[i];
                         if ( ! (isascii(c) && (isgraph(c) || isblank(c)))) {                          if ( ! (isascii(c) && (isgraph(c) || isblank(c)))) {
                                 if ( ! mmsg(MANDOCERR_BADCHAR, curp,                                  mmsg(MANDOCERR_BADCHAR, curp,
                                                 lnn_start, pos,                                      lnn_start, pos, "ignoring byte");
                                                 "ignoring byte"))  
                                         goto bailout;  
                                 i++;                                  i++;
                                 continue;                                  continue;
                         }                          }
Line 522  fdesc(struct curparse *curp)
Line 465  fdesc(struct curparse *curp)
                         /* Trailing backslash is like a plain character. */                          /* Trailing backslash is like a plain character. */
                         if ('\\' != blk.buf[i] || i + 1 == (int)blk.sz) {                          if ('\\' != blk.buf[i] || i + 1 == (int)blk.sz) {
                                 if (pos >= (int)ln.sz)                                  if (pos >= (int)ln.sz)
                                         if (! resize_buf(&ln, 256))                                          resize_buf(&ln, 256);
                                                 goto bailout;  
                                 ln.buf[pos++] = blk.buf[i++];                                  ln.buf[pos++] = blk.buf[i++];
                                 continue;                                  continue;
                         }                          }
Line 555  fdesc(struct curparse *curp)
Line 497  fdesc(struct curparse *curp)
                         }                          }
                         /* Some other escape sequence, copy and continue. */                          /* Some other escape sequence, copy and continue. */
                         if (pos + 1 >= (int)ln.sz)                          if (pos + 1 >= (int)ln.sz)
                                 if (! resize_buf(&ln, 256))                                  resize_buf(&ln, 256);
                                         goto bailout;  
   
                         ln.buf[pos++] = blk.buf[i++];                          ln.buf[pos++] = blk.buf[i++];
                         ln.buf[pos++] = blk.buf[i++];                          ln.buf[pos++] = blk.buf[i++];
                 }                  }
   
                 if (pos >= (int)ln.sz)                  if (pos >= (int)ln.sz)
                         if (! resize_buf(&ln, 256))                          resize_buf(&ln, 256);
                                 goto bailout;  
                 ln.buf[pos] = '\0';                  ln.buf[pos] = '\0';
   
                 /*                  /*
Line 582  fdesc(struct curparse *curp)
Line 522  fdesc(struct curparse *curp)
                                         &ln.buf, &ln.sz, of, &of);                                          &ln.buf, &ln.sz, of, &of);
                 } while (ROFF_RERUN == re);                  } while (ROFF_RERUN == re);
   
                 if (ROFF_IGN == re)                  if (ROFF_IGN == re) {
                         continue;                          continue;
                 else if (ROFF_ERR == re)                  } else if (ROFF_ERR == re) {
                         goto bailout;                          assert(MANDOCLEVEL_FATAL <= exit_status);
                           goto cleanup;
                   }
   
                 /*                  /*
                  * If input parsers have not been allocated, do so now.                   * If input parsers have not been allocated, do so now.
Line 595  fdesc(struct curparse *curp)
Line 537  fdesc(struct curparse *curp)
                  */                   */
   
                 if ( ! (man || mdoc))                  if ( ! (man || mdoc))
                         if ( ! pset(ln.buf + of, pos - of, curp, &man, &mdoc))                          pset(ln.buf + of, pos - of, curp, &man, &mdoc);
                                 goto bailout;  
   
                 /* Lastly, push down into the parsers themselves. */                  /* Lastly, push down into the parsers themselves. */
   
                 if (man && ! man_parseln(man, lnn_start, ln.buf, of))                  if (man && ! man_parseln(man, lnn_start, ln.buf, of)) {
                         goto bailout;                          assert(MANDOCLEVEL_FATAL <= exit_status);
                 if (mdoc && ! mdoc_parseln(mdoc, lnn_start, ln.buf, of))                          goto cleanup;
                         goto bailout;                  }
                   if (mdoc && ! mdoc_parseln(mdoc, lnn_start, ln.buf, of)) {
                           assert(MANDOCLEVEL_FATAL <= exit_status);
                           goto cleanup;
                   }
         }          }
   
           /*
            * With -Wstop and warnings or errors of at least
            * the requested level, do not produce output.
            */
   
           if (MANDOCLEVEL_OK != exit_status && curp->wstop)
                   goto cleanup;
   
         /* NOTE a parser may not have been assigned, yet. */          /* NOTE a parser may not have been assigned, yet. */
   
         if ( ! (man || mdoc)) {          if ( ! (man || mdoc)) {
                 fprintf(stderr, "%s: Not a manual\n", curp->file);                  fprintf(stderr, "%s: Not a manual\n", curp->file);
                 goto bailout;                  exit_status = MANDOCLEVEL_FATAL;
                   goto cleanup;
         }          }
   
         /* Clean up the parse routine ASTs. */          /* Clean up the parse routine ASTs. */
   
         if (mdoc && ! mdoc_endparse(mdoc))          if (mdoc && ! mdoc_endparse(mdoc)) {
                 goto bailout;                  assert(MANDOCLEVEL_FATAL <= exit_status);
         if (man && ! man_endparse(man))                  goto cleanup;
                 goto bailout;          }
         if (roff && ! roff_endparse(roff))          if (man && ! man_endparse(man)) {
                 goto bailout;                  assert(MANDOCLEVEL_FATAL <= exit_status);
                   goto cleanup;
           }
           if (roff && ! roff_endparse(roff)) {
                   assert(MANDOCLEVEL_FATAL <= exit_status);
                   goto cleanup;
           }
   
         /* If unset, allocate output dev now (if applicable). */          /* If unset, allocate output dev now (if applicable). */
   
Line 696  fdesc(struct curparse *curp)
Line 656  fdesc(struct curparse *curp)
                 free(blk.buf);                  free(blk.buf);
   
         return;          return;
   
  bailout:  
         with_fatal = 1;  
         goto cleanup;  
 }  }
   
   
 static int  static void
 pset(const char *buf, int pos, struct curparse *curp,  pset(const char *buf, int pos, struct curparse *curp,
                 struct man **man, struct mdoc **mdoc)                  struct man **man, struct mdoc **mdoc)
 {  {
Line 721  pset(const char *buf, int pos, struct curparse *curp,
Line 677  pset(const char *buf, int pos, struct curparse *curp,
                 for (i = 1; buf[i]; i++)                  for (i = 1; buf[i]; i++)
                         if (' ' != buf[i] && '\t' != buf[i])                          if (' ' != buf[i] && '\t' != buf[i])
                                 break;                                  break;
                 if (0 == buf[i])                  if ('\0' == buf[i])
                         return(1);                          return;
         }          }
   
         switch (curp->inttype) {          switch (curp->inttype) {
         case (INTT_MDOC):          case (INTT_MDOC):
                 if (NULL == curp->mdoc)                  if (NULL == curp->mdoc)
                         curp->mdoc = mdoc_init(curp);                          curp->mdoc = mdoc_alloc(&curp->regs, curp, mmsg);
                 if (NULL == (*mdoc = curp->mdoc))                  assert(curp->mdoc);
                         return(0);                  *mdoc = curp->mdoc;
                 return(1);                  return;
         case (INTT_MAN):          case (INTT_MAN):
                 if (NULL == curp->man)                  if (NULL == curp->man)
                         curp->man = man_init(curp);                          curp->man = man_alloc(&curp->regs, curp, mmsg);
                 if (NULL == (*man = curp->man))                  assert(curp->man);
                         return(0);                  *man = curp->man;
                 return(1);                  return;
         default:          default:
                 break;                  break;
         }          }
   
         if (pos >= 3 && 0 == memcmp(buf, ".Dd", 3))  {          if (pos >= 3 && 0 == memcmp(buf, ".Dd", 3))  {
                 if (NULL == curp->mdoc)                  if (NULL == curp->mdoc)
                         curp->mdoc = mdoc_init(curp);                          curp->mdoc = mdoc_alloc(&curp->regs, curp, mmsg);
                 if (NULL == (*mdoc = curp->mdoc))                  assert(curp->mdoc);
                         return(0);                  *mdoc = curp->mdoc;
                 return(1);                  return;
         }          }
   
         if (NULL == curp->man)          if (NULL == curp->man)
                 curp->man = man_init(curp);                  curp->man = man_alloc(&curp->regs, curp, mmsg);
         if (NULL == (*man = curp->man))          assert(curp->man);
                 return(0);          *man = curp->man;
         return(1);  
 }  }
   
   
Line 785  toptions(struct curparse *curp, char *arg)
Line 740  toptions(struct curparse *curp, char *arg)
                 curp->outtype = OUTT_ASCII;                  curp->outtype = OUTT_ASCII;
         else if (0 == strcmp(arg, "lint")) {          else if (0 == strcmp(arg, "lint")) {
                 curp->outtype = OUTT_LINT;                  curp->outtype = OUTT_LINT;
                 curp->wflags |= WARN_WALL;                  curp->wlevel  = MANDOCLEVEL_WARNING;
                 curp->fflags |= FL_STRICT;  
         }          }
         else if (0 == strcmp(arg, "tree"))          else if (0 == strcmp(arg, "tree"))
                 curp->outtype = OUTT_TREE;                  curp->outtype = OUTT_TREE;
Line 808  toptions(struct curparse *curp, char *arg)
Line 762  toptions(struct curparse *curp, char *arg)
   
   
 static int  static int
 foptions(int *fflags, char *arg)  woptions(struct curparse *curp, char *arg)
 {  {
         char            *v, *o;          char            *v, *o;
         const char      *toks[8];          const char      *toks[6];
   
         toks[0] = "ign-scope";          toks[0] = "stop";
         toks[1] = "no-ign-escape";          toks[1] = "all";
         toks[2] = "no-ign-macro";          toks[2] = "warning";
         toks[3] = "ign-errors";          toks[3] = "error";
         toks[4] = "strict";          toks[4] = "fatal";
         toks[5] = "ign-escape";          toks[5] = NULL;
         toks[6] = NULL;  
   
         while (*arg) {          while (*arg) {
                 o = arg;                  o = arg;
                 switch (getsubopt(&arg, UNCONST(toks), &v)) {                  switch (getsubopt(&arg, UNCONST(toks), &v)) {
                 case (0):                  case (0):
                         *fflags |= FL_IGN_SCOPE;                          curp->wstop = 1;
                         break;                          break;
                 case (1):                  case (1):
                         *fflags |= FL_NIGN_ESCAPE;                          /* FALLTHROUGH */
                         break;  
                 case (2):                  case (2):
                         *fflags |= FL_NIGN_MACRO;                          curp->wlevel = MANDOCLEVEL_WARNING;
                         break;                          break;
                 case (3):                  case (3):
                         *fflags |= FL_IGN_ERRORS;                          curp->wlevel = MANDOCLEVEL_ERROR;
                         break;                          break;
                 case (4):                  case (4):
                         *fflags |= FL_STRICT;                          curp->wlevel = MANDOCLEVEL_FATAL;
                         break;                          break;
                 case (5):  
                         *fflags &= ~FL_NIGN_ESCAPE;  
                         break;  
                 default:                  default:
                         fprintf(stderr, "%s: Bad argument\n", o);                          fprintf(stderr, "-W%s: Bad argument\n", o);
                         return(0);                          return(0);
                 }                  }
         }          }
Line 853  foptions(int *fflags, char *arg)
Line 802  foptions(int *fflags, char *arg)
   
   
 static int  static int
 woptions(int *wflags, char *arg)  
 {  
         char            *v, *o;  
         const char      *toks[3];  
   
         toks[0] = "all";  
         toks[1] = "error";  
         toks[2] = NULL;  
   
         while (*arg) {  
                 o = arg;  
                 switch (getsubopt(&arg, UNCONST(toks), &v)) {  
                 case (0):  
                         *wflags |= WARN_WALL;  
                         break;  
                 case (1):  
                         *wflags |= WARN_WERR;  
                         break;  
                 default:  
                         fprintf(stderr, "%s: Bad argument\n", o);  
                         return(0);  
                 }  
         }  
   
         return(1);  
 }  
   
   
 static int  
 mmsg(enum mandocerr t, void *arg, int ln, int col, const char *msg)  mmsg(enum mandocerr t, void *arg, int ln, int col, const char *msg)
 {  {
         struct curparse *cp;          struct curparse *cp;
         const char *level;          enum mandoclevel level;
         int rc;  
   
           level = MANDOCLEVEL_FATAL;
           while (t < mandoclimits[level])
                   level--;
   
         cp = (struct curparse *)arg;          cp = (struct curparse *)arg;
         level = NULL;          if (level < cp->wlevel)
         rc = 1;                  return(1);
   
         if (t >= MANDOCERR_FATAL) {          fprintf(stderr, "%s:%d:%d: %s: %s",
                 with_fatal = 1;              cp->file, ln, col + 1, mandoclevels[level], mandocerrs[t]);
                 level = "FATAL";  
                 rc = 0;  
         } else {  
                 if ( ! (WARN_WALL & cp->wflags))  
                         return(1);  
                 if (t >= MANDOCERR_ERROR) {  
                         with_error = 1;  
                         level = "ERROR";  
                 }  
                 if (WARN_WERR & cp->wflags) {  
                         with_fatal = 1;  
                         rc = 0;  
                 }  
         }  
   
         fprintf(stderr, "%s:%d:%d:", cp->file, ln, col + 1);  
         if (level)  
                 fprintf(stderr, " %s:", level);  
         fprintf(stderr, " %s", mandocerrs[t]);  
         if (msg)          if (msg)
                 fprintf(stderr, ": %s", msg);                  fprintf(stderr, ": %s", msg);
         fputc('\n', stderr);          fputc('\n', stderr);
   
         return(rc);          if (exit_status < level)
                   exit_status = level;
   
           return(level < MANDOCLEVEL_FATAL);
 }  }

Legend:
Removed from v.1.102  
changed lines
  Added in v.1.103

CVSweb