[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.210 and 1.215

version 1.210, 2014/04/20 16:46:05 version 1.215, 2014/06/20 17:24:00
Line 45 
Line 45 
 #define PRE_ARGS  struct mdoc *mdoc, struct mdoc_node *n  #define PRE_ARGS  struct mdoc *mdoc, struct mdoc_node *n
 #define POST_ARGS struct mdoc *mdoc  #define POST_ARGS struct mdoc *mdoc
   
 #define NUMSIZ    32  
   
 enum    check_ineq {  enum    check_ineq {
         CHECK_LT,          CHECK_LT,
         CHECK_GT,          CHECK_GT,
Line 937  pre_dt(PRE_ARGS)
Line 935  pre_dt(PRE_ARGS)
 {  {
   
         if (NULL == mdoc->meta.date || mdoc->meta.os)          if (NULL == mdoc->meta.date || mdoc->meta.os)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGOOO);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_ORDER);
   
         if (mdoc->meta.title)          if (mdoc->meta.title)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGREP);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_REP);
   
         return(1);          return(1);
 }  }
Line 950  pre_os(PRE_ARGS)
Line 948  pre_os(PRE_ARGS)
 {  {
   
         if (NULL == mdoc->meta.title || NULL == mdoc->meta.date)          if (NULL == mdoc->meta.title || NULL == mdoc->meta.date)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGOOO);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_ORDER);
   
         if (mdoc->meta.os)          if (mdoc->meta.os)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGREP);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_REP);
   
         return(1);          return(1);
 }  }
Line 963  pre_dd(PRE_ARGS)
Line 961  pre_dd(PRE_ARGS)
 {  {
   
         if (mdoc->meta.title || mdoc->meta.os)          if (mdoc->meta.title || mdoc->meta.os)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGOOO);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_ORDER);
   
         if (mdoc->meta.date)          if (mdoc->meta.date)
                 mdoc_nmsg(mdoc, n, MANDOCERR_PROLOGREP);                  mdoc_nmsg(mdoc, n, MANDOCERR_PROLOG_REP);
   
         return(1);          return(1);
 }  }
Line 1046  post_bf(POST_ARGS)
Line 1044  post_bf(POST_ARGS)
 static int  static int
 post_lb(POST_ARGS)  post_lb(POST_ARGS)
 {  {
         const char      *p;          struct mdoc_node        *n;
         char            *buf;          const char              *stdlibname;
         size_t           sz;          char                    *libname;
   
         check_count(mdoc, MDOC_ELEM, CHECK_WARN, CHECK_EQ, 1);          check_count(mdoc, MDOC_ELEM, CHECK_WARN, CHECK_EQ, 1);
   
         assert(mdoc->last->child);          n = mdoc->last->child;
         assert(MDOC_TEXT == mdoc->last->child->type);  
   
         p = mdoc_a2lib(mdoc->last->child->string);          assert(n);
           assert(MDOC_TEXT == n->type);
   
         /* If lookup ok, replace with table value. */          if (NULL == (stdlibname = mdoc_a2lib(n->string)))
                   mandoc_asprintf(&libname,
                       "library \\(lq%s\\(rq", n->string);
           else
                   libname = mandoc_strdup(stdlibname);
   
         if (p) {          free(n->string);
                 free(mdoc->last->child->string);          n->string = libname;
                 mdoc->last->child->string = mandoc_strdup(p);  
                 return(1);  
         }  
   
         /* If not, use "library ``xxxx''. */  
   
         sz = strlen(mdoc->last->child->string) + 2 +  
              strlen("\\(lqlibrary\\(rq");  
         buf = mandoc_malloc(sz);  
         snprintf(buf, sz, "library \\(lq%s\\(rq",  
             mdoc->last->child->string);  
         free(mdoc->last->child->string);  
         mdoc->last->child->string = buf;  
         return(1);          return(1);
 }  }
   
