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

Diff for /mandoc/mdoc_validate.c between version 1.319 and 1.320

version 1.319, 2017/03/06 17:26:04 version 1.320, 2017/04/24 23:06:18
Line 57  static void  check_argv(struct roff_man *,
Line 57  static void  check_argv(struct roff_man *,
                         struct roff_node *, struct mdoc_argv *);                          struct roff_node *, struct mdoc_argv *);
 static  void     check_args(struct roff_man *, struct roff_node *);  static  void     check_args(struct roff_man *, struct roff_node *);
 static  int      child_an(const struct roff_node *);  static  int      child_an(const struct roff_node *);
 static  size_t          macro2len(int);  static  size_t          macro2len(enum roff_tok);
 static  void     rewrite_macro2len(char **);  static  void     rewrite_macro2len(char **);
   
 static  void     post_an(POST_ARGS);  static  void     post_an(POST_ARGS);
Line 108  static void  post_std(POST_ARGS);
Line 108  static void  post_std(POST_ARGS);
 static  void     post_xr(POST_ARGS);  static  void     post_xr(POST_ARGS);
 static  void     post_xx(POST_ARGS);  static  void     post_xx(POST_ARGS);
   
 static  v_post mdoc_valids[MDOC_MAX] = {  static  const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] = {
         NULL,           /* Ap */  
         post_dd,        /* Dd */          post_dd,        /* Dd */
         post_dt,        /* Dt */          post_dt,        /* Dt */
         post_os,        /* Os */          post_os,        /* Os */
Line 125  static v_post mdoc_valids[MDOC_MAX] = {
Line 124  static v_post mdoc_valids[MDOC_MAX] = {
         post_it,        /* It */          post_it,        /* It */
         NULL,           /* Ad */          NULL,           /* Ad */
         post_an,        /* An */          post_an,        /* An */
           NULL,           /* Ap */
         post_defaults,  /* Ar */          post_defaults,  /* Ar */
         NULL,           /* Cd */          NULL,           /* Cd */
         NULL,           /* Cm */          NULL,           /* Cm */
Line 233  static v_post mdoc_valids[MDOC_MAX] = {
Line 233  static v_post mdoc_valids[MDOC_MAX] = {
         NULL,           /* Ta */          NULL,           /* Ta */
         NULL,           /* ll */          NULL,           /* ll */
 };  };
   static  const v_post *const mdoc_valids = __mdoc_valids - MDOC_Dd;
   
 #define RSORD_MAX 14 /* Number of `Rs' blocks. */  #define RSORD_MAX 14 /* Number of `Rs' blocks. */
   
 static  const int rsord[RSORD_MAX] = {  static  const enum roff_tok rsord[RSORD_MAX] = {
         MDOC__A,          MDOC__A,
         MDOC__T,          MDOC__T,
         MDOC__B,          MDOC__B,
Line 284  void
Line 285  void
 mdoc_node_validate(struct roff_man *mdoc)  mdoc_node_validate(struct roff_man *mdoc)
 {  {
         struct roff_node *n;          struct roff_node *n;
         v_post *p;          const v_post *p;
   
         n = mdoc->last;          n = mdoc->last;
         mdoc->last = mdoc->last->child;          mdoc->last = mdoc->last->child;
Line 661  post_eoln(POST_ARGS)
Line 662  post_eoln(POST_ARGS)
   
         n = mdoc->last;          n = mdoc->last;
         if (n->child != NULL)          if (n->child != NULL)
                 mandoc_vmsg(MANDOCERR_ARG_SKIP, mdoc->parse,                  mandoc_vmsg(MANDOCERR_ARG_SKIP, mdoc->parse, n->line,
                     n->line, n->pos, "%s %s",                      n->pos, "%s %s", roff_name[n->tok], n->child->string);
                     mdoc_macronames[n->tok], n->child->string);  
   
         while (n->child != NULL)          while (n->child != NULL)
                 roff_node_delete(mdoc, n->child);                  roff_node_delete(mdoc, n->child);
Line 817  post_std(POST_ARGS)
Line 817  post_std(POST_ARGS)
                         return;                          return;
   
         mandoc_msg(MANDOCERR_ARG_STD, mdoc->parse,          mandoc_msg(MANDOCERR_ARG_STD, mdoc->parse,
             n->line, n->pos, mdoc_macronames[n->tok]);              n->line, n->pos, roff_name[n->tok]);
 }  }
   
 static void  static void
Line 852  post_obsolete(POST_ARGS)
Line 852  post_obsolete(POST_ARGS)
         n = mdoc->last;          n = mdoc->last;
         if (n->type == ROFFT_ELEM || n->type == ROFFT_BLOCK)          if (n->type == ROFFT_ELEM || n->type == ROFFT_BLOCK)
                 mandoc_msg(MANDOCERR_MACRO_OBS, mdoc->parse,                  mandoc_msg(MANDOCERR_MACRO_OBS, mdoc->parse,
                     n->line, n->pos, mdoc_macronames[n->tok]);                      n->line, n->pos, roff_name[n->tok]);
 }  }
   
 /*  /*
Line 1060  post_display(POST_ARGS)
Line 1060  post_display(POST_ARGS)
                                 roff_node_delete(mdoc, n);                                  roff_node_delete(mdoc, n);
                 } else if (n->child == NULL)                  } else if (n->child == NULL)
                         mandoc_msg(MANDOCERR_BLK_EMPTY, mdoc->parse,                          mandoc_msg(MANDOCERR_BLK_EMPTY, mdoc->parse,
                             n->line, n->pos, mdoc_macronames[n->tok]);                              n->line, n->pos, roff_name[n->tok]);
                 else if (n->tok == MDOC_D1)                  else if (n->tok == MDOC_D1)
                         post_hyph(mdoc);                          post_hyph(mdoc);
                 break;                  break;
Line 1083  post_display(POST_ARGS)
Line 1083  post_display(POST_ARGS)
                         if (np->type == ROFFT_BLOCK && np->tok == MDOC_Bd) {                          if (np->type == ROFFT_BLOCK && np->tok == MDOC_Bd) {
                                 mandoc_vmsg(MANDOCERR_BD_NEST,                                  mandoc_vmsg(MANDOCERR_BD_NEST,
                                     mdoc->parse, n->line, n->pos,                                      mdoc->parse, n->line, n->pos,
                                     "%s in Bd", mdoc_macronames[n->tok]);                                      "%s in Bd", roff_name[n->tok]);
                                 break;                                  break;
                         }                          }
                 }                  }
Line 1269  post_it(POST_ARGS)
Line 1269  post_it(POST_ARGS)
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case LIST_item:          case LIST_item:
                 if ((nch = nit->head->child) != NULL)                  if ((nch = nit->head->child) != NULL)
                         mandoc_vmsg(MANDOCERR_ARG_SKIP,                          mandoc_vmsg(MANDOCERR_ARG_SKIP, mdoc->parse,
                             mdoc->parse, nit->line, nit->pos,                              nit->line, nit->pos, "It %s",
                             "It %s", nch->string == NULL ?                              nch->string == NULL ? roff_name[nch->tok] :
                             mdoc_macronames[nch->tok] : nch->string);                              nch->string);
                 break;                  break;
         case LIST_column:          case LIST_column:
                 cols = (int)nbl->norm->Bl.ncols;                  cols = (int)nbl->norm->Bl.ncols;
Line 1319  post_bl_block(POST_ARGS)
Line 1319  post_bl_block(POST_ARGS)
                         if (ni->next == NULL) {                          if (ni->next == NULL) {
                                 mandoc_msg(MANDOCERR_PAR_MOVE,                                  mandoc_msg(MANDOCERR_PAR_MOVE,
                                     mdoc->parse, nc->line, nc->pos,                                      mdoc->parse, nc->line, nc->pos,
                                     mdoc_macronames[nc->tok]);                                      roff_name[nc->tok]);
                                 mdoc_node_relink(mdoc, nc);                                  mdoc_node_relink(mdoc, nc);
                         } else if (n->norm->Bl.comp == 0 &&                          } else if (n->norm->Bl.comp == 0 &&
                             n->norm->Bl.type != LIST_column) {                              n->norm->Bl.type != LIST_column) {
                                 mandoc_vmsg(MANDOCERR_PAR_SKIP,                                  mandoc_vmsg(MANDOCERR_PAR_SKIP,
                                     mdoc->parse, nc->line, nc->pos,                                      mdoc->parse, nc->line, nc->pos,
                                     "%s before It",                                      "%s before It", roff_name[nc->tok]);
                                     mdoc_macronames[nc->tok]);  
                                 roff_node_delete(mdoc, nc);                                  roff_node_delete(mdoc, nc);
                         } else                          } else
                                 break;                                  break;
Line 1343  void
Line 1342  void
 rewrite_macro2len(char **arg)  rewrite_macro2len(char **arg)
 {  {
         size_t            width;          size_t            width;
         int               tok;          enum roff_tok     tok;
   
         if (*arg == NULL)          if (*arg == NULL)
                 return;                  return;
Line 1490  post_bl(POST_ARGS)
Line 1489  post_bl(POST_ARGS)
                 }                  }
   
                 mandoc_msg(MANDOCERR_BL_MOVE, mdoc->parse,                  mandoc_msg(MANDOCERR_BL_MOVE, mdoc->parse,
                     nchild->line, nchild->pos,                      nchild->line, nchild->pos, roff_name[nchild->tok]);
                     mdoc_macronames[nchild->tok]);  
   
                 /*                  /*
                  * Move the node out of the Bl block.                   * Move the node out of the Bl block.
Line 1569  post_sm(POST_ARGS)
Line 1567  post_sm(POST_ARGS)
   
         mandoc_vmsg(MANDOCERR_SM_BAD,          mandoc_vmsg(MANDOCERR_SM_BAD,
             mdoc->parse, nch->line, nch->pos,              mdoc->parse, nch->line, nch->pos,
             "%s %s", mdoc_macronames[mdoc->last->tok], nch->string);              "%s %s", roff_name[mdoc->last->tok], nch->string);
         mdoc_node_relink(mdoc, nch);          mdoc_node_relink(mdoc, nch);
         return;          return;
 }  }
Line 1612  post_root(POST_ARGS)
Line 1610  post_root(POST_ARGS)
                 mandoc_msg(MANDOCERR_DOC_EMPTY, mdoc->parse, 0, 0, NULL);                  mandoc_msg(MANDOCERR_DOC_EMPTY, mdoc->parse, 0, 0, NULL);
         else if (n->tok != MDOC_Sh)          else if (n->tok != MDOC_Sh)
                 mandoc_msg(MANDOCERR_SEC_BEFORE, mdoc->parse,                  mandoc_msg(MANDOCERR_SEC_BEFORE, mdoc->parse,
                     n->line, n->pos, mdoc_macronames[n->tok]);                      n->line, n->pos, roff_name[n->tok]);
 }  }
   
 static void  static void
Line 1646  post_rs(POST_ARGS)
Line 1644  post_rs(POST_ARGS)
                                 break;                                  break;
   
                 if (i == RSORD_MAX) {                  if (i == RSORD_MAX) {
                         mandoc_msg(MANDOCERR_RS_BAD,                          mandoc_msg(MANDOCERR_RS_BAD, mdoc->parse,
                             mdoc->parse, nch->line, nch->pos,                              nch->line, nch->pos, roff_name[nch->tok]);
                             mdoc_macronames[nch->tok]);  
                         i = -1;                          i = -1;
                 } else if (nch->tok == MDOC__J || nch->tok == MDOC__B)                  } else if (nch->tok == MDOC__J || nch->tok == MDOC__B)
                         np->norm->Rs.quote_T++;                          np->norm->Rs.quote_T++;
Line 1801  post_sh_name(POST_ARGS)
Line 1798  post_sh_name(POST_ARGS)
                         /* FALLTHROUGH */                          /* FALLTHROUGH */
                 default:                  default:
                         mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,                          mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,
                             n->line, n->pos, mdoc_macronames[n->tok]);                              n->line, n->pos, roff_name[n->tok]);
                         continue;                          continue;
                 }                  }
                 break;                  break;
