[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.347 and 1.348

version 1.347, 2017/07/02 15:31:59 version 1.348, 2017/07/03 17:33:06
Line 78  static void  post_defaults(POST_ARGS);
Line 78  static void  post_defaults(POST_ARGS);
 static  void     post_display(POST_ARGS);  static  void     post_display(POST_ARGS);
 static  void     post_dd(POST_ARGS);  static  void     post_dd(POST_ARGS);
 static  void     post_delim(POST_ARGS);  static  void     post_delim(POST_ARGS);
   static  void     post_delim_nb(POST_ARGS);
 static  void     post_dt(POST_ARGS);  static  void     post_dt(POST_ARGS);
 static  void     post_en(POST_ARGS);  static  void     post_en(POST_ARGS);
 static  void     post_es(POST_ARGS);  static  void     post_es(POST_ARGS);
Line 109  static void  post_sh_authors(POST_ARGS);
Line 110  static void  post_sh_authors(POST_ARGS);
 static  void     post_sm(POST_ARGS);  static  void     post_sm(POST_ARGS);
 static  void     post_st(POST_ARGS);  static  void     post_st(POST_ARGS);
 static  void     post_std(POST_ARGS);  static  void     post_std(POST_ARGS);
   static  void     post_sx(POST_ARGS);
 static  void     post_useless(POST_ARGS);  static  void     post_useless(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);
Line 127  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
Line 129  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
         post_bl,        /* Bl */          post_bl,        /* Bl */
         NULL,           /* El */          NULL,           /* El */
         post_it,        /* It */          post_it,        /* It */
         post_delim,     /* Ad */          post_delim_nb,  /* Ad */
         post_an,        /* An */          post_an,        /* An */
         NULL,           /* Ap */          NULL,           /* Ap */
         post_defaults,  /* Ar */          post_defaults,  /* Ar */
         NULL,           /* Cd */          NULL,           /* Cd */
         post_delim,     /* Cm */          post_delim_nb,  /* Cm */
         post_delim,     /* Dv */          post_delim_nb,  /* Dv */
         post_delim,     /* Er */          post_delim_nb,  /* Er */
         post_delim,     /* Ev */          post_delim_nb,  /* Ev */
         post_ex,        /* Ex */          post_ex,        /* Ex */
         post_fa,        /* Fa */          post_fa,        /* Fa */
         NULL,           /* Fd */          NULL,           /* Fd */
         post_delim,     /* Fl */          post_delim_nb,  /* Fl */
         post_fn,        /* Fn */          post_fn,        /* Fn */
         post_delim,     /* Ft */          post_delim_nb,  /* Ft */
         post_delim,     /* Ic */          post_delim_nb,  /* Ic */
         post_delim,     /* In */          post_delim_nb,  /* In */
         post_defaults,  /* Li */          post_defaults,  /* Li */
         post_nd,        /* Nd */          post_nd,        /* Nd */
         post_nm,        /* Nm */          post_nm,        /* Nm */
         post_delim,     /* Op */          post_delim_nb,  /* Op */
         post_obsolete,  /* Ot */          post_obsolete,  /* Ot */
         post_defaults,  /* Pa */          post_defaults,  /* Pa */
         post_rv,        /* Rv */          post_rv,        /* Rv */
         post_st,        /* St */          post_st,        /* St */
         post_delim,     /* Va */          post_delim_nb,  /* Va */
         post_delim,     /* Vt */          post_delim_nb,  /* Vt */
         post_xr,        /* Xr */          post_xr,        /* Xr */
         NULL,           /* %A */          NULL,           /* %A */
         post_hyph,      /* %B */ /* FIXME: can be used outside Rs/Re. */          post_hyph,      /* %B */ /* FIXME: can be used outside Rs/Re. */
Line 167  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
Line 169  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
         post_hyph,      /* %T */ /* FIXME: can be used outside Rs/Re. */          post_hyph,      /* %T */ /* FIXME: can be used outside Rs/Re. */
         NULL,           /* %V */          NULL,           /* %V */
         NULL,           /* Ac */          NULL,           /* Ac */
         post_delim,     /* Ao */          post_delim_nb,  /* Ao */
         post_delim,     /* Aq */          post_delim_nb,  /* Aq */
         post_at,        /* At */          post_at,        /* At */
         NULL,           /* Bc */          NULL,           /* Bc */
         post_bf,        /* Bf */          post_bf,        /* Bf */
         post_delim,     /* Bo */          post_delim_nb,  /* Bo */
         NULL,           /* Bq */          NULL,           /* Bq */
         post_xx,        /* Bsx */          post_xx,        /* Bsx */
         post_bx,        /* Bx */          post_bx,        /* Bx */
Line 182  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
Line 184  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
         NULL,           /* Dq */          NULL,           /* Dq */
         NULL,           /* Ec */          NULL,           /* Ec */
         NULL,           /* Ef */          NULL,           /* Ef */
         post_delim,     /* Em */          post_delim_nb,  /* Em */
         NULL,           /* Eo */          NULL,           /* Eo */
         post_xx,        /* Fx */          post_xx,        /* Fx */
         post_delim,     /* Ms */          post_delim_nb,  /* Ms */
         NULL,           /* No */          NULL,           /* No */
         post_ns,        /* Ns */          post_ns,        /* Ns */
         post_xx,        /* Nx */          post_xx,        /* Nx */
         post_xx,        /* Ox */          post_xx,        /* Ox */
         NULL,           /* Pc */          NULL,           /* Pc */
         NULL,           /* Pf */          NULL,           /* Pf */
         post_delim,     /* Po */          post_delim_nb,  /* Po */
         post_delim,     /* Pq */          post_delim_nb,  /* Pq */
         NULL,           /* Qc */          NULL,           /* Qc */
         post_delim,     /* Ql */          post_delim_nb,  /* Ql */
         post_delim,     /* Qo */          post_delim_nb,  /* Qo */
         post_delim,     /* Qq */          post_delim_nb,  /* Qq */
         NULL,           /* Re */          NULL,           /* Re */
         post_rs,        /* Rs */          post_rs,        /* Rs */
         NULL,           /* Sc */          NULL,           /* Sc */
         post_delim,     /* So */          post_delim_nb,  /* So */
         post_delim,     /* Sq */          post_delim_nb,  /* Sq */
         post_sm,        /* Sm */          post_sm,        /* Sm */
         post_hyph,      /* Sx */          post_sx,        /* Sx */
         post_delim,     /* Sy */          post_delim_nb,  /* Sy */
         post_useless,   /* Tn */          post_useless,   /* Tn */
         post_xx,        /* Ux */          post_xx,        /* Ux */
         NULL,           /* Xc */          NULL,           /* Xc */
         NULL,           /* Xo */          NULL,           /* Xo */
         post_fo,        /* Fo */          post_fo,        /* Fo */
         NULL,           /* Fc */          NULL,           /* Fc */
         post_delim,     /* Oo */          post_delim_nb,  /* Oo */
         NULL,           /* Oc */          NULL,           /* Oc */
         post_bk,        /* Bk */          post_bk,        /* Bk */
         NULL,           /* Ek */          NULL,           /* Ek */
Line 222  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
Line 224  static const v_post __mdoc_valids[MDOC_MAX - MDOC_Dd] 
         post_eoln,      /* Ud */          post_eoln,      /* Ud */
         post_lb,        /* Lb */          post_lb,        /* Lb */
         post_par,       /* Lp */          post_par,       /* Lp */
         post_delim,     /* Lk */          post_delim_nb,  /* Lk */
         post_defaults,  /* Mt */          post_defaults,  /* Mt */
         post_delim,     /* Brq */          post_delim_nb,  /* Brq */
         post_delim,     /* Bro */          post_delim_nb,  /* Bro */
         NULL,           /* Brc */          NULL,           /* Brc */
         NULL,           /* %C */          NULL,           /* %C */
         post_es,        /* Es */          post_es,        /* Es */
Line 431  static void
Line 433  static void
 post_delim(POST_ARGS)  post_delim(POST_ARGS)
 {  {
         const struct roff_node  *nch;          const struct roff_node  *nch;
           const char              *lc;
           enum mdelim              delim;
           enum roff_tok            tok;
   
           tok = mdoc->last->tok;
           nch = mdoc->last->last;
           if (nch == NULL || nch->type != ROFFT_TEXT)
                   return;
           lc = strchr(nch->string, '\0') - 1;
           if (lc < nch->string)
                   return;
           delim = mdoc_isdelim(lc);
           if (delim == DELIM_NONE || delim == DELIM_OPEN)
                   return;
           if (*lc == ')' && (tok == MDOC_Nd || tok == MDOC_Sh ||
               tok == MDOC_Ss || tok == MDOC_Fo))
                   return;
   
           mandoc_vmsg(MANDOCERR_DELIM, mdoc->parse,
               nch->line, nch->pos + (lc - nch->string),
               "%s%s %s", roff_name[tok],
               nch == mdoc->last->child ? "" : " ...", nch->string);
   }
   
   static void
   post_delim_nb(POST_ARGS)
   {
           const struct roff_node  *nch;
         const char              *lc, *cp;          const char              *lc, *cp;
         int                      nw;          int                      nw;
         enum mdelim              delim;          enum mdelim              delim;
Line 516  post_delim(POST_ARGS)
Line 546  post_delim(POST_ARGS)
                 }                  }
         }          }
   
         mandoc_vmsg(MANDOCERR_DELIM, mdoc->parse,          mandoc_vmsg(MANDOCERR_DELIM_NB, mdoc->parse,
             nch->line, nch->pos + (lc - nch->string),              nch->line, nch->pos + (lc - nch->string),
             "%s%s %s", roff_name[tok],              "%s%s %s", roff_name[tok],
             nch == mdoc->last->child ? "" : " ...", nch->string);              nch == mdoc->last->child ? "" : " ...", nch->string);