Line 1194  post_defaults(POST_ARGS)
Line 1183  post_defaults(POST_ARGS)
 static int  static int
 post_at(POST_ARGS)  post_at(POST_ARGS)
 {  {
         const char       *p, *q;          struct mdoc_node        *n;
         char             *buf;          const char              *std_att;
         size_t            sz;          char                    *att;
   
         /*          /*
          * If we have a child, look it up in the standard keys.  If a           * If we have a child, look it up in the standard keys.  If a
Line 1204  post_at(POST_ARGS)
Line 1193  post_at(POST_ARGS)
          * prefix "AT&T UNIX " to the existing data.           * prefix "AT&T UNIX " to the existing data.
          */           */
   
         if (NULL == mdoc->last->child)          if (NULL == (n = mdoc->last->child))
                 return(1);                  return(1);
   
         assert(MDOC_TEXT == mdoc->last->child->type);          assert(MDOC_TEXT == n->type);
         p = mdoc_a2att(mdoc->last->child->string);          if (NULL == (std_att = mdoc_a2att(n->string))) {
   
         if (p) {  
                 free(mdoc->last->child->string);  
                 mdoc->last->child->string = mandoc_strdup(p);  
         } else {  
                 mdoc_nmsg(mdoc, mdoc->last, MANDOCERR_BADATT);                  mdoc_nmsg(mdoc, mdoc->last, MANDOCERR_BADATT);
                 p = "AT&T UNIX ";                  mandoc_asprintf(&att, "AT&T UNIX %s", n->string);
                 q = mdoc->last->child->string;          } else
                 sz = strlen(p) + strlen(q) + 1;                  att = mandoc_strdup(std_att);
                 buf = mandoc_malloc(sz);  
                 strlcpy(buf, p, sz);  
                 strlcat(buf, q, sz);  
                 free(mdoc->last->child->string);  
                 mdoc->last->child->string = buf;  
         }  
   
           free(n->string);
           n->string = att;
         return(1);          return(1);
 }  }
   
Line 1388  post_bl_block_width(POST_ARGS)
Line 1368  post_bl_block_width(POST_ARGS)
         int               i;          int               i;
         enum mdoct        tok;          enum mdoct        tok;
         struct mdoc_node *n;          struct mdoc_node *n;
         char              buf[NUMSIZ];          char              buf[24];
   
         n = mdoc->last;          n = mdoc->last;
   
Line 1420  post_bl_block_width(POST_ARGS)
Line 1400  post_bl_block_width(POST_ARGS)
   
         assert(i < (int)n->args->argc);          assert(i < (int)n->args->argc);
   
         snprintf(buf, NUMSIZ, "%un", (unsigned int)width);          (void)snprintf(buf, sizeof(buf), "%un", (unsigned int)width);
         free(n->args->argv[i].value[0]);          free(n->args->argv[i].value[0]);
         n->args->argv[i].value[0] = mandoc_strdup(buf);          n->args->argv[i].value[0] = mandoc_strdup(buf);
   
