[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.52 and 1.65

version 1.52, 2010/01/01 17:14:29 version 1.65, 2010/05/17 22:11:42
Line 27 
Line 27 
 #include <string.h>  #include <string.h>
 #include <unistd.h>  #include <unistd.h>
   
   #include "mandoc.h"
 #include "out.h"  #include "out.h"
 #include "html.h"  #include "html.h"
 #include "mdoc.h"  #include "mdoc.h"
Line 200  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 201  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {NULL, NULL}, /* Dc */          {NULL, NULL}, /* Dc */
         {mdoc_dq_pre, mdoc_dq_post}, /* Do */          {mdoc_dq_pre, mdoc_dq_post}, /* Do */
         {mdoc_dq_pre, mdoc_dq_post}, /* Dq */          {mdoc_dq_pre, mdoc_dq_post}, /* Dq */
         {NULL, NULL}, /* Ec */          {NULL, NULL}, /* Ec */ /* FIXME: no space */
         {NULL, NULL}, /* Ef */          {NULL, NULL}, /* Ef */
         {mdoc_em_pre, NULL}, /* Em */          {mdoc_em_pre, NULL}, /* Em */
         {NULL, NULL}, /* Eo */          {NULL, NULL}, /* Eo */
Line 266  html_mdoc(void *arg, const struct mdoc *m)
Line 267  html_mdoc(void *arg, const struct mdoc *m)
   
         h = (struct html *)arg;          h = (struct html *)arg;
   
         print_gen_doctype(h);          print_gen_decls(h);
         t = print_otag(h, TAG_HTML, 0, NULL);          t = print_otag(h, TAG_HTML, 0, NULL);
         print_mdoc(mdoc_meta(m), mdoc_node(m), h);          print_mdoc(mdoc_meta(m), mdoc_node(m), h);
         print_tagq(h, t);          print_tagq(h, t);
Line 387  print_mdoc_head(MDOC_ARGS)
Line 388  print_mdoc_head(MDOC_ARGS)
   
         print_gen_head(h);          print_gen_head(h);
         bufinit(h);          bufinit(h);
         buffmt(h, "%s(%d)", m->title, m->msec);          buffmt(h, "%s(%s)", m->title, m->msec);
   
         if (m->arch) {          if (m->arch) {
                 bufcat(h, " (");                  bufcat(h, " (");
Line 509  mdoc_root_pre(MDOC_ARGS)
Line 510  mdoc_root_pre(MDOC_ARGS)
         }          }
   
         (void)snprintf(title, BUFSIZ - 1,          (void)snprintf(title, BUFSIZ - 1,
                         "%s(%d)", m->title, m->msec);                          "%s(%s)", m->title, m->msec);
   
         /* XXX: see note in mdoc_root_post() about divs. */          /* XXX: see note in mdoc_root_post() about divs. */
   
Line 589  mdoc_sh_pre(MDOC_ARGS)
Line 590  mdoc_sh_pre(MDOC_ARGS)
                         html_idcat(buf, " ", BUFSIZ);                          html_idcat(buf, " ", BUFSIZ);
         }          }
   
         /*  
          * TODO: make sure there are no duplicates, as HTML does not  
          * allow for multiple `id' tags of the same name.  
          */  
   
         PAIR_CLASS_INIT(&tag[0], "sec-head");          PAIR_CLASS_INIT(&tag[0], "sec-head");
         tag[1].key = ATTR_ID;          PAIR_ID_INIT(&tag[1], buf);
         tag[1].val = buf;  
         print_otag(h, TAG_DIV, 2, tag);          print_otag(h, TAG_DIV, 2, tag);
         return(1);          return(1);
 }  }
Line 648  mdoc_ss_pre(MDOC_ARGS)
Line 644  mdoc_ss_pre(MDOC_ARGS)
   
         PAIR_CLASS_INIT(&tag[0], "ssec-head");          PAIR_CLASS_INIT(&tag[0], "ssec-head");
         PAIR_STYLE_INIT(&tag[1], h);          PAIR_STYLE_INIT(&tag[1], h);
         tag[2].key = ATTR_ID;          PAIR_ID_INIT(&tag[2], buf);
         tag[2].val = buf;  
         print_otag(h, TAG_DIV, 3, tag);          print_otag(h, TAG_DIV, 3, tag);
         return(1);          return(1);
 }  }