Line 897  post_lb(POST_ARGS)
Line 927  post_lb(POST_ARGS)
         struct roff_node        *n;          struct roff_node        *n;
         const char              *p;          const char              *p;
   
         post_delim(mdoc);          post_delim_nb(mdoc);
   
         n = mdoc->last;          n = mdoc->last;
         assert(n->child->type == ROFFT_TEXT);          assert(n->child->type == ROFFT_TEXT);
Line 968  post_std(POST_ARGS)
Line 998  post_std(POST_ARGS)
 {  {
         struct roff_node *n;          struct roff_node *n;
   
           post_delim(mdoc);
   
         n = mdoc->last;          n = mdoc->last;
         if (n->args && n->args->argc == 1)          if (n->args && n->args->argc == 1)
                 if (n->args->argv[0].arg == MDOC_Std)                  if (n->args->argv[0].arg == MDOC_Std)
Line 1137  post_fo(POST_ARGS)
Line 1169  post_fo(POST_ARGS)
                     "Fo ... %s", n->child->next->string);                      "Fo ... %s", n->child->next->string);
                 while (n->child != n->last)                  while (n->child != n->last)
                         roff_node_delete(mdoc, n->last);                          roff_node_delete(mdoc, n->last);
         }          } else
                   post_delim(mdoc);
   
         post_fname(mdoc);          post_fname(mdoc);
 }  }
