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

Diff for /mandoc/mdoc_html.c between version 1.68 and 1.92

version 1.68, 2010/05/29 18:47:54 version 1.92, 2010/07/02 12:54:33
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>   * Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@bsd.lv>
  *   *
  * Permission to use, copy, modify, and distribute this software for any   * Permission to use, copy, modify, and distribute this software for any
  * purpose with or without fee is hereby granted, provided that the above   * purpose with or without fee is hereby granted, provided that the above
Line 30 
Line 30 
 #include "mandoc.h"  #include "mandoc.h"
 #include "out.h"  #include "out.h"
 #include "html.h"  #include "html.h"
   #include "regs.h"
 #include "mdoc.h"  #include "mdoc.h"
 #include "main.h"  #include "main.h"
   
Line 53  static void    print_mdoc(MDOC_ARGS);
Line 54  static void    print_mdoc(MDOC_ARGS);
 static  void              print_mdoc_head(MDOC_ARGS);  static  void              print_mdoc_head(MDOC_ARGS);
 static  void              print_mdoc_node(MDOC_ARGS);  static  void              print_mdoc_node(MDOC_ARGS);
 static  void              print_mdoc_nodelist(MDOC_ARGS);  static  void              print_mdoc_nodelist(MDOC_ARGS);
   static  void              synopsis_pre(struct html *,
                                   const struct mdoc_node *);
   
 static  void              a2width(const char *, struct roffsu *);  static  void              a2width(const char *, struct roffsu *);
 static  void              a2offs(const char *, struct roffsu *);  static  void              a2offs(const char *, struct roffsu *);
Line 100  static int    mdoc_it_block_pre(MDOC_ARGS, enum mdoc_l
Line 103  static int    mdoc_it_block_pre(MDOC_ARGS, enum mdoc_l
                                 int, struct roffsu *, struct roffsu *);                                  int, struct roffsu *, struct roffsu *);
 static  int               mdoc_it_head_pre(MDOC_ARGS, enum mdoc_list,  static  int               mdoc_it_head_pre(MDOC_ARGS, enum mdoc_list,
                                 struct roffsu *);                                  struct roffsu *);
 static  int               mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list);  static  int               mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list,
                                   struct roffsu *);
 static  int               mdoc_it_pre(MDOC_ARGS);  static  int               mdoc_it_pre(MDOC_ARGS);
 static  int               mdoc_lb_pre(MDOC_ARGS);  static  int               mdoc_lb_pre(MDOC_ARGS);
 static  int               mdoc_li_pre(MDOC_ARGS);  static  int               mdoc_li_pre(MDOC_ARGS);
Line 254  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 258  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {mdoc_sp_pre, NULL}, /* br */          {mdoc_sp_pre, NULL}, /* br */
         {mdoc_sp_pre, NULL}, /* sp */          {mdoc_sp_pre, NULL}, /* sp */
         {mdoc__x_pre, mdoc__x_post}, /* %U */          {mdoc__x_pre, mdoc__x_post}, /* %U */
           {NULL, NULL}, /* Ta */
 };  };
   
   