Line 1922  post_sh_head(POST_ARGS)
Line 1919  post_sh_head(POST_ARGS)
                     sec != SEC_CUSTOM ? secnames[sec] :                      sec != SEC_CUSTOM ? secnames[sec] :
                     (nch = mdoc->last->child) == NULL ? "" :                      (nch = mdoc->last->child) == NULL ? "" :
                     nch->type == ROFFT_TEXT ? nch->string :                      nch->type == ROFFT_TEXT ? nch->string :
                     mdoc_macronames[nch->tok]);                      roff_name[nch->tok]);
   
         /* The SYNOPSIS gets special attention in other areas. */          /* The SYNOPSIS gets special attention in other areas. */
   
Line 2031  post_ignpar(POST_ARGS)
Line 2028  post_ignpar(POST_ARGS)
                 if (np->tok == MDOC_Pp || np->tok == MDOC_Lp) {                  if (np->tok == MDOC_Pp || np->tok == MDOC_Lp) {
                         mandoc_vmsg(MANDOCERR_PAR_SKIP,                          mandoc_vmsg(MANDOCERR_PAR_SKIP,
                             mdoc->parse, np->line, np->pos,                              mdoc->parse, np->line, np->pos,
                             "%s after %s", mdoc_macronames[np->tok],                              "%s after %s", roff_name[np->tok],
                             mdoc_macronames[mdoc->last->tok]);                              roff_name[mdoc->last->tok]);
                         roff_node_delete(mdoc, np);                          roff_node_delete(mdoc, np);
                 }                  }
   