Line 1161  post_fa(POST_ARGS)
Line 1194  post_fa(POST_ARGS)
                         break;                          break;
                 }                  }
         }          }
         post_delim(mdoc);          post_delim_nb(mdoc);
 }  }
   
 static void  static void
Line 1189  post_nm(POST_ARGS)
Line 1222  post_nm(POST_ARGS)
                 mandoc_msg(MANDOCERR_NM_NONAME, mdoc->parse,                  mandoc_msg(MANDOCERR_NM_NONAME, mdoc->parse,
                     n->line, n->pos, "Nm");                      n->line, n->pos, "Nm");
   
         if (n->type == ROFFT_ELEM)          switch (n->type) {
           case ROFFT_ELEM:
                   post_delim_nb(mdoc);
                   break;
           case ROFFT_HEAD:
                 post_delim(mdoc);                  post_delim(mdoc);
                   break;
           default:
                   return;
           }
   
         if ((n->type != ROFFT_ELEM && n->type != ROFFT_HEAD) ||          if ((n->child != NULL && n->child->type == ROFFT_TEXT) ||
             (n->child != NULL && n->child->type == ROFFT_TEXT) ||  
             mdoc->meta.name == NULL)              mdoc->meta.name == NULL)
                 return;                  return;
   
Line 1207  static void
Line 1247  static void
 post_nd(POST_ARGS)  post_nd(POST_ARGS)
 {  {
         struct roff_node        *n;          struct roff_node        *n;
         size_t                   sz;  
   
         n = mdoc->last;          n = mdoc->last;
   
Line 1221  post_nd(POST_ARGS)
Line 1260  post_nd(POST_ARGS)
         if (n->child == NULL)          if (n->child == NULL)
                 mandoc_msg(MANDOCERR_ND_EMPTY, mdoc->parse,                  mandoc_msg(MANDOCERR_ND_EMPTY, mdoc->parse,
                     n->line, n->pos, "Nd");                      n->line, n->pos, "Nd");
         else if (n->last->type == ROFFT_TEXT &&          else
             (sz = strlen(n->last->string)) != 0 &&                  post_delim(mdoc);
             n->last->string[sz - 1] == '.')  
                 mandoc_msg(MANDOCERR_ND_DOT, mdoc->parse,  
                     n->last->line, n->last->pos + sz - 1, NULL);  
   
         post_hyph(mdoc);          post_hyph(mdoc);
 }  }
