[BACK]Return to man.c CVS log [TXT][DIR] Up to [cvsweb.bsd.lv] / mandoc

Diff for /mandoc/man.c between version 1.95 and 1.100

version 1.95, 2011/01/01 13:54:58 version 1.100, 2011/02/08 07:40:23
Line 44  const char *const __man_macronames[MAN_MAX] = {   
Line 44  const char *const __man_macronames[MAN_MAX] = {   
   
 const   char * const *man_macronames = __man_macronames;  const   char * const *man_macronames = __man_macronames;
   
 static  struct man_node *man_node_alloc(int, int,  static  struct man_node *man_node_alloc(struct man *, int, int,
                                 enum man_type, enum mant);                                  enum man_type, enum mant);
 static  int              man_node_append(struct man *,  static  int              man_node_append(struct man *,
                                 struct man_node *);                                  struct man_node *);
 static  int              man_span_alloc(struct man *,  
                                 const struct tbl_span *);  
 static  void             man_node_free(struct man_node *);  static  void             man_node_free(struct man_node *);
 static  void             man_node_unlink(struct man *,  static  void             man_node_unlink(struct man *,
                                 struct man_node *);                                  struct man_node *);
Line 64  const struct man_node *
Line 62  const struct man_node *
 man_node(const struct man *m)  man_node(const struct man *m)
 {  {
   
         return(MAN_HALT & m->flags ? NULL : m->first);          assert( ! (MAN_HALT & m->flags));
           return(m->first);
 }  }
   
   
Line 72  const struct man_meta *
Line 71  const struct man_meta *
 man_meta(const struct man *m)  man_meta(const struct man *m)
 {  {
   
         return(MAN_HALT & m->flags ? NULL : &m->meta);          assert( ! (MAN_HALT & m->flags));
           return(&m->meta);
 }  }
   
   
Line 115  int
Line 115  int
 man_endparse(struct man *m)  man_endparse(struct man *m)
 {  {
   
         if (MAN_HALT & m->flags)          assert( ! (MAN_HALT & m->flags));
                 return(0);          if (man_macroend(m))
         else if (man_macroend(m))  
                 return(1);                  return(1);
         m->flags |= MAN_HALT;          m->flags |= MAN_HALT;
         return(0);          return(0);
Line 128  int
Line 127  int
 man_parseln(struct man *m, int ln, char *buf, int offs)  man_parseln(struct man *m, int ln, char *buf, int offs)
 {  {
   
         if (MAN_HALT & m->flags)          m->flags |= MAN_NEWLINE;
                 return(0);  
   
           assert( ! (MAN_HALT & m->flags));
         return(('.' == buf[offs] || '\'' == buf[offs]) ?          return(('.' == buf[offs] || '\'' == buf[offs]) ?
                         man_pmacro(m, ln, buf, offs) :                          man_pmacro(m, ln, buf, offs) :
                         man_ptext(m, ln, buf, offs));                          man_ptext(m, ln, buf, offs));
Line 230  man_node_append(struct man *man, struct man_node *p)
Line 229  man_node_append(struct man *man, struct man_node *p)
   
   
 static struct man_node *  static struct man_node *
 man_node_alloc(int line, int pos, enum man_type type, enum mant tok)  man_node_alloc(struct man *m, int line, int pos,
                   enum man_type type, enum mant tok)
 {  {
         struct man_node *p;          struct man_node *p;
   
Line 239  man_node_alloc(int line, int pos, enum man_type type, 
Line 239  man_node_alloc(int line, int pos, enum man_type type, 
         p->pos = pos;          p->pos = pos;
         p->type = type;          p->type = type;
         p->tok = tok;          p->tok = tok;
   
           if (MAN_NEWLINE & m->flags)
                   p->flags |= MAN_LINE;
           m->flags &= ~MAN_NEWLINE;
         return(p);          return(p);
 }  }
   
Line 248  man_elem_alloc(struct man *m, int line, int pos, enum 
Line 252  man_elem_alloc(struct man *m, int line, int pos, enum 
 {  {
         struct man_node *p;          struct man_node *p;
   
         p = man_node_alloc(line, pos, MAN_ELEM, tok);          p = man_node_alloc(m, line, pos, MAN_ELEM, tok);
         if ( ! man_node_append(m, p))          if ( ! man_node_append(m, p))
                 return(0);                  return(0);
         m->next = MAN_NEXT_CHILD;          m->next = MAN_NEXT_CHILD;
Line 261  man_head_alloc(struct man *m, int line, int pos, enum 
Line 265  man_head_alloc(struct man *m, int line, int pos, enum 
 {  {
         struct man_node *p;          struct man_node *p;
   
         p = man_node_alloc(line, pos, MAN_HEAD, tok);          p = man_node_alloc(m, line, pos, MAN_HEAD, tok);
         if ( ! man_node_append(m, p))          if ( ! man_node_append(m, p))
                 return(0);                  return(0);
         m->next = MAN_NEXT_CHILD;          m->next = MAN_NEXT_CHILD;
Line 274  man_body_alloc(struct man *m, int line, int pos, enum 
Line 278  man_body_alloc(struct man *m, int line, int pos, enum 
 {  {
         struct man_node *p;          struct man_node *p;
   
         p = man_node_alloc(line, pos, MAN_BODY, tok);          p = man_node_alloc(m, line, pos, MAN_BODY, tok);
         if ( ! man_node_append(m, p))          if ( ! man_node_append(m, p))
                 return(0);                  return(0);
         m->next = MAN_NEXT_CHILD;          m->next = MAN_NEXT_CHILD;
Line 287  man_block_alloc(struct man *m, int line, int pos, enum
Line 291  man_block_alloc(struct man *m, int line, int pos, enum
 {  {
         struct man_node *p;          struct man_node *p;
   
         p = man_node_alloc(line, pos, MAN_BLOCK, tok);          p = man_node_alloc(m, line, pos, MAN_BLOCK, tok);
         if ( ! man_node_append(m, p))          if ( ! man_node_append(m, p))
                 return(0);                  return(0);
         m->next = MAN_NEXT_CHILD;          m->next = MAN_NEXT_CHILD;
         return(1);          return(1);
 }  }
   
 static int  
 man_span_alloc(struct man *m, const struct tbl_span *span)  
 {  
         struct man_node *n;  
   
         /* FIXME: grab from span */  
         n = man_node_alloc(0, 0, MAN_TBL, MAN_MAX);  
         n->span = span;  
   
         if ( ! man_node_append(m, n))  
                 return(0);  
   
         m->next = MAN_NEXT_SIBLING;  
         return(1);  
 }  
   
 int  int
 man_word_alloc(struct man *m, int line, int pos, const char *word)  man_word_alloc(struct man *m, int line, int pos, const char *word)
 {  {
Line 318  man_word_alloc(struct man *m, int line, int pos, const
Line 306  man_word_alloc(struct man *m, int line, int pos, const
   
         len = strlen(word);          len = strlen(word);
   
         n = man_node_alloc(line, pos, MAN_TEXT, MAN_MAX);          n = man_node_alloc(m, line, pos, MAN_TEXT, MAN_MAX);
         n->string = mandoc_malloc(len + 1);          n->string = mandoc_malloc(len + 1);
         sv = strlcpy(n->string, word, len + 1);          sv = strlcpy(n->string, word, len + 1);
   
Line 362  man_node_delete(struct man *m, struct man_node *p)
Line 350  man_node_delete(struct man *m, struct man_node *p)
 int  int
 man_addspan(struct man *m, const struct tbl_span *sp)  man_addspan(struct man *m, const struct tbl_span *sp)
 {  {
           struct man_node *n;
   
         if ( ! man_span_alloc(m, sp))          assert( ! (MAN_HALT & m->flags));
   
           n = man_node_alloc(m, sp->line, 0, MAN_TBL, MAN_MAX);
           n->span = sp;
   
           if ( ! man_node_append(m, n))
                 return(0);                  return(0);
         return(man_descope(m, 0, 0));  
           m->next = MAN_NEXT_SIBLING;
           return(man_descope(m, sp->line, 0));
 }  }
   
 static int  static int
Line 465  man_ptext(struct man *m, int line, char *buf, int offs
Line 461  man_ptext(struct man *m, int line, char *buf, int offs
 }  }
   
   
 int  static int
 man_pmacro(struct man *m, int ln, char *buf, int offs)  man_pmacro(struct man *m, int ln, char *buf, int offs)
 {  {
         int              i, j, ppos;          int              i, j, ppos;

Legend:
Removed from v.1.95  
changed lines
  Added in v.1.100

CVSweb