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

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

version 1.96, 2011/01/03 11:31:26 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 129  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)
 {  {
   
           m->flags |= MAN_NEWLINE;
   
         assert( ! (MAN_HALT & m->flags));          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) :
Line 229  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 238  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 247  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 260  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 273  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 286  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 317  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 361  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;
   
         assert( ! (MAN_HALT & m->flags));          assert( ! (MAN_HALT & m->flags));
         if ( ! man_span_alloc(m, sp))  
           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

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

CVSweb