[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.286 and 1.290

version 1.286, 2015/04/18 16:06:41 version 1.290, 2015/04/20 09:48:53
Line 36 
Line 36 
 #include "roff.h"  #include "roff.h"
 #include "mdoc.h"  #include "mdoc.h"
 #include "libmandoc.h"  #include "libmandoc.h"
   #include "roff_int.h"
 #include "libmdoc.h"  #include "libmdoc.h"
   
 /* FIXME: .Bl -diag can't have non-text children in HEAD. */  /* FIXME: .Bl -diag can't have non-text children in HEAD. */
Line 904  post_fo(POST_ARGS)
Line 905  post_fo(POST_ARGS)
                     n->child->next->line, n->child->next->pos,                      n->child->next->line, n->child->next->pos,
                     "Fo ... %s", n->child->next->string);                      "Fo ... %s", n->child->next->string);
                 while (n->child != n->last)                  while (n->child != n->last)
                         mdoc_node_delete(mdoc, n->last);                          roff_node_delete(mdoc, n->last);
         }          }
   
         post_fname(mdoc);          post_fname(mdoc);
Line 1050  post_defaults(POST_ARGS)
Line 1051  post_defaults(POST_ARGS)
   
         switch (nn->tok) {          switch (nn->tok) {
         case MDOC_Ar:          case MDOC_Ar:
                 mdoc_word_alloc(mdoc, nn->line, nn->pos, "file");                  roff_word_alloc(mdoc, nn->line, nn->pos, "file");
                 mdoc_word_alloc(mdoc, nn->line, nn->pos, "...");                  roff_word_alloc(mdoc, nn->line, nn->pos, "...");
                 break;                  break;
         case MDOC_Pa:          case MDOC_Pa:
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case MDOC_Mt:          case MDOC_Mt:
                 mdoc_word_alloc(mdoc, nn->line, nn->pos, "~");                  roff_word_alloc(mdoc, nn->line, nn->pos, "~");
                 break;                  break;
         default:          default:
                 abort();                  abort();
Line 1075  post_at(POST_ARGS)
Line 1076  post_at(POST_ARGS)
         n = mdoc->last;          n = mdoc->last;
         if (n->child == NULL) {          if (n->child == NULL) {
                 mdoc->next = ROFF_NEXT_CHILD;                  mdoc->next = ROFF_NEXT_CHILD;
                 mdoc_word_alloc(mdoc, n->line, n->pos, "AT&T UNIX");                  roff_word_alloc(mdoc, n->line, n->pos, "AT&T UNIX");
                 mdoc->last = n;                  mdoc->last = n;
                 return;                  return;
         }          }
Line 1246  post_bl_block(POST_ARGS)
Line 1247  post_bl_block(POST_ARGS)
                                     mdoc->parse, nc->line, nc->pos,                                      mdoc->parse, nc->line, nc->pos,
                                     "%s before It",                                      "%s before It",
                                     mdoc_macronames[nc->tok]);                                      mdoc_macronames[nc->tok]);
                                 mdoc_node_delete(mdoc, nc);                                  roff_node_delete(mdoc, nc);
                         } else                          } else
                                 break;                                  break;
                         nc = ni->body->last;                          nc = ni->body->last;
Line 1268  rewrite_macro2len(char **arg)
Line 1269  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)) == MDOC_MAX)          else if ((tok = mdoc_hash_find(*arg)) == TOKEN_NONE)
                 return;                  return;
         else          else
                 width = macro2len(tok);                  width = macro2len(tok);
Line 1357  post_bl_head(POST_ARGS)
Line 1358  post_bl_head(POST_ARGS)
                 mandoc_vmsg(MANDOCERR_ARG_EXCESS, mdoc->parse,                  mandoc_vmsg(MANDOCERR_ARG_EXCESS, mdoc->parse,
                     nch->line, nch->pos, "Bl ... %s", nch->string);                      nch->line, nch->pos, "Bl ... %s", nch->string);
                 while (nch != NULL) {                  while (nch != NULL) {
                         mdoc_node_delete(mdoc, nch);                          roff_node_delete(mdoc, nch);
                         nch = nh->child;                          nch = nh->child;
                 }                  }
                 return;                  return;
