[BACK]Return to man.c CVS log [TXT][DIR] Up to [local] / src / usr.bin / mandoc

Diff for /src/usr.bin/mandoc/man.c between version 1.8 and 1.9

version 1.8, 2009/08/22 15:15:37 version 1.9, 2009/08/22 20:14:37
Line 35 
Line 35 
         "document has no title/section", /* WNOTITLE */          "document has no title/section", /* WNOTITLE */
         "invalid escape sequence", /* WESCAPE */          "invalid escape sequence", /* WESCAPE */
         "invalid number format", /* WNUMFMT */          "invalid number format", /* WNUMFMT */
           "expected block head arguments", /* WHEADARGS */
           "expected block body arguments", /* WBODYARGS */
           "expected empty block head", /* WNHEADARGS */
           "unknown macro", /* WMACRO */
           "ill-formed macro", /* WMACROFORM */
           "scope open on exit" /* WEXITSCOPE */
 };  };
   
 const   char *const __man_macronames[MAN_MAX] = {  const   char *const __man_macronames[MAN_MAX] = {
Line 43 
Line 49 
         "IP",           "HP",           "SM",           "SB",          "IP",           "HP",           "SM",           "SB",
         "BI",           "IB",           "BR",           "RB",          "BI",           "IB",           "BR",           "RB",
         "R",            "B",            "I",            "IR",          "R",            "B",            "I",            "IR",
         "RI",           "na",           "i",            "sp"          "RI",           "na",           "i",            "sp",
           "nf",           "fi",           "r"
         };          };
   
 const   char * const *man_macronames = __man_macronames;  const   char * const *man_macronames = __man_macronames;
