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

Diff for /src/usr.bin/mandoc/mdoc_term.c between version 1.44 and 1.45

version 1.44, 2009/08/09 19:15:14 version 1.45, 2009/08/09 19:28:21
Line 305 
Line 305 
 static  size_t    arg_offset(const struct mdoc_argv *);  static  size_t    arg_offset(const struct mdoc_argv *);
 static  size_t    arg_width(const struct mdoc_argv *, int);  static  size_t    arg_width(const struct mdoc_argv *, int);
 static  int       arg_listtype(const struct mdoc_node *);  static  int       arg_listtype(const struct mdoc_node *);
 static  int       fmt_block_vspace(struct termp *,  static  void      fmt_block_vspace(struct termp *,
                         const struct mdoc_node *,                          const struct mdoc_node *,
                         const struct mdoc_node *);                          const struct mdoc_node *);
 static  void      print_node(DECL_ARGS);  static  void      print_node(DECL_ARGS);
Line 656 
Line 656 
   
   
 /* ARGSUSED */  /* ARGSUSED */
 static int  static void
 fmt_block_vspace(struct termp *p,  fmt_block_vspace(struct termp *p,
                 const struct mdoc_node *bl,                  const struct mdoc_node *bl,
                 const struct mdoc_node *node)                  const struct mdoc_node *node)
Line 665 
Line 665 
   
         term_newln(p);          term_newln(p);
   
         if (arg_hasattr(MDOC_Compact, bl))          if (MDOC_Bl == bl->tok && arg_hasattr(MDOC_Compact, bl))
                 return(1);                  return;
         /* XXX - not documented! */  
         else if (arg_hasattr(MDOC_Column, bl))  
                 return(1);  
   
           /*
            * Search through our prior nodes.  If we follow a `Ss' or `Sh',
            * then don't vspace.
            */
   
         for (n = node; n; n = n->parent) {          for (n = node; n; n = n->parent) {
                 if (MDOC_BLOCK != n->type)                  if (MDOC_BLOCK != n->type)
                         continue;                          continue;
                 if (MDOC_Ss == n->tok)                  if (MDOC_Ss == n->tok)
                         break;                          return;
                 if (MDOC_Sh == n->tok)                  if (MDOC_Sh == n->tok)
                         break;                          return;
                 if (NULL == n->prev)                  if (NULL == n->prev)
                         continue;                          continue;
                 term_vspace(p);  
                 break;                  break;
         }          }
   
         return(1);          /*
            * XXX - not documented: a `-column' does not ever assert vspace
            * within the list.
            */
   
           if (MDOC_Bl == bl->tok && arg_hasattr(MDOC_Column, bl))
                   if (node->prev && MDOC_It == node->prev->tok)
                           return;
   
           /*
            * XXX - not documented: a `-diag' without a body does not
            * assert a vspace prior to the next element.
            */
           if (MDOC_Bl == bl->tok && arg_hasattr(MDOC_Diag, bl))
                   if (node->prev && MDOC_It == node->prev->tok) {
                           assert(node->prev->body);
                           if (NULL == node->prev->body->child)
                                   return;
                   }
   
           term_vspace(p);
 }  }
   
   
Line 724 
Line 745 
         int                     i, type, keys[3], vals[3];          int                     i, type, keys[3], vals[3];
         size_t                  width, offset;          size_t                  width, offset;
   
         if (MDOC_BLOCK == node->type)          if (MDOC_BLOCK == node->type) {
                 return(fmt_block_vspace(p, node->parent->parent, node));                  fmt_block_vspace(p, node->parent->parent, node);
                   return(1);
           }
   
         bl = node->parent->parent->parent;          bl = node->parent->parent->parent;
   
Line 1528 
Line 1551 
          * line.  Blank lines are allowed.           * line.  Blank lines are allowed.
          */           */
   
         if (MDOC_BLOCK == node->type)          if (MDOC_BLOCK == node->type) {
                 return(fmt_block_vspace(p, node, node));                  fmt_block_vspace(p, node, node);
         else if (MDOC_BODY != node->type)  
                 return(1);                  return(1);
           } else if (MDOC_BODY != node->type)
                   return(1);
   
         /* FIXME: display type should be mandated by parser. */          /* FIXME: display type should be mandated by parser. */
   
Line 1706 
Line 1730 
   
 /* ARGSUSED */  /* ARGSUSED */
 static int  static int
   termp_pa_pre(DECL_ARGS)
   {
   
           pair->flag |= ttypes[TTYPE_FILE];
           return(1);
   }
   
   
   /* ARGSUSED */
   static int
 termp_pf_pre(DECL_ARGS)  termp_pf_pre(DECL_ARGS)
 {  {
   
Line 1754 
Line 1788 
   
         if (MDOC_HEAD == node->type)          if (MDOC_HEAD == node->type)
                 term_newln(p);                  term_newln(p);
 }  
   
   
 /* ARGSUSED */  
 static int  
 termp_pa_pre(DECL_ARGS)  
 {  
   
         pair->flag |= ttypes[TTYPE_FILE];  
         return(1);  
 }  }
   
   

Legend:
Removed from v.1.44  
changed lines
  Added in v.1.45