Line 1398  post_bl_head(POST_ARGS)
Line 1399  post_bl_head(POST_ARGS)
                 argv->value[i++] = nch->string;                  argv->value[i++] = nch->string;
                 nch->string = NULL;                  nch->string = NULL;
                 nnext = nch->next;                  nnext = nch->next;
                 mdoc_node_delete(NULL, nch);                  roff_node_delete(NULL, nch);
         }          }
         nh->nchild = 0;          nh->nchild = 0;
         nh->child = NULL;          nh->child = NULL;
Line 1497  post_bk(POST_ARGS)
Line 1498  post_bk(POST_ARGS)
         if (n->type == ROFFT_BLOCK && n->body->child == NULL) {          if (n->type == ROFFT_BLOCK && n->body->child == NULL) {
                 mandoc_msg(MANDOCERR_BLK_EMPTY,                  mandoc_msg(MANDOCERR_BLK_EMPTY,
                     mdoc->parse, n->line, n->pos, "Bk");                      mdoc->parse, n->line, n->pos, "Bk");
                 mdoc_node_delete(mdoc, n);                  roff_node_delete(mdoc, n);
         }          }
 }  }
   
Line 1561  post_root(POST_ARGS)
Line 1562  post_root(POST_ARGS)
         /* Check that we begin with a proper `Sh'. */          /* Check that we begin with a proper `Sh'. */
   
         n = mdoc->first->child;          n = mdoc->first->child;
         while (n != NULL && mdoc_macros[n->tok].flags & MDOC_PROLOGUE)          while (n != NULL && n->tok != TOKEN_NONE &&
               mdoc_macros[n->tok].flags & MDOC_PROLOGUE)
                 n = n->next;                  n = n->next;
   
         if (n == NULL)          if (n == NULL)
Line 1585  post_st(POST_ARGS)
Line 1587  post_st(POST_ARGS)
         if (NULL == (p = mdoc_a2st(nch->string))) {          if (NULL == (p = mdoc_a2st(nch->string))) {
                 mandoc_vmsg(MANDOCERR_ST_BAD, mdoc->parse,                  mandoc_vmsg(MANDOCERR_ST_BAD, mdoc->parse,
                     nch->line, nch->pos, "St %s", nch->string);                      nch->line, nch->pos, "St %s", nch->string);
                 mdoc_node_delete(mdoc, n);                  roff_node_delete(mdoc, n);
         } else {          } else {
                 free(nch->string);                  free(nch->string);
                 nch->string = mandoc_strdup(p);                  nch->string = mandoc_strdup(p);
Line 1632  post_rs(POST_ARGS)
Line 1634  post_rs(POST_ARGS)
   
                 /*                  /*
                  * Remove this child from the chain.  This somewhat                   * Remove this child from the chain.  This somewhat
                  * repeats mdoc_node_unlink(), but since we're                   * repeats roff_node_unlink(), but since we're
                  * just re-ordering, there's no need for the                   * just re-ordering, there's no need for the
                  * full unlink process.                   * full unlink process.
                  */                   */
Line 1764  post_sh_name(POST_ARGS)
Line 1766  post_sh_name(POST_ARGS)
                                 mandoc_msg(MANDOCERR_NAMESEC_ND,                                  mandoc_msg(MANDOCERR_NAMESEC_ND,
                                     mdoc->parse, n->line, n->pos, NULL);                                      mdoc->parse, n->line, n->pos, NULL);
                         break;                          break;
                 case MDOC_MAX:                  case TOKEN_NONE:
                         if (hasnm)                          if (hasnm)
                                 break;                                  break;
                         /* FALLTHROUGH */                          /* FALLTHROUGH */
Line 2005  post_ignpar(POST_ARGS)
Line 2007  post_ignpar(POST_ARGS)
                             mdoc->parse, np->line, np->pos,                              mdoc->parse, np->line, np->pos,
                             "%s after %s", mdoc_macronames[np->tok],                              "%s after %s", mdoc_macronames[np->tok],
                             mdoc_macronames[mdoc->last->tok]);                              mdoc_macronames[mdoc->last->tok]);
                         mdoc_node_delete(mdoc, np);                          roff_node_delete(mdoc, np);
                 }                  }
   
         if (NULL != (np = mdoc->last->last))          if (NULL != (np = mdoc->last->last))