Line 291  a2width(const char *p, struct roffsu *su)
Line 296  a2width(const char *p, struct roffsu *su)
   
   
 /*  /*
    * See the same function in mdoc_term.c for documentation.
    */
   static void
   synopsis_pre(struct html *h, const struct mdoc_node *n)
   {
           struct roffsu    su;
           struct htmlpair  tag;
   
           if (NULL == n->prev || ! (MDOC_SYNPRETTY & n->flags))
                   return;
   
           SCALE_VS_INIT(&su, 1);
           bufcat_su(h, "margin-top", &su);
           PAIR_STYLE_INIT(&tag, h);
   
           if (n->prev->tok == n->tok &&
                           MDOC_Fo != n->tok &&
                           MDOC_Ft != n->tok &&
                           MDOC_Fn != n->tok) {
                   print_otag(h, TAG_DIV, 0, NULL);
                   return;
           }
   
           switch (n->prev->tok) {
           case (MDOC_Fd):
                   /* FALLTHROUGH */
           case (MDOC_Fn):
                   /* FALLTHROUGH */
           case (MDOC_Fo):
                   /* FALLTHROUGH */
           case (MDOC_In):
                   /* FALLTHROUGH */
           case (MDOC_Vt):
                   print_otag(h, TAG_DIV, 1, &tag);
                   break;
           case (MDOC_Ft):
                   if (MDOC_Fn != n->tok && MDOC_Fo != n->tok) {
                           print_otag(h, TAG_DIV, 1, &tag);
                           break;
                   }
                   /* FALLTHROUGH */
           default:
                   print_otag(h, TAG_DIV, 0, NULL);
                   break;
           }
   }
   
   
   /*
  * Calculate the scaling unit passed in an `-offset' argument.  This   * Calculate the scaling unit passed in an `-offset' argument.  This
  * uses either a native scaling unit (e.g., 1i, 2m), one of a set of   * uses either a native scaling unit (e.g., 1i, 2m), one of a set of
  * predefined strings (indent, etc.), or the string length of the value.   * predefined strings (indent, etc.), or the string length of the value.
Line 383  print_mdoc_node(MDOC_ARGS)
Line 437  print_mdoc_node(MDOC_ARGS)
                 print_text(h, n->string);                  print_text(h, n->string);
                 return;                  return;
         default:          default:
                 if (mdocs[n->tok].pre)                  if (mdocs[n->tok].pre && ENDBODY_NOT == n->end)
                         child = (*mdocs[n->tok].pre)(m, n, h);                          child = (*mdocs[n->tok].pre)(m, n, h);
                 break;                  break;
         }          }
Line 399  print_mdoc_node(MDOC_ARGS)
Line 453  print_mdoc_node(MDOC_ARGS)
                 mdoc_root_post(m, n, h);                  mdoc_root_post(m, n, h);
                 break;                  break;
         default:          default:
                 if (mdocs[n->tok].post)                  if (mdocs[n->tok].post && ENDBODY_NOT == n->end)
                         (*mdocs[n->tok].post)(m, n, h);                          (*mdocs[n->tok].post)(m, n, h);
                 break;                  break;
         }          }
Line 682  mdoc_op_post(MDOC_ARGS)
Line 736  mdoc_op_post(MDOC_ARGS)
 static int  static int
 mdoc_nm_pre(MDOC_ARGS)  mdoc_nm_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair  tag;
           struct roffsu    su;
           const char      *cp;
   
         if (NULL == n->child && NULL == m->name)          /*
                 return(1);           * Accomodate for `Nm' being both an element (which may have
            * NULL children AND no m->name) and a block.
            */
   
         if (SEC_SYNOPSIS == n->sec &&          cp = NULL;
                         n->prev && MDOC_LINE & n->flags) {  
           if (MDOC_ELEM == n->type) {
                   if (NULL == n->child && NULL == m->name)
                           return(1);
                   synopsis_pre(h, n);
                   PAIR_CLASS_INIT(&tag, "name");
                   print_otag(h, TAG_SPAN, 1, &tag);
                   if (NULL == n->child)
                           print_text(h, m->name);
           } else if (MDOC_BLOCK == n->type) {
                   synopsis_pre(h, n);
   
                 bufcat_style(h, "clear", "both");                  bufcat_style(h, "clear", "both");
                   if (n->head->child || m->name) {
                           if (n->head->child && MDOC_TEXT ==
                                           n->head->child->type)
                                   cp = n->head->child->string;
                           if (NULL == cp || '\0' == *cp)
                                   cp = m->name;
   
                           SCALE_HS_INIT(&su, (double)strlen(cp));
                           bufcat_su(h, "padding-left", &su);
                   }
   
                 PAIR_STYLE_INIT(&tag, h);                  PAIR_STYLE_INIT(&tag, h);
                 print_otag(h, TAG_BR, 1, &tag);                  print_otag(h, TAG_DIV, 1, &tag);
         }          } else if (MDOC_HEAD == n->type) {
                   if (NULL == n->child && NULL == m->name)
                           return(1);
   
         PAIR_CLASS_INIT(&tag, "name");                  if (n->child && MDOC_TEXT == n->child->type)
         print_otag(h, TAG_SPAN, 1, &tag);                          cp = n->child->string;
         if (NULL == n->child)                  if (NULL == cp || '\0' == *cp)
                 print_text(h, m->name);                          cp = m->name;
   
                   SCALE_HS_INIT(&su, (double)strlen(cp));
   
                   bufcat_style(h, "float", "left");
                   bufcat_su(h, "min-width", &su);
                   SCALE_INVERT(&su);
                   bufcat_su(h, "margin-left", &su);
   
                   PAIR_STYLE_INIT(&tag, h);
                   print_otag(h, TAG_DIV, 1, &tag);
   
                   if (NULL == n->child)
                           print_text(h, m->name);
           } else if (MDOC_BODY == n->type) {
                   SCALE_HS_INIT(&su, 2);
                   bufcat_su(h, "margin-left", &su);
                   PAIR_STYLE_INIT(&tag, h);
                   print_otag(h, TAG_DIV, 1, &tag);
           }
   
         return(1);          return(1);
 }  }
   