Line 2040  post_ignpar(POST_ARGS)
Line 2037  post_ignpar(POST_ARGS)
                 if (np->tok == MDOC_Pp || np->tok == MDOC_Lp) {                  if (np->tok == MDOC_Pp || np->tok == MDOC_Lp) {
                         mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,                          mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,
                             np->line, np->pos, "%s at the end of %s",                              np->line, np->pos, "%s at the end of %s",
                             mdoc_macronames[np->tok],                              roff_name[np->tok],
                             mdoc_macronames[mdoc->last->tok]);                              roff_name[mdoc->last->tok]);
                         roff_node_delete(mdoc, np);                          roff_node_delete(mdoc, np);
                 }                  }
 }  }
Line 2074  post_prevpar(POST_ARGS)
Line 2071  post_prevpar(POST_ARGS)
                 return;                  return;
   
         mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,          mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,
             n->prev->line, n->prev->pos,              n->prev->line, n->prev->pos, "%s before %s",
             "%s before %s", mdoc_macronames[n->prev->tok],              roff_name[n->prev->tok], roff_name[n->tok]);
             mdoc_macronames[n->tok]);  
         roff_node_delete(mdoc, n->prev);          roff_node_delete(mdoc, n->prev);
 }  }
   
Line 2097  post_par(POST_ARGS)
Line 2093  post_par(POST_ARGS)
         } else if (np->child != NULL)          } else if (np->child != NULL)
                 mandoc_vmsg(MANDOCERR_ARG_SKIP,                  mandoc_vmsg(MANDOCERR_ARG_SKIP,
                     mdoc->parse, np->line, np->pos, "%s %s",                      mdoc->parse, np->line, np->pos, "%s %s",
                     mdoc_macronames[np->tok], np->child->string);                      roff_name[np->tok], np->child->string);
   
         if ((np = mdoc->last->prev) == NULL) {          if ((np = mdoc->last->prev) == NULL) {
                 np = mdoc->last->parent;                  np = mdoc->last->parent;
Line 2109  post_par(POST_ARGS)
Line 2105  post_par(POST_ARGS)
                 return;                  return;
   
         mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,          mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,
             mdoc->last->line, mdoc->last->pos,              mdoc->last->line, mdoc->last->pos, "%s after %s",
             "%s after %s", mdoc_macronames[mdoc->last->tok],              roff_name[mdoc->last->tok], roff_name[np->tok]);
             mdoc_macronames[np->tok]);  
         roff_node_delete(mdoc, mdoc->last);          roff_node_delete(mdoc, mdoc->last);
 }  }
   
Line 2362  mdoc_a2sec(const char *p)
Line 2357  mdoc_a2sec(const char *p)
 }  }
   
 static size_t  static size_t
 macro2len(int macro)  macro2len(enum roff_tok macro)
 {  {
   
         switch (macro) {          switch (macro) {

Legend:
Removed from v.1.319  
changed lines
  Added in v.1.320

CVSweb