[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.279 and 1.282

version 1.279, 2015/02/14 13:23:57 version 1.282, 2015/02/23 13:31:04
Line 839  post_lb(POST_ARGS)
Line 839  post_lb(POST_ARGS)
   
         if (NULL == (stdlibname = mdoc_a2lib(n->string)))          if (NULL == (stdlibname = mdoc_a2lib(n->string)))
                 mandoc_asprintf(&libname,                  mandoc_asprintf(&libname,
                     "library \\(lq%s\\(rq", n->string);                      "library \\(Lq%s\\(Rq", n->string);
         else          else
                 libname = mandoc_strdup(stdlibname);                  libname = mandoc_strdup(stdlibname);
   
Line 1748  static void
Line 1748  static void
 post_sh_name(POST_ARGS)  post_sh_name(POST_ARGS)
 {  {
         struct mdoc_node *n;          struct mdoc_node *n;
           int hasnm, hasnd;
   
         /*          hasnm = hasnd = 0;
          * Warn if the NAME section doesn't contain the `Nm' and `Nd'  
          * macros (can have multiple `Nm' and one `Nd').  Note that the  
          * children of the BODY declaration can also be "text".  
          */  
   
         if (NULL == (n = mdoc->last->child)) {          for (n = mdoc->last->child; n != NULL; n = n->next) {
                 mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,                  switch (n->tok) {
                     mdoc->last->line, mdoc->last->pos, "empty");                  case MDOC_Nm:
                 return;                          hasnm = 1;
                           break;
                   case MDOC_Nd:
                           hasnd = 1;
                           if (n->next != NULL)
                                   mandoc_msg(MANDOCERR_NAMESEC_ND,
                                       mdoc->parse, n->line, n->pos, NULL);
                           break;
                   default:
                           mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,
                               n->line, n->pos, mdoc_macronames[n->tok]);
                           break;
                   }
         }          }
   
         for ( ; n && n->next; n = n->next) {          if ( ! hasnm)
                 if (MDOC_ELEM == n->type && MDOC_Nm == n->tok)                  mandoc_msg(MANDOCERR_NAMESEC_NONM, mdoc->parse,
                         continue;                      mdoc->last->line, mdoc->last->pos, NULL);
                 if (MDOC_TEXT == n->type)          if ( ! hasnd)
                         continue;                  mandoc_msg(MANDOCERR_NAMESEC_NOND, mdoc->parse,
                 mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,                      mdoc->last->line, mdoc->last->pos, NULL);
                     n->line, n->pos, mdoc_macronames[n->tok]);  
         }  
   
         assert(n);  
         if (MDOC_BLOCK == n->type && MDOC_Nd == n->tok)  
                 return;  
   
         mandoc_msg(MANDOCERR_NAMESEC_BAD, mdoc->parse,  
             n->line, n->pos, mdoc_macronames[n->tok]);  
 }  }
   
 static void  static void