Line 2014  post_ignpar(POST_ARGS)
Line 2016  post_ignpar(POST_ARGS)
                             np->line, np->pos, "%s at the end of %s",                              np->line, np->pos, "%s at the end of %s",
                             mdoc_macronames[np->tok],                              mdoc_macronames[np->tok],
                             mdoc_macronames[mdoc->last->tok]);                              mdoc_macronames[mdoc->last->tok]);
                         mdoc_node_delete(mdoc, np);                          roff_node_delete(mdoc, np);
                 }                  }
 }  }
   
Line 2047  pre_par(PRE_ARGS)
Line 2049  pre_par(PRE_ARGS)
             mdoc->last->line, mdoc->last->pos,              mdoc->last->line, mdoc->last->pos,
             "%s before %s", mdoc_macronames[mdoc->last->tok],              "%s before %s", mdoc_macronames[mdoc->last->tok],
             mdoc_macronames[n->tok]);              mdoc_macronames[n->tok]);
         mdoc_node_delete(mdoc, mdoc->last);          roff_node_delete(mdoc, mdoc->last);
 }  }
   
 static void  static void
Line 2080  post_par(POST_ARGS)
Line 2082  post_par(POST_ARGS)
             mdoc->last->line, mdoc->last->pos,              mdoc->last->line, mdoc->last->pos,
             "%s after %s", mdoc_macronames[mdoc->last->tok],              "%s after %s", mdoc_macronames[mdoc->last->tok],
             mdoc_macronames[np->tok]);              mdoc_macronames[np->tok]);
         mdoc_node_delete(mdoc, mdoc->last);          roff_node_delete(mdoc, mdoc->last);
 }  }
   
 static void  static void
Line 2139  post_dd(POST_ARGS)
Line 2141  post_dd(POST_ARGS)
                 free(datestr);                  free(datestr);
         }          }
 out:  out:
         mdoc_node_delete(mdoc, n);          roff_node_delete(mdoc, n);
 }  }
   
 static void  static void
Line 2224  post_dt(POST_ARGS)
Line 2226  post_dt(POST_ARGS)
                     nn->line, nn->pos, "Dt ... %s", nn->string);                      nn->line, nn->pos, "Dt ... %s", nn->string);
   
 out:  out:
         mdoc_node_delete(mdoc, n);          roff_node_delete(mdoc, n);
 }  }
   
 static void  static void
Line 2290  post_os(POST_ARGS)
Line 2292  post_os(POST_ARGS)
 #endif /*!OSNAME*/  #endif /*!OSNAME*/
   
 out:  out:
         mdoc_node_delete(mdoc, n);          roff_node_delete(mdoc, n);
 }  }
   
 /*  /*
Line 2314  post_ex(POST_ARGS)
Line 2316  post_ex(POST_ARGS)
         }          }
   
         mdoc->next = ROFF_NEXT_CHILD;          mdoc->next = ROFF_NEXT_CHILD;
         mdoc_word_alloc(mdoc, n->line, n->pos, mdoc->meta.name);          roff_word_alloc(mdoc, n->line, n->pos, mdoc->meta.name);
         mdoc->last = n;          mdoc->last = n;
 }  }
   

Legend:
Removed from v.1.286  
changed lines
  Added in v.1.290

CVSweb