[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.321 and 1.323

version 1.321, 2017/04/28 16:25:11 version 1.323, 2017/05/04 17:48:29
Line 58  static void  check_argv(struct roff_man *,
Line 58  static void  check_argv(struct roff_man *,
 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(enum roff_tok);  static  size_t          macro2len(enum roff_tok);
 static  void     rewrite_macro2len(char **);  static  void     rewrite_macro2len(struct roff_man *, char **);
   
 static  void     post_an(POST_ARGS);  static  void     post_an(POST_ARGS);
 static  void     post_an_norm(POST_ARGS);  static  void     post_an_norm(POST_ARGS);
Line 227  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
Line 227  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
         post_en,        /* En */          post_en,        /* En */
         post_xx,        /* Dx */          post_xx,        /* Dx */
         NULL,           /* %Q */          NULL,           /* %Q */
         post_par,       /* br */  
         post_par,       /* sp */          post_par,       /* sp */
         NULL,           /* %U */          NULL,           /* %U */
         NULL,           /* Ta */          NULL,           /* Ta */
Line 327  mdoc_node_validate(struct roff_man *mdoc)
Line 326  mdoc_node_validate(struct roff_man *mdoc)
   
                 /* Call the macro's postprocessor. */                  /* Call the macro's postprocessor. */
   
                   if (n->tok < ROFF_MAX) {
                           switch(n->tok) {
                           case ROFF_br:
                                   post_par(mdoc);
                                   break;
                           default:
                                   abort();
                           }
                           break;
                   }
   
                   assert(n->tok >= MDOC_Dd && n->tok < MDOC_MAX);
                 p = mdoc_valids + n->tok;                  p = mdoc_valids + n->tok;
                 if (*p)                  if (*p)
                         (*p)(mdoc);                          (*p)(mdoc);
Line 451  post_bl_norm(POST_ARGS)
Line 462  post_bl_norm(POST_ARGS)
                                     mdoc->parse, argv->line,                                      mdoc->parse, argv->line,
                                     argv->pos, "Bl -width %s",                                      argv->pos, "Bl -width %s",
                                     argv->value[0]);                                      argv->value[0]);
                         rewrite_macro2len(argv->value);                          rewrite_macro2len(mdoc, argv->value);
                         n->norm->Bl.width = argv->value[0];                          n->norm->Bl.width = argv->value[0];
                         break;                          break;
                 case MDOC_Offset:                  case MDOC_Offset:
Line 466  post_bl_norm(POST_ARGS)
Line 477  post_bl_norm(POST_ARGS)
                                     mdoc->parse, argv->line,                                      mdoc->parse, argv->line,
                                     argv->pos, "Bl -offset %s",                                      argv->pos, "Bl -offset %s",
                                     argv->value[0]);                                      argv->value[0]);
                         rewrite_macro2len(argv->value);                          rewrite_macro2len(mdoc, argv->value);
                         n->norm->Bl.offs = argv->value[0];                          n->norm->Bl.offs = argv->value[0];
                         break;                          break;
                 default:                  default:
Line 593  post_bd(POST_ARGS)
Line 604  post_bd(POST_ARGS)
                                     mdoc->parse, argv->line,                                      mdoc->parse, argv->line,
                                     argv->pos, "Bd -offset %s",                                      argv->pos, "Bd -offset %s",
                                     argv->value[0]);                                      argv->value[0]);
                         rewrite_macro2len(argv->value);                          rewrite_macro2len(mdoc, argv->value);
                         n->norm->Bd.offs = argv->value[0];                          n->norm->Bd.offs = argv->value[0];
                         break;                          break;
                 case MDOC_Compact:                  case MDOC_Compact:
Line 1310  post_bl_block(POST_ARGS)
Line 1321  post_bl_block(POST_ARGS)
                         switch (nc->tok) {                          switch (nc->tok) {
                         case MDOC_Pp:                          case MDOC_Pp:
                         case MDOC_Lp:                          case MDOC_Lp:
                         case MDOC_br:                          case ROFF_br:
                                 break;                                  break;
                         default:                          default:
                                 nc = NULL;                                  nc = NULL;
Line 1338  post_bl_block(POST_ARGS)
Line 1349  post_bl_block(POST_ARGS)
  * If the argument of -offset or -width is a macro,   * If the argument of -offset or -width is a macro,
  * replace it with the associated default width.   * replace it with the associated default width.
  */   */
 void  static void
 rewrite_macro2len(char **arg)  rewrite_macro2len(struct roff_man *mdoc, char **arg)
 {  {
         size_t            width;          size_t            width;
         enum roff_tok     tok;          enum roff_tok     tok;
Line 1348  rewrite_macro2len(char **arg)
Line 1359  rewrite_macro2len(char **arg)
                 return;                  return;
         else if ( ! strcmp(*arg, "Ds"))          else if ( ! strcmp(*arg, "Ds"))
                 width = 6;                  width = 6;
         else if ((tok = mdoc_hash_find(*arg)) == TOKEN_NONE)          else if ((tok = roffhash_find(mdoc->mdocmac, *arg, 0)) == TOKEN_NONE)
                 return;                  return;
         else          else
                 width = macro2len(tok);                  width = macro2len(tok);
Line 2064  post_prevpar(POST_ARGS)
Line 2075  post_prevpar(POST_ARGS)
   
         if (n->prev->tok != MDOC_Pp &&          if (n->prev->tok != MDOC_Pp &&
             n->prev->tok != MDOC_Lp &&              n->prev->tok != MDOC_Lp &&
             n->prev->tok != MDOC_br)              n->prev->tok != ROFF_br)
                 return;                  return;
         if (n->tok == MDOC_Bl && n->norm->Bl.comp)          if (n->tok == MDOC_Bl && n->norm->Bl.comp)
                 return;                  return;
Line 2085  post_par(POST_ARGS)
Line 2096  post_par(POST_ARGS)
         struct roff_node *np;          struct roff_node *np;
   
         np = mdoc->last;          np = mdoc->last;
         if (np->tok != MDOC_br && np->tok != MDOC_sp)          if (np->tok != ROFF_br && np->tok != MDOC_sp)
                 post_prevpar(mdoc);                  post_prevpar(mdoc);
   
         if (np->tok == MDOC_sp) {          if (np->tok == MDOC_sp) {
Line 2103  post_par(POST_ARGS)
Line 2114  post_par(POST_ARGS)
                 if (np->tok != MDOC_Sh && np->tok != MDOC_Ss)                  if (np->tok != MDOC_Sh && np->tok != MDOC_Ss)
                         return;                          return;
         } else if (np->tok != MDOC_Pp && np->tok != MDOC_Lp &&          } else if (np->tok != MDOC_Pp && np->tok != MDOC_Lp &&
             (mdoc->last->tok != MDOC_br ||              (mdoc->last->tok != ROFF_br ||
              (np->tok != MDOC_sp && np->tok != MDOC_br)))               (np->tok != MDOC_sp && np->tok != ROFF_br)))
                 return;                  return;
   
         mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,          mandoc_vmsg(MANDOCERR_PAR_SKIP, mdoc->parse,

Legend:
Removed from v.1.321  
changed lines
  Added in v.1.323

CVSweb