Line 1283  post_defaults(POST_ARGS)
Line 1319  post_defaults(POST_ARGS)
         struct roff_node *nn;          struct roff_node *nn;
   
         if (mdoc->last->child != NULL) {          if (mdoc->last->child != NULL) {
                 post_delim(mdoc);                  post_delim_nb(mdoc);
                 return;                  return;
         }          }
   
Line 1358  post_an(POST_ARGS)
Line 1394  post_an(POST_ARGS)
                         mandoc_msg(MANDOCERR_MACRO_EMPTY, mdoc->parse,                          mandoc_msg(MANDOCERR_MACRO_EMPTY, mdoc->parse,
                             np->line, np->pos, "An");                              np->line, np->pos, "An");
                 else                  else
                         post_delim(mdoc);                          post_delim_nb(mdoc);
         } else if (nch != NULL)          } else if (nch != NULL)
                 mandoc_vmsg(MANDOCERR_ARG_EXCESS, mdoc->parse,                  mandoc_vmsg(MANDOCERR_ARG_EXCESS, mdoc->parse,
                     nch->line, nch->pos, "An ... %s", nch->string);                      nch->line, nch->pos, "An ... %s", nch->string);
Line 1387  post_xx(POST_ARGS)
Line 1423  post_xx(POST_ARGS)
         struct roff_node        *n;          struct roff_node        *n;
         const char              *os;          const char              *os;
   
         post_delim(mdoc);          post_delim_nb(mdoc);
   
         n = mdoc->last;          n = mdoc->last;
         switch (n->tok) {          switch (n->tok) {
Line 2016  post_ns(POST_ARGS)
Line 2052  post_ns(POST_ARGS)
 }  }
   
 static void  static void
   post_sx(POST_ARGS)
   {
           post_delim(mdoc);
           post_hyph(mdoc);
   }
   
   static void
 post_sh(POST_ARGS)  post_sh(POST_ARGS)
 {  {
   
Line 2352  post_xr(POST_ARGS)
Line 2395  post_xr(POST_ARGS)
                             nch->line, nch->pos, "Xr %s %s",                              nch->line, nch->pos, "Xr %s %s",
                             nch->string, nch->next->string);                              nch->string, nch->next->string);
         }          }
         post_delim(mdoc);          post_delim_nb(mdoc);
 }  }
   
 static void  static void
Line 2365  post_ignpar(POST_ARGS)
Line 2408  post_ignpar(POST_ARGS)
                 post_prevpar(mdoc);                  post_prevpar(mdoc);
                 return;                  return;
         case ROFFT_HEAD:          case ROFFT_HEAD:
                   post_delim(mdoc);
                 post_hyph(mdoc);                  post_hyph(mdoc);
                 return;                  return;
         case ROFFT_BODY:          case ROFFT_BODY:
Line 2601  post_bx(POST_ARGS)
Line 2645  post_bx(POST_ARGS)
         struct roff_node        *n, *nch;          struct roff_node        *n, *nch;
         const char              *macro;          const char              *macro;
   
         post_delim(mdoc);          post_delim_nb(mdoc);
   
         n = mdoc->last;          n = mdoc->last;
         nch = n->child;          nch = n->child;
Line 2666  post_os(POST_ARGS)
Line 2710  post_os(POST_ARGS)
         else if (mdoc->flags & MDOC_PBODY)          else if (mdoc->flags & MDOC_PBODY)
                 mandoc_msg(MANDOCERR_PROLOG_LATE, mdoc->parse,                  mandoc_msg(MANDOCERR_PROLOG_LATE, mdoc->parse,
                     n->line, n->pos, "Os");                      n->line, n->pos, "Os");
   
           post_delim(mdoc);
   
         /*          /*
          * Set the operating system by way of the `Os' macro.           * Set the operating system by way of the `Os' macro.

Legend:
Removed from v.1.347  
changed lines
  Added in v.1.348

CVSweb