Line 830  mdoc_it_block_pre(MDOC_ARGS, enum mdoc_list type, int 
Line 931  mdoc_it_block_pre(MDOC_ARGS, enum mdoc_list type, int 
         struct roffsu            su;          struct roffsu            su;
   
         nn = n->parent->parent;          nn = n->parent->parent;
         assert(nn->args);  
   
         /* XXX: see notes in mdoc_it_pre(). */          /* XXX: see notes in mdoc_it_pre(). */
   
Line 877  mdoc_it_block_pre(MDOC_ARGS, enum mdoc_list type, int 
Line 977  mdoc_it_block_pre(MDOC_ARGS, enum mdoc_list type, int 
   
 /* ARGSUSED */  /* ARGSUSED */
 static int  static int
 mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list type)  mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list type, struct roffsu *width)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;          struct roffsu    su;
Line 888  mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list type)
Line 988  mdoc_it_body_pre(MDOC_ARGS, enum mdoc_list type)
         case (LIST_ohang):          case (LIST_ohang):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (LIST_column):          case (LIST_column):
                   bufcat_su(h, "min-width", width);
                   bufcat_style(h, "clear", "none");
                   if (n->next)
                           bufcat_style(h, "float", "left");
                   PAIR_STYLE_INIT(&tag, h);
                   print_otag(h, TAG_DIV, 1, &tag);
                 break;                  break;
         default:          default:
                 /*                  /*
Line 920  mdoc_it_head_pre(MDOC_ARGS, enum mdoc_list type, struc
Line 1026  mdoc_it_head_pre(MDOC_ARGS, enum mdoc_list type, struc
                 print_otag(h, TAG_DIV, 0, &tag);                  print_otag(h, TAG_DIV, 0, &tag);
                 return(1);                  return(1);
         case (LIST_column):          case (LIST_column):
                 bufcat_su(h, "min-width", width);  
                 bufcat_style(h, "clear", "none");  
                 if (n->next && MDOC_HEAD == n->next->type)  
                         bufcat_style(h, "float", "left");  
                 PAIR_STYLE_INIT(&tag, h);  
                 print_otag(h, TAG_DIV, 1, &tag);  
                 break;                  break;
         default:          default:
                 bufcat_su(h, "min-width", width);                  bufcat_su(h, "min-width", width);
Line 989  mdoc_it_pre(MDOC_ARGS)
Line 1089  mdoc_it_pre(MDOC_ARGS)
         if (MDOC_BLOCK != n->type)          if (MDOC_BLOCK != n->type)
                 bl = bl->parent;                  bl = bl->parent;
   
         type = bl->data.list;          SCALE_HS_INIT(&offs, 0);
   
         /* Set default width and offset. */          assert(bl->data.Bl);
           type = bl->data.Bl->type;
           comp = bl->data.Bl->comp;
   
         SCALE_HS_INIT(&offs, 0);          if (bl->data.Bl->offs)
                   a2offs(bl->data.Bl->offs, &offs);
   
         switch (type) {          switch (type) {
         case (LIST_enum):          case (LIST_enum):
Line 1010  mdoc_it_pre(MDOC_ARGS)
Line 1113  mdoc_it_pre(MDOC_ARGS)
                 break;                  break;
         }          }
   
         /* Get width, offset, and compact arguments. */          if (bl->data.Bl->width)
                   a2width(bl->data.Bl->width, &width);
   
         for (wp = -1, comp = i = 0; i < (int)bl->args->argc; i++)          wp = -1;
           for (i = 0; bl->args && i < (int)bl->args->argc; i++)
                 switch (bl->args->argv[i].arg) {                  switch (bl->args->argv[i].arg) {
                 case (MDOC_Column):                  case (MDOC_Column):
                         wp = i; /* Save for later. */                          wp = i; /* Save for later. */
                         break;                          break;
                 case (MDOC_Width):  
                         a2width(bl->args->argv[i].value[0], &width);  
                         break;  
                 case (MDOC_Offset):  
                         a2offs(bl->args->argv[i].value[0], &offs);  
                         break;  
                 case (MDOC_Compact):  
                         comp = 1;  
                         break;  
                 default:                  default:
                         break;                          break;
                 }                  }
Line 1048  mdoc_it_pre(MDOC_ARGS)
Line 1144  mdoc_it_pre(MDOC_ARGS)
                 break;                  break;
         }          }
   
         /* Flip to body/block processing. */          if (LIST_column == type && MDOC_BODY == n->type) {
   
         if (MDOC_BODY == n->type)  
                 return(mdoc_it_body_pre(m, n, h, type));  
         if (MDOC_BLOCK == n->type)  
                 return(mdoc_it_block_pre(m, n, h, type, comp,  
                                         &offs, &width));  
   
         /* Override column widths. */  
   
         if (LIST_column == type) {  
                 nn = n->parent->child;                  nn = n->parent->child;
                 for (i = 0; nn && nn != n; nn = nn->next, i++)                  for (i = 0; nn && nn != n; nn = nn->next)
                         /* Counter... */ ;                          if (MDOC_BODY == nn->type)
                                   i++;
                 if (i < (int)bl->args->argv[wp].sz)                  if (i < (int)bl->args->argv[wp].sz)
                         a2width(bl->args->argv[wp].value[i], &width);                          a2width(bl->args->argv[wp].value[i], &width);
         }          }
   
         return(mdoc_it_head_pre(m, n, h, type, &width));          if (MDOC_HEAD == n->type)
                   return(mdoc_it_head_pre(m, n, h, type, &width));
           else if (MDOC_BODY == n->type)
                   return(mdoc_it_body_pre(m, n, h, type, &width));
   
           return(mdoc_it_block_pre(m, n, h, type, comp, &offs, &width));
 }  }
   
   