Line 1435  post_bl_block_tag(POST_ARGS)
Line 1415  post_bl_block_tag(POST_ARGS)
         struct mdoc_node *n, *nn;          struct mdoc_node *n, *nn;
         size_t            sz, ssz;          size_t            sz, ssz;
         int               i;          int               i;
         char              buf[NUMSIZ];          char              buf[24];
   
         /*          /*
          * Calculate the -width for a `Bl -tag' list if it hasn't been           * Calculate the -width for a `Bl -tag' list if it hasn't been
Line 1470  post_bl_block_tag(POST_ARGS)
Line 1450  post_bl_block_tag(POST_ARGS)
   
         /* Defaults to ten ens. */          /* Defaults to ten ens. */
   
         snprintf(buf, NUMSIZ, "%un", (unsigned int)sz);          (void)snprintf(buf, sizeof(buf), "%un", (unsigned int)sz);
   
         /*          /*
          * We have to dynamically add this to the macro's argument list.           * We have to dynamically add this to the macro's argument list.
Line 1480  post_bl_block_tag(POST_ARGS)
Line 1460  post_bl_block_tag(POST_ARGS)
         assert(n->args);          assert(n->args);
         i = (int)(n->args->argc)++;          i = (int)(n->args->argc)++;
   
         n->args->argv = mandoc_realloc(n->args->argv,          n->args->argv = mandoc_reallocarray(n->args->argv,
             n->args->argc * sizeof(struct mdoc_argv));              n->args->argc, sizeof(struct mdoc_argv));
   
         n->args->argv[i].arg = MDOC_Width;          n->args->argv[i].arg = MDOC_Width;
         n->args->argv[i].line = n->line;          n->args->argv[i].line = n->line;
Line 1541  post_bl_head(POST_ARGS)
Line 1521  post_bl_head(POST_ARGS)
          */           */
   
         np->args->argv[j].sz = (size_t)mdoc->last->nchild;          np->args->argv[j].sz = (size_t)mdoc->last->nchild;
         np->args->argv[j].value = mandoc_malloc(          np->args->argv[j].value = mandoc_reallocarray(NULL,
             (size_t)mdoc->last->nchild * sizeof(char *));              (size_t)mdoc->last->nchild, sizeof(char *));
   
         mdoc->last->norm->Bl.ncols = np->args->argv[j].sz;          mdoc->last->norm->Bl.ncols = np->args->argv[j].sz;
         mdoc->last->norm->Bl.cols = (void *)np->args->argv[j].value;          mdoc->last->norm->Bl.cols = (void *)np->args->argv[j].value;
Line 2204  post_dt(POST_ARGS)
Line 2184  post_dt(POST_ARGS)
                          * FIXME: don't be lazy: have this make all                           * FIXME: don't be lazy: have this make all
                          * characters be uppercase and just warn once.                           * characters be uppercase and just warn once.
                          */                           */
                         mdoc_nmsg(mdoc, nn, MANDOCERR_UPPERCASE);                          mdoc_nmsg(mdoc, nn, MANDOCERR_TITLE_CASE);
                         break;                          break;
                 }                  }
   
Line 2248  post_dt(POST_ARGS)
Line 2228  post_dt(POST_ARGS)
                 mdoc->meta.vol = mandoc_strdup(cp);                  mdoc->meta.vol = mandoc_strdup(cp);
                 mdoc->meta.msec = mandoc_strdup(nn->string);                  mdoc->meta.msec = mandoc_strdup(nn->string);
         } else {          } else {
                 mdoc_nmsg(mdoc, n, MANDOCERR_BADMSEC);                  mdoc_nmsg(mdoc, n, MANDOCERR_MSEC_BAD);
                 mdoc->meta.vol = mandoc_strdup(nn->string);                  mdoc->meta.vol = mandoc_strdup(nn->string);
                 mdoc->meta.msec = mandoc_strdup(nn->string);                  mdoc->meta.msec = mandoc_strdup(nn->string);
         }          }
Line 2270  post_dt(POST_ARGS)
Line 2250  post_dt(POST_ARGS)
         } else {          } else {
                 cp = mdoc_a2arch(nn->string);                  cp = mdoc_a2arch(nn->string);
                 if (NULL == cp) {                  if (NULL == cp) {
                         mdoc_nmsg(mdoc, nn, MANDOCERR_BADVOLARCH);                          mdoc_nmsg(mdoc, nn, MANDOCERR_ARCH_BAD);
                         free(mdoc->meta.vol);                          free(mdoc->meta.vol);
                         mdoc->meta.vol = mandoc_strdup(nn->string);                          mdoc->meta.vol = mandoc_strdup(nn->string);
                 } else                  } else

Legend:
Removed from v.1.210  
changed lines
  Added in v.1.215

CVSweb