Line 2156  post_dt(POST_ARGS)
Line 2156  post_dt(POST_ARGS)
         mdoc->meta.vol = NULL;          mdoc->meta.vol = NULL;
         mdoc->meta.arch = NULL;          mdoc->meta.arch = NULL;
   
         /* First check that all characters are uppercase. */          /* Mandatory first argument: title. */
   
         if (NULL != (nn = n->child))          nn = n->child;
                 for (p = nn->string; *p; p++) {          if (nn == NULL || *nn->string == '\0') {
                         if (toupper((unsigned char)*p) == *p)  
                                 continue;  
                         mandoc_vmsg(MANDOCERR_TITLE_CASE,  
                             mdoc->parse, nn->line,  
                             nn->pos + (p - nn->string),  
                             "Dt %s", nn->string);  
                         break;  
                 }  
   
         /* No argument: msec and arch remain NULL. */  
   
         if (NULL == (nn = n->child)) {  
                 mandoc_msg(MANDOCERR_DT_NOTITLE,                  mandoc_msg(MANDOCERR_DT_NOTITLE,
                     mdoc->parse, n->line, n->pos, "Dt");                      mdoc->parse, n->line, n->pos, "Dt");
                 mdoc->meta.title = mandoc_strdup("UNTITLED");                  mdoc->meta.title = mandoc_strdup("UNTITLED");
                 mdoc->meta.vol = mandoc_strdup("LOCAL");          } else {
                 goto out;                  mdoc->meta.title = mandoc_strdup(nn->string);
   
                   /* Check that all characters are uppercase. */
   
                   for (p = nn->string; *p != '\0'; p++)
                           if (islower((unsigned char)*p)) {
                                   mandoc_vmsg(MANDOCERR_TITLE_CASE,
                                       mdoc->parse, nn->line,
                                       nn->pos + (p - nn->string),
                                       "Dt %s", nn->string);
                                   break;
                           }
         }          }
   
         /* One argument: msec and arch remain NULL. */          /* Mandatory second argument: section. */
   
         mdoc->meta.title = mandoc_strdup(          if (nn != NULL)
             '\0' == nn->string[0] ? "UNTITLED" : nn->string);                  nn = nn->next;
   
         if (NULL == (nn = nn->next)) {          if (nn == NULL) {
                 mandoc_vmsg(MANDOCERR_MSEC_MISSING,                  mandoc_vmsg(MANDOCERR_MSEC_MISSING,
                     mdoc->parse, n->line, n->pos,                      mdoc->parse, n->line, n->pos,
                     "Dt %s", mdoc->meta.title);                      "Dt %s", mdoc->meta.title);
                 mdoc->meta.vol = mandoc_strdup("LOCAL");                  mdoc->meta.vol = mandoc_strdup("LOCAL");
                 goto out;                  goto out;  /* msec and arch remain NULL. */
         }          }
   
         /* Handles: `.Dt TITLE SEC'          mdoc->meta.msec = mandoc_strdup(nn->string);
          * title = TITLE,  
          * volume = SEC is msec ? format(msec) : SEC,  
          * msec = SEC is msec ? atoi(msec) : 0,  
          * arch = NULL  
          */  
   
           /* Infer volume title from section number. */
   
         cp = mandoc_a2msec(nn->string);          cp = mandoc_a2msec(nn->string);
         if (cp) {          if (cp == NULL) {
                 mdoc->meta.vol = mandoc_strdup(cp);  
                 mdoc->meta.msec = mandoc_strdup(nn->string);  
         } else {  
                 mandoc_vmsg(MANDOCERR_MSEC_BAD, mdoc->parse,                  mandoc_vmsg(MANDOCERR_MSEC_BAD, mdoc->parse,
                     nn->line, nn->pos, "Dt ... %s", nn->string);                      nn->line, nn->pos, "Dt ... %s", nn->string);
                 mdoc->meta.vol = mandoc_strdup(nn->string);                  mdoc->meta.vol = mandoc_strdup(nn->string);
                 mdoc->meta.msec = mandoc_strdup(nn->string);          } else
         }                  mdoc->meta.vol = mandoc_strdup(cp);
   
         /* Handle an optional architecture */          /* Optional third argument: architecture. */
   
         if ((nn = nn->next) != NULL) {          if ((nn = nn->next) == NULL)
                 for (p = nn->string; *p; p++)                  goto out;
                         *p = tolower((unsigned char)*p);  
                 mdoc->meta.arch = mandoc_strdup(nn->string);  
         }  
   
         /* Ignore any subsequent parameters... */          for (p = nn->string; *p != '\0'; p++)
         /* FIXME: warn about subsequent parameters. */                  *p = tolower((unsigned char)*p);
           mdoc->meta.arch = mandoc_strdup(nn->string);
   
           /* Ignore fourth and later arguments. */
   
           if ((nn = nn->next) != NULL)
                   mandoc_vmsg(MANDOCERR_ARG_EXCESS, mdoc->parse,
                       nn->line, nn->pos, "Dt ... %s", nn->string);
   
 out:  out:
         mdoc_node_delete(mdoc, n);          mdoc_node_delete(mdoc, n);
 }  }

Legend:
Removed from v.1.279  
changed lines
  Added in v.1.282

CVSweb