Line 1080  mdoc_bl_pre(MDOC_ARGS)
Line 1172  mdoc_bl_pre(MDOC_ARGS)
                 return(0);                  return(0);
         if (MDOC_BLOCK != n->type)          if (MDOC_BLOCK != n->type)
                 return(1);                  return(1);
         if (LIST_enum != n->data.list)          assert(n->data.Bl);
           if (LIST_enum != n->data.Bl->type)
                 return(1);                  return(1);
   
         ord = malloc(sizeof(struct ord));          ord = malloc(sizeof(struct ord));
Line 1104  mdoc_bl_post(MDOC_ARGS)
Line 1197  mdoc_bl_post(MDOC_ARGS)
   
         if (MDOC_BLOCK != n->type)          if (MDOC_BLOCK != n->type)
                 return;                  return;
         if (LIST_enum != n->data.list)          if (LIST_enum != n->data.Bl->type)
                 return;                  return;
   
         ord = h->ords.head;          ord = h->ords.head;
Line 1248  mdoc_d1_pre(MDOC_ARGS)
Line 1341  mdoc_d1_pre(MDOC_ARGS)
   
         /* FIXME: D1 shouldn't be literal. */          /* FIXME: D1 shouldn't be literal. */
   
         SCALE_VS_INIT(&su, INDENT - 1);          SCALE_VS_INIT(&su, INDENT - 2);
         bufcat_su(h, "margin-left", &su);          bufcat_su(h, "margin-left", &su);
         PAIR_CLASS_INIT(&tag[0], "lit");          PAIR_CLASS_INIT(&tag[0], "lit");
         PAIR_STYLE_INIT(&tag[1], h);          PAIR_STYLE_INIT(&tag[1], h);