Line 671  mdoc_fl_pre(MDOC_ARGS)
Line 667  mdoc_fl_pre(MDOC_ARGS)
   
         print_text(h, "\\-");          print_text(h, "\\-");
   
         /* A blank `Fl' should incur a subsequent space. */  
   
         if (n->child)          if (n->child)
                 h->flags |= HTML_NOSPACE;                  h->flags |= HTML_NOSPACE;
           else if (n->next && n->next->line == n->line)
                   h->flags |= HTML_NOSPACE;
   
         return(1);          return(1);
 }  }
Line 734  mdoc_nm_pre(MDOC_ARGS)
Line 730  mdoc_nm_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair tag;
   
         if (SEC_SYNOPSIS == n->sec && n->prev) {          if (NULL == n->child && NULL == m->name)
                   return(1);
   
           if (SEC_SYNOPSIS == n->sec &&
                           n->prev && MDOC_LINE & n->flags) {
                 bufcat_style(h, "clear", "both");                  bufcat_style(h, "clear", "both");
                 PAIR_STYLE_INIT(&tag, h);                  PAIR_STYLE_INIT(&tag, h);
                 print_otag(h, TAG_BR, 1, &tag);                  print_otag(h, TAG_BR, 1, &tag);
Line 756  mdoc_xr_pre(MDOC_ARGS)
Line 756  mdoc_xr_pre(MDOC_ARGS)
         struct htmlpair          tag[2];          struct htmlpair          tag[2];
         const struct mdoc_node  *nn;          const struct mdoc_node  *nn;
   
           if (NULL == n->child)
                   return(0);
   
         PAIR_CLASS_INIT(&tag[0], "link-man");          PAIR_CLASS_INIT(&tag[0], "link-man");
   
         if (h->base_man) {          if (h->base_man) {
                 buffmt_man(h, n->child->string,                  buffmt_man(h, n->child->string,
                                 n->child->next ?                                  n->child->next ?
                                 n->child->next->string : NULL);                                  n->child->next->string : NULL);
                 tag[1].key = ATTR_HREF;                  PAIR_HREF_INIT(&tag[1], h->buf);
                 tag[1].val = h->buf;  
                 print_otag(h, TAG_A, 2, tag);                  print_otag(h, TAG_A, 2, tag);
         } else          } else
                 print_otag(h, TAG_A, 1, tag);                  print_otag(h, TAG_A, 1, tag);
Line 1119  mdoc_bl_pre(MDOC_ARGS)
Line 1121  mdoc_bl_pre(MDOC_ARGS)
 {  {
         struct ord      *ord;          struct ord      *ord;
   
           if (MDOC_HEAD == n->type)
                   return(0);
         if (MDOC_BLOCK != n->type)          if (MDOC_BLOCK != n->type)
                 return(1);                  return(1);
         if (MDOC_Enum != a2list(n))          if (MDOC_Enum != a2list(n))
Line 1181  mdoc_ex_pre(MDOC_ARGS)
Line 1185  mdoc_ex_pre(MDOC_ARGS)
                         h->flags &= ~HTML_NOSPACE;                          h->flags &= ~HTML_NOSPACE;
         }          }
   
         if (n->child->next)          if (n->child && n->child->next)
                 print_text(h, "utilities exit");                  print_text(h, "utilities exit");
         else          else
                 print_text(h, "utility exits");                  print_text(h, "utility exits");
Line 1289  mdoc_d1_pre(MDOC_ARGS)
Line 1293  mdoc_d1_pre(MDOC_ARGS)
   
         /* FIXME: D1 shouldn't be literal. */          /* FIXME: D1 shouldn't be literal. */
   
         SCALE_VS_INIT(&su, INDENT - 2);          SCALE_VS_INIT(&su, INDENT - 1);
         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 1306  mdoc_sx_pre(MDOC_ARGS)
Line 1310  mdoc_sx_pre(MDOC_ARGS)
         const struct mdoc_node  *nn;          const struct mdoc_node  *nn;
         char                     buf[BUFSIZ];          char                     buf[BUFSIZ];
   
         /* FIXME: duplicates? */  
   
         strlcpy(buf, "#", BUFSIZ);          strlcpy(buf, "#", BUFSIZ);
         for (nn = n->child; nn; nn = nn->next) {          for (nn = n->child; nn; nn = nn->next) {
                 html_idcat(buf, nn->string, BUFSIZ);                  html_idcat(buf, nn->string, BUFSIZ);
Line 1316  mdoc_sx_pre(MDOC_ARGS)
Line 1318  mdoc_sx_pre(MDOC_ARGS)
         }          }
   
         PAIR_CLASS_INIT(&tag[0], "link-sec");          PAIR_CLASS_INIT(&tag[0], "link-sec");
         tag[1].key = ATTR_HREF;          PAIR_HREF_INIT(&tag[1], buf);
         tag[1].val = buf;  
   
         print_otag(h, TAG_A, 2, tag);          print_otag(h, TAG_A, 2, tag);
         return(1);          return(1);
Line 1392  mdoc_bd_pre(MDOC_ARGS)
Line 1393  mdoc_bd_pre(MDOC_ARGS)
                 }                  }
   
         /* FIXME: -centered, etc. formatting. */          /* FIXME: -centered, etc. formatting. */
           /* FIXME: does not respect -offset ??? */
   
         if (MDOC_BLOCK == n->type) {          if (MDOC_BLOCK == n->type) {
                 bufcat_su(h, "margin-left", &su);                  bufcat_su(h, "margin-left", &su);
Line 1404  mdoc_bd_pre(MDOC_ARGS)
Line 1406  mdoc_bd_pre(MDOC_ARGS)
                                 break;                                  break;
                 }                  }
                 if (comp) {                  if (comp) {
                         print_otag(h, TAG_DIV, 0, tag);                          PAIR_STYLE_INIT(&tag[0], h);
                           print_otag(h, TAG_DIV, 1, tag);
                         return(1);                          return(1);
                 }                  }
                 SCALE_VS_INIT(&su, 1);                  SCALE_VS_INIT(&su, 1);
