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

Diff for /mandoc/mdoc_term.c between version 1.53 and 1.54

version 1.53, 2009/07/21 14:28:36 version 1.54, 2009/07/21 15:03:37
Line 308  static int   arg_getattr(int, const struct mdoc_node *
Line 308  static int   arg_getattr(int, const struct mdoc_node *
 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 659  arg_getattrs(const int *keys, int *vals, 
Line 659  arg_getattrs(const int *keys, int *vals, 
   
   
 /* 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 669  fmt_block_vspace(struct termp *p, 
Line 669  fmt_block_vspace(struct termp *p, 
         term_newln(p);          term_newln(p);
   
         if (arg_hasattr(MDOC_Compact, bl))          if (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
            * vertical space within the list.
            */
   
           if (arg_hasattr(MDOC_Column, bl))
                   if (node->prev && MDOC_It == node->prev->tok)
                           return;
   
           term_vspace(p);
 }  }
   
   
Line 727  termp_it_pre(DECL_ARGS)
Line 737  termp_it_pre(DECL_ARGS)
         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 1531  termp_bd_pre(DECL_ARGS)
Line 1543  termp_bd_pre(DECL_ARGS)
          * 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);
           } else if (MDOC_BODY != node->type)
                 return(1);                  return(1);
   
         /* FIXME: display type should be mandated by parser. */          /* FIXME: display type should be mandated by parser. */

Legend:
Removed from v.1.53  
changed lines
  Added in v.1.54

CVSweb