Line 1310  static int
Line 1403  static int
 mdoc_bd_pre(MDOC_ARGS)  mdoc_bd_pre(MDOC_ARGS)
 {  {
         struct htmlpair          tag[2];          struct htmlpair          tag[2];
         int                      type, comp, i;          int                      comp;
         const struct mdoc_node  *bl, *nn;          const struct mdoc_node  *nn;
         struct roffsu            su;          struct roffsu            su;
   
         if (MDOC_BLOCK == n->type)          if (MDOC_HEAD == n->type)
                 bl = n;  
         else if (MDOC_HEAD == n->type)  
                 return(0);                  return(0);
         else  
                 bl = n->parent;  
   
         SCALE_VS_INIT(&su, 0);          SCALE_VS_INIT(&su, 0);
   
         type = comp = 0;          assert(n->data.Bd);
         for (i = 0; i < (int)bl->args->argc; i++)          if (n->data.Bd->offs)
                 switch (bl->args->argv[i].arg) {                  a2offs(n->data.Bd->offs, &su);
                 case (MDOC_Offset):  
                         a2offs(bl->args->argv[i].value[0], &su);  
                         break;  
                 case (MDOC_Compact):  
                         comp = 1;  
                         break;  
                 case (MDOC_Centred):  
                         /* FALLTHROUGH */  
                 case (MDOC_Ragged):  
                         /* FALLTHROUGH */  
                 case (MDOC_Filled):  
                         /* FALLTHROUGH */  
                 case (MDOC_Unfilled):  
                         /* FALLTHROUGH */  
                 case (MDOC_Literal):  
                         type = bl->args->argv[i].arg;  
                         break;  
                 default:  
                         break;  
                 }  
   
           comp = n->data.Bd->comp;
   
         /* FIXME: -centered, etc. formatting. */          /* FIXME: -centered, etc. formatting. */
         /* FIXME: does not respect -offset ??? */          /* FIXME: does not respect -offset ??? */
   
Line 1372  mdoc_bd_pre(MDOC_ARGS)
Line 1443  mdoc_bd_pre(MDOC_ARGS)
                 return(1);                  return(1);
         }          }
   
         if (MDOC_Unfilled != type && MDOC_Literal != type)          if (DISP_unfilled != n->data.Bd->type &&
                           DISP_literal != n->data.Bd->type)
                 return(1);                  return(1);
   
         PAIR_CLASS_INIT(&tag[0], "lit");          PAIR_CLASS_INIT(&tag[0], "lit");
Line 1439  mdoc_cd_pre(MDOC_ARGS)
Line 1511  mdoc_cd_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair tag;
   
         print_otag(h, TAG_DIV, 0, NULL);          synopsis_pre(h, n);
         PAIR_CLASS_INIT(&tag, "config");          PAIR_CLASS_INIT(&tag, "config");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
         return(1);          return(1);