Line 199 
Line 206 
   
         p->parent->nchild++;          p->parent->nchild++;
   
           if ( ! man_valid_pre(man, p))
                   return(0);
   
           switch (p->type) {
           case (MAN_HEAD):
                   assert(MAN_BLOCK == p->parent->type);
                   p->parent->head = p;
                   break;
           case (MAN_BODY):
                   assert(MAN_BLOCK == p->parent->type);
                   p->parent->body = p;
                   break;
           default:
                   break;
           }
   
         man->last = p;          man->last = p;
   
         switch (p->type) {          switch (p->type) {
Line 246 
Line 269 
   
   
 int  int
   man_head_alloc(struct man *m, int line, int pos, int tok)
   {
           struct man_node *p;
   
           p = man_node_alloc(line, pos, MAN_HEAD, tok);
           if (NULL == p)
                   return(0);
           if ( ! man_node_append(m, p))
                   return(0);
           m->next = MAN_NEXT_CHILD;
           return(1);
   }
   
   
   int
   man_body_alloc(struct man *m, int line, int pos, int tok)
   {
           struct man_node *p;
   
           p = man_node_alloc(line, pos, MAN_BODY, tok);
           if (NULL == p)
                   return(0);
           if ( ! man_node_append(m, p))
                   return(0);
           m->next = MAN_NEXT_CHILD;
           return(1);
   }
   
   
   int
   man_block_alloc(struct man *m, int line, int pos, int tok)
   {
           struct man_node *p;
   
           p = man_node_alloc(line, pos, MAN_BLOCK, tok);
           if (NULL == p)
                   return(0);
           if ( ! man_node_append(m, p))
                   return(0);
           m->next = MAN_NEXT_CHILD;
           return(1);
   }
   
   
   int
 man_word_alloc(struct man *man,  man_word_alloc(struct man *man,
                 int line, int pos, const char *word)                  int line, int pos, const char *word)
 {  {
Line 290 
Line 358 
 man_ptext(struct man *m, int line, char *buf)  man_ptext(struct man *m, int line, char *buf)
 {  {
   
           /* First allocate word. */
   
         if ( ! man_word_alloc(m, line, 0, buf))          if ( ! man_word_alloc(m, line, 0, buf))
                 return(0);                  return(0);
         m->next = MAN_NEXT_SIBLING;          m->next = MAN_NEXT_SIBLING;
   
         /*          /*
          * If this is one of the zany NLINE macros that consumes the           * Co-ordinate what happens with having a next-line scope open:
          * next line of input as being influenced, then close out the           * first close out the element scope (if applicable), then close
          * existing macro "scope" and continue processing.           * out the block scope (also if applicable).
          */           */
   
         if ( ! (MAN_NLINE & m->flags))          /* XXX - this should be in man_action.c. */
                 return(1);  
   
         m->flags &= ~MAN_NLINE;          if (MAN_ELINE & m->flags) {
         m->last = m->last->parent;                  m->flags &= ~MAN_ELINE;
                   if ( ! man_unscope(m, m->last->parent))
                           return(0);
           }
   
         assert(MAN_ROOT != m->last->type);          if ( ! (MAN_BLINE & m->flags))
         if ( ! man_valid_post(m))                  return(1);
                 return(0);          m->flags &= ~MAN_BLINE;
         if ( ! man_action_post(m))  
                 return(0);  
   
         return(1);          if ( ! man_unscope(m, m->last->parent))
                   return(0);
           return(man_body_alloc(m, line, 0, m->last->tok));
 }  }
   
   
Line 321 
Line 393 
 {  {
         int               i, j, c, ppos, fl;          int               i, j, c, ppos, fl;
         char              mac[5];          char              mac[5];
         struct man_node  *n;  
   
         /* Comments and empties are quickly ignored. */          /* Comments and empties are quickly ignored. */
   
         n = m->last;          fl = m->flags;
         fl = MAN_NLINE & m->flags;  
   
         if (0 == buf[1])          if (0 == buf[1])
                 goto out;                  goto out;
Line 356 
Line 426 
   
         if (j == 4 || j < 1) {          if (j == 4 || j < 1) {
                 if ( ! (MAN_IGN_MACRO & m->pflags)) {                  if ( ! (MAN_IGN_MACRO & m->pflags)) {
                         (void)man_verr(m, ln, ppos,                          (void)man_perr(m, ln, ppos, WMACROFORM);
                                 "ill-formed macro: %s", mac);  
                         goto err;                          goto err;
                 }                  }
                 if ( ! man_vwarn(m, ln, ppos,                  if ( ! man_pwarn(m, ln, ppos, WMACROFORM))
                                 "ill-formed macro: %s", mac))  
                         goto err;                          goto err;
                 return(1);                  return(1);
         }          }
   
         if (MAN_MAX == (c = man_hash_find(m->htab, mac))) {          if (MAN_MAX == (c = man_hash_find(m->htab, mac))) {
                 if ( ! (MAN_IGN_MACRO & m->pflags)) {                  if ( ! (MAN_IGN_MACRO & m->pflags)) {
                         (void)man_verr(m, ln, ppos,                          (void)man_perr(m, ln, ppos, WMACRO);
                                 "unknown macro: %s", mac);  
                         goto err;                          goto err;
                 }                  }
                 if ( ! man_vwarn(m, ln, ppos,                  if ( ! man_pwarn(m, ln, ppos, WMACRO))
                                 "unknown macro: %s", mac))  
                         goto err;                          goto err;
                 return(1);                  return(1);
         }          }
Line 385 
Line 451 
   
         /* Begin recursive parse sequence. */          /* Begin recursive parse sequence. */
   
         if ( ! man_macro(m, c, ln, ppos, &i, buf))          assert(man_macros[c].fp);
   
           if ( ! (*man_macros[c].fp)(m, c, ln, ppos, &i, buf))
                 goto err;                  goto err;
   
 out:  out:
         if (fl) {          if ( ! (MAN_BLINE & fl))
                 /*                  return(1);
                  * A NLINE macro has been immediately followed with  
                  * another.  Close out the preceding macro's scope, and  
                  * continue.  
                  */  
                 assert(MAN_ROOT != m->last->type);  
                 assert(m->last->parent);  
                 assert(MAN_ROOT != m->last->parent->type);  
   
                 if (n != m->last)          /*
                         m->last = m->last->parent;           * If we've opened a new next-line element scope, then return
            * now, as the next line will close out the block scope.
            */
   
                 if ( ! man_valid_post(m))          if (MAN_ELINE & m->flags)
                         return(0);                  return(1);
                 if ( ! man_action_post(m))  
                         return(0);  
                 m->next = MAN_NEXT_SIBLING;  
                 m->flags &= ~MAN_NLINE;  
         }  
   
         return(1);          /* Close out the block scope opened in the prior line.  */
   
           /* XXX - this should be in man_action.c. */
   
           assert(MAN_BLINE & m->flags);
           m->flags &= ~MAN_BLINE;
   
           if ( ! man_unscope(m, m->last->parent))
                   return(0);
           return(man_body_alloc(m, ln, 0, m->last->tok));
   
 err:    /* Error out. */  err:    /* Error out. */
   

Legend:
Removed from v.1.8  
changed lines
  Added in v.1.9