Line 1560  mdoc_fd_pre(MDOC_ARGS)
Line 1563  mdoc_fd_pre(MDOC_ARGS)
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;          struct roffsu    su;
   
         if (SEC_SYNOPSIS == n->sec) {          if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {
                 if (n->next && MDOC_Fd != n->next->tok) {                  if (n->next && MDOC_Fd != n->next->tok) {
                         SCALE_VS_INIT(&su, 1);                          SCALE_VS_INIT(&su, 1);
                         bufcat_su(h, "margin-bottom", &su);                          bufcat_su(h, "margin-bottom", &su);
Line 1583  mdoc_vt_pre(MDOC_ARGS)
Line 1586  mdoc_vt_pre(MDOC_ARGS)
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;          struct roffsu    su;
   
         if (SEC_SYNOPSIS == n->sec) {          if (SEC_SYNOPSIS == n->sec && MDOC_BLOCK == n->type) {
                 if (n->prev && MDOC_Vt != n->prev->tok) {                  if (n->next && MDOC_Vt != n->next->tok) {
                         SCALE_VS_INIT(&su, 1);                          SCALE_VS_INIT(&su, 1);
                         bufcat_su(h, "margin-top", &su);                          bufcat_su(h, "margin-bottom", &su);
                         PAIR_STYLE_INIT(&tag, h);                          PAIR_STYLE_INIT(&tag, h);
                         print_otag(h, TAG_DIV, 1, &tag);                          print_otag(h, TAG_DIV, 1, &tag);
                 } else                  } else
                         print_otag(h, TAG_DIV, 0, NULL);                          print_otag(h, TAG_DIV, 0, NULL);
         }  
                   return(1);
           } else if (MDOC_HEAD == n->type)
                   return(0);
   
         PAIR_CLASS_INIT(&tag, "type");          PAIR_CLASS_INIT(&tag, "type");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
Line 1604  static int
Line 1610  static int
 mdoc_ft_pre(MDOC_ARGS)  mdoc_ft_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;  
   
         if (SEC_SYNOPSIS == n->sec) {          if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags)
                 if (n->prev && MDOC_Fo == n->prev->tok) {                  print_otag(h, TAG_DIV, 0, NULL);
                         SCALE_VS_INIT(&su, 1);  
                         bufcat_su(h, "margin-top", &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, "ftype");          PAIR_CLASS_INIT(&tag, "ftype");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
Line 1634  mdoc_fn_pre(MDOC_ARGS)
Line 1632  mdoc_fn_pre(MDOC_ARGS)
         int                      sz, i;          int                      sz, i;
         struct roffsu            su;          struct roffsu            su;
   
         if (SEC_SYNOPSIS == n->sec) {          if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {
                 SCALE_HS_INIT(&su, INDENT);                  SCALE_HS_INIT(&su, INDENT);
                 bufcat_su(h, "margin-left", &su);                  bufcat_su(h, "margin-left", &su);
                 su.scale = -su.scale;                  su.scale = -su.scale;
Line 1668  mdoc_fn_pre(MDOC_ARGS)
Line 1666  mdoc_fn_pre(MDOC_ARGS)
         }          }
   
         PAIR_CLASS_INIT(&tag[0], "fname");          PAIR_CLASS_INIT(&tag[0], "fname");
   
           /*
            * FIXME: only refer to IDs that we know exist.
            */
   
   #if 0
           if (SEC_SYNOPSIS == n->sec) {
                   nbuf[0] = '\0';
                   html_idcat(nbuf, sp, BUFSIZ);
                   PAIR_ID_INIT(&tag[1], nbuf);
           } else {
                   strlcpy(nbuf, "#", BUFSIZ);
                   html_idcat(nbuf, sp, BUFSIZ);
                   PAIR_HREF_INIT(&tag[1], nbuf);
           }
   #endif
   
         t = print_otag(h, TAG_SPAN, 1, tag);          t = print_otag(h, TAG_SPAN, 1, tag);
   
         if (sp) {          if (sp) {
                 (void)strlcpy(nbuf, sp, BUFSIZ);                  strlcpy(nbuf, sp, BUFSIZ);
                 print_text(h, nbuf);                  print_text(h, nbuf);
         }          }
   
Line 1772  mdoc_lk_pre(MDOC_ARGS)
Line 1787  mdoc_lk_pre(MDOC_ARGS)
         nn = n->child;          nn = n->child;
   
         PAIR_CLASS_INIT(&tag[0], "link-ext");          PAIR_CLASS_INIT(&tag[0], "link-ext");
         tag[1].key = ATTR_HREF;          PAIR_HREF_INIT(&tag[1], nn->string);
         tag[1].val = nn->string;  
         print_otag(h, TAG_A, 2, tag);          print_otag(h, TAG_A, 2, tag);
   
         if (NULL == nn->next)          if (NULL == nn->next)
Line 1800  mdoc_mt_pre(MDOC_ARGS)
Line 1814  mdoc_mt_pre(MDOC_ARGS)
                 bufinit(h);                  bufinit(h);
                 bufcat(h, "mailto:");                  bufcat(h, "mailto:");
                 bufcat(h, nn->string);                  bufcat(h, nn->string);
                 PAIR_STYLE_INIT(&tag[1], h);                  PAIR_HREF_INIT(&tag[1], h->buf);
                 t = print_otag(h, TAG_A, 2, tag);                  t = print_otag(h, TAG_A, 2, tag);
                 print_text(h, nn->string);                  print_text(h, nn->string);
                 print_tagq(h, t);                  print_tagq(h, t);
Line 1815  static int
Line 1829  static int
 mdoc_fo_pre(MDOC_ARGS)  mdoc_fo_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair tag;
           struct roffsu   su;
   
         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)          } else if (MDOC_BLOCK == n->type && n->next) {
                   SCALE_VS_INIT(&su, 1);
                   bufcat_su(h, "margin-bottom", &su);
                   PAIR_STYLE_INIT(&tag, h);
                   print_otag(h, TAG_DIV, 1, &tag);
                 return(1);                  return(1);
           }
   
         PAIR_CLASS_INIT(&tag, "fname");          PAIR_CLASS_INIT(&tag, "fname");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
Line 1853  mdoc_in_pre(MDOC_ARGS)
Line 1873  mdoc_in_pre(MDOC_ARGS)
         int                      i;          int                      i;
         struct roffsu            su;          struct roffsu            su;
   
         if (SEC_SYNOPSIS == n->sec) {          if (SEC_SYNOPSIS == n->sec && MDOC_LINE & n->flags) {
                 if (n->next && MDOC_In != n->next->tok) {                  if (n->next && MDOC_In != n->next->tok) {
                         SCALE_VS_INIT(&su, 1);                          SCALE_VS_INIT(&su, 1);
                         bufcat_su(h, "margin-bottom", &su);                          bufcat_su(h, "margin-bottom", &su);
Line 1882  mdoc_in_pre(MDOC_ARGS)
Line 1902  mdoc_in_pre(MDOC_ARGS)
                 bufinit(h);                  bufinit(h);
                 if (h->base_includes) {                  if (h->base_includes) {
                         buffmt_includes(h, nn->string);                          buffmt_includes(h, nn->string);
                         tag[i].key = ATTR_HREF;                          PAIR_HREF_INIT(&tag[i], h->buf);
                         tag[i++].val = h->buf;                          i++;
                 }                  }
                 t = print_otag(h, TAG_A, i, tag);                  t = print_otag(h, TAG_A, i, tag);
                 print_mdoc_node(m, nn, h);                  print_mdoc_node(m, nn, h);
Line 1935  mdoc_rv_pre(MDOC_ARGS)
Line 1955  mdoc_rv_pre(MDOC_ARGS)
                         print_text(h, "()");                          print_text(h, "()");
         }          }
   
         if (n->child->next)          if (n->child && n->child->next)
                 print_text(h, "functions return");                  print_text(h, "functions return");
         else          else
                 print_text(h, "function returns");                  print_text(h, "function returns");
Line 2158  mdoc_lb_pre(MDOC_ARGS)
Line 2178  mdoc_lb_pre(MDOC_ARGS)
 {  {
         struct htmlpair tag;          struct htmlpair tag;
   
         if (SEC_SYNOPSIS == n->sec)          if (SEC_LIBRARY == n->sec && MDOC_LINE & n->flags)
                 print_otag(h, TAG_DIV, 0, NULL);                  print_otag(h, TAG_DIV, 0, NULL);
         PAIR_CLASS_INIT(&tag, "lib");          PAIR_CLASS_INIT(&tag, "lib");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_SPAN, 1, &tag);
Line 2208  mdoc__x_pre(MDOC_ARGS)
Line 2228  mdoc__x_pre(MDOC_ARGS)
                 break;                  break;
         case(MDOC__T):          case(MDOC__T):
                 PAIR_CLASS_INIT(&tag[0], "ref-title");                  PAIR_CLASS_INIT(&tag[0], "ref-title");
                 print_text(h, "\\(lq");  
                 h->flags |= HTML_NOSPACE;  
                 break;                  break;
         case(MDOC__U):          case(MDOC__U):
                 PAIR_CLASS_INIT(&tag[0], "link-ref");                  PAIR_CLASS_INIT(&tag[0], "link-ref");
Line 2238  static void
Line 2256  static void
 mdoc__x_post(MDOC_ARGS)  mdoc__x_post(MDOC_ARGS)
 {  {
   
           /* TODO: %U */
   
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
         switch (n->tok) {  
         case (MDOC__T):  
                 print_text(h, "\\(rq");  
                 h->flags |= HTML_NOSPACE;  
                 break;  
         default:  
                 break;  
         }  
         print_text(h, n->next ? "," : ".");          print_text(h, n->next ? "," : ".");
 }  }

Legend:
Removed from v.1.52  
changed lines
  Added in v.1.65

CVSweb