Line 1516  static int
Line 1588  static int
 mdoc_fd_pre(MDOC_ARGS)  mdoc_fd_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;  
   
         if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {          synopsis_pre(h, n);
                 if (n->next && MDOC_Fd != n->next->tok) {  
                         SCALE_VS_INIT(&su, 1);  
                         bufcat_su(h, "margin-bottom", &su);  
                         PAIR_STYLE_INIT(&tag, h);  
                         print_otag(h, TAG_DIV, 1, &tag);  
                 } else  
                         print_otag(h, TAG_DIV, 0, NULL);  
         }  
   
         PAIR_CLASS_INIT(&tag, "macro");          PAIR_CLASS_INIT(&tag, "macro");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
Line 1539  static int
Line 1602  static int
 mdoc_vt_pre(MDOC_ARGS)  mdoc_vt_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;  
   
         if (SEC_SYNOPSIS == n->sec && MDOC_BLOCK == n->type) {          if (MDOC_BLOCK == n->type) {
                 if (n->next && MDOC_Vt != n->next->tok) {                  synopsis_pre(h, n);
                         SCALE_VS_INIT(&su, 1);  
                         bufcat_su(h, "margin-bottom", &su);  
                         PAIR_STYLE_INIT(&tag, h);  
                         print_otag(h, TAG_DIV, 1, &tag);  
                 } else  
                         print_otag(h, TAG_DIV, 0, NULL);  
   
                 return(1);                  return(1);
           } else if (MDOC_ELEM == n->type) {
                   synopsis_pre(h, n);
         } else if (MDOC_HEAD == n->type)          } else if (MDOC_HEAD == n->type)
                 return(0);                  return(0);
   
Line 1566  mdoc_ft_pre(MDOC_ARGS)
Line 1623  mdoc_ft_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
   
         if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags)          synopsis_pre(h, n);
                 print_otag(h, TAG_DIV, 0, NULL);  
   
         PAIR_CLASS_INIT(&tag, "ftype");          PAIR_CLASS_INIT(&tag, "ftype");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
         return(1);          return(1);
Line 1585  mdoc_fn_pre(MDOC_ARGS)
Line 1640  mdoc_fn_pre(MDOC_ARGS)
         char                     nbuf[BUFSIZ];          char                     nbuf[BUFSIZ];
         const char              *sp, *ep;          const char              *sp, *ep;
         int                      sz, i;          int                      sz, i;
         struct roffsu            su;  
   
         if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {          synopsis_pre(h, n);
                 SCALE_HS_INIT(&su, INDENT);  
                 bufcat_su(h, "margin-left", &su);  
                 su.scale = -su.scale;  
                 bufcat_su(h, "text-indent", &su);  
                 if (n->next) {  
                         SCALE_VS_INIT(&su, 1);  
                         bufcat_su(h, "margin-bottom", &su);  
                 }  
                 PAIR_STYLE_INIT(&tag[0], h);  
                 print_otag(h, TAG_DIV, 1, tag);  
         }  
   
         /* Split apart into type and name. */          /* Split apart into type and name. */
         assert(n->child->string);          assert(n->child->string);
Line 1627  mdoc_fn_pre(MDOC_ARGS)
Line 1670  mdoc_fn_pre(MDOC_ARGS)
          */           */
   
 #if 0  #if 0
         if (SEC_SYNOPSIS == n->sec) {          if (MDOC_SYNPRETTY & n->flags) {
                 nbuf[0] = '\0';                  nbuf[0] = '\0';
                 html_idcat(nbuf, sp, BUFSIZ);                  html_idcat(nbuf, sp, BUFSIZ);
                 PAIR_ID_INIT(&tag[1], nbuf);                  PAIR_ID_INIT(&tag[1], nbuf);
Line 1657  mdoc_fn_pre(MDOC_ARGS)
Line 1700  mdoc_fn_pre(MDOC_ARGS)
   
         for (nn = n->child->next; nn; nn = nn->next) {          for (nn = n->child->next; nn; nn = nn->next) {
                 i = 1;                  i = 1;
                 if (SEC_SYNOPSIS == n->sec)                  if (MDOC_SYNPRETTY & n->flags)
                         i = 2;                          i = 2;
                 t = print_otag(h, TAG_SPAN, i, tag);                  t = print_otag(h, TAG_SPAN, i, tag);
                 print_text(h, nn->string);                  print_text(h, nn->string);
Line 1667  mdoc_fn_pre(MDOC_ARGS)
Line 1710  mdoc_fn_pre(MDOC_ARGS)
         }          }
   
         print_text(h, ")");          print_text(h, ")");
         if (SEC_SYNOPSIS == n->sec)          if (MDOC_SYNPRETTY & n->flags)
                 print_text(h, ";");                  print_text(h, ";");
   
         return(0);          return(0);
Line 1783  mdoc_mt_pre(MDOC_ARGS)
Line 1826  mdoc_mt_pre(MDOC_ARGS)
 static int  static int
 mdoc_fo_pre(MDOC_ARGS)  mdoc_fo_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair  tag;
         struct roffsu   su;          struct tag      *t;
   
         if (MDOC_BODY == n->type) {          if (MDOC_BODY == n->type) {
                 h->flags |= HTML_NOSPACE;                  h->flags |= HTML_NOSPACE;
                 print_text(h, "(");                  print_text(h, "(");
                 h->flags |= HTML_NOSPACE;                  h->flags |= HTML_NOSPACE;
                 return(1);                  return(1);
         } else if (MDOC_BLOCK == n->type && n->next) {          } else if (MDOC_BLOCK == n->type) {
                 SCALE_VS_INIT(&su, 1);                  synopsis_pre(h, n);
                 bufcat_su(h, "margin-bottom", &su);  
                 PAIR_STYLE_INIT(&tag, h);  
                 print_otag(h, TAG_DIV, 1, &tag);  
                 return(1);                  return(1);
         }          }
   
           /* XXX: we drop non-initial arguments as per groff. */
   
           assert(n->child);
           assert(n->child->string);
   
         PAIR_CLASS_INIT(&tag, "fname");          PAIR_CLASS_INIT(&tag, "fname");
         print_otag(h, TAG_SPAN, 1, &tag);          t = print_otag(h, TAG_SPAN, 1, &tag);
         return(1);          print_text(h, n->child->string);
           print_tagq(h, t);
           return(0);
 }  }
   
   
Line 1809  mdoc_fo_pre(MDOC_ARGS)
Line 1856  mdoc_fo_pre(MDOC_ARGS)
 static void  static void
 mdoc_fo_post(MDOC_ARGS)  mdoc_fo_post(MDOC_ARGS)
 {  {
   
         if (MDOC_BODY != n->type)          if (MDOC_BODY != n->type)
                 return;                  return;
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
Line 1826  mdoc_in_pre(MDOC_ARGS)
Line 1874  mdoc_in_pre(MDOC_ARGS)
         struct tag              *t;          struct tag              *t;
         struct htmlpair          tag[2];          struct htmlpair          tag[2];
         int                      i;          int                      i;
         struct roffsu            su;  
   
         if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {          synopsis_pre(h, n);
                 if (n->next && MDOC_In != n->next->tok) {  
                         SCALE_VS_INIT(&su, 1);  
                         bufcat_su(h, "margin-bottom", &su);  
                         PAIR_STYLE_INIT(&tag[0], h);  
                         print_otag(h, TAG_DIV, 1, tag);  
                 } else  
                         print_otag(h, TAG_DIV, 0, NULL);  
         }  
   
         /* FIXME: there's a buffer bug in here somewhere. */  
   
         PAIR_CLASS_INIT(&tag[0], "includes");          PAIR_CLASS_INIT(&tag[0], "includes");
         print_otag(h, TAG_SPAN, 1, tag);          print_otag(h, TAG_SPAN, 1, tag);
   
         if (SEC_SYNOPSIS == n->sec)          if (MDOC_SYNPRETTY & n->flags && MDOC_LINE & n->flags)
                 print_text(h, "#include");                  print_text(h, "#include");
   
         print_text(h, "<");          print_text(h, "<");
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
   
         /* XXX -- see warning in termp_in_post(). */  
   
         for (nn = n->child; nn; nn = nn->next) {          for (nn = n->child; nn; nn = nn->next) {
                 PAIR_CLASS_INIT(&tag[0], "link-includes");                  PAIR_CLASS_INIT(&tag[0], "link-includes");
                 i = 1;                  i = 1;
Line 1980  mdoc_ap_pre(MDOC_ARGS)
Line 2015  mdoc_ap_pre(MDOC_ARGS)
 static int  static int
 mdoc_bf_pre(MDOC_ARGS)  mdoc_bf_pre(MDOC_ARGS)
 {  {
         int              i;  
         struct htmlpair  tag[2];          struct htmlpair  tag[2];
         struct roffsu    su;          struct roffsu    su;
   
         if (MDOC_HEAD == n->type)          if (MDOC_HEAD == n->type)
                 return(0);                  return(0);
         else if (MDOC_BLOCK != n->type)          else if (MDOC_BODY != n->type)
                 return(1);                  return(1);
   
         PAIR_CLASS_INIT(&tag[0], "lit");          assert(n->data.Bf);
   
         if (n->head->child) {          if (FONT_Em == n->data.Bf->font)
                 if ( ! strcmp("Em", n->head->child->string))                  PAIR_CLASS_INIT(&tag[0], "emph");
                         PAIR_CLASS_INIT(&tag[0], "emph");          else if (FONT_Sy == n->data.Bf->font)
                 else if ( ! strcmp("Sy", n->head->child->string))                  PAIR_CLASS_INIT(&tag[0], "symb");
                         PAIR_CLASS_INIT(&tag[0], "symb");          else if (FONT_Li == n->data.Bf->font)
                 else if ( ! strcmp("Li", n->head->child->string))                  PAIR_CLASS_INIT(&tag[0], "lit");
                         PAIR_CLASS_INIT(&tag[0], "lit");          else
         } else {                  PAIR_CLASS_INIT(&tag[0], "none");
                 assert(n->args);  
                 for (i = 0; i < (int)n->args->argc; i++)  
                         switch (n->args->argv[i].arg) {  
                         case (MDOC_Symbolic):  
                                 PAIR_CLASS_INIT(&tag[0], "symb");  
                                 break;  
                         case (MDOC_Literal):  
                                 PAIR_CLASS_INIT(&tag[0], "lit");  
                                 break;  
                         case (MDOC_Emphasis):  
                                 PAIR_CLASS_INIT(&tag[0], "emph");  
                                 break;  
                         default:  
                                 break;  
                         }  
         }  
   
         /* FIXME: div's have spaces stripped--we want them. */          /*
            * We want this to be inline-formatted, but needs to be div to
            * accept block children.
            */
         bufcat_style(h, "display", "inline");          bufcat_style(h, "display", "inline");
         SCALE_HS_INIT(&su, 1);          SCALE_HS_INIT(&su, 1);
         bufcat_su(h, "margin-right", &su);          /* Needs a left-margin for spacing. */
           bufcat_su(h, "margin-left", &su);
         PAIR_STYLE_INIT(&tag[1], h);          PAIR_STYLE_INIT(&tag[1], h);
         print_otag(h, TAG_DIV, 2, tag);          print_otag(h, TAG_DIV, 2, tag);
         return(1);          return(1);
Line 2091  mdoc_li_pre(MDOC_ARGS)
Line 2112  mdoc_li_pre(MDOC_ARGS)
   
         PAIR_CLASS_INIT(&tag, "lit");          PAIR_CLASS_INIT(&tag, "lit");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
         if (NULL == n->child)  
                 print_text(h, "");  
         return(1);          return(1);
 }  }
   

Legend:
Removed from v.1.68  
changed lines
  Added in v.1.92

CVSweb