[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.162 and 1.186

version 1.162, 2011/04/04 16:48:18 version 1.186, 2013/12/24 20:45:27
Line 34 
Line 34 
 #include "main.h"  #include "main.h"
   
 #define INDENT           5  #define INDENT           5
 #define HALFINDENT       3  
   
 #define MDOC_ARGS         const struct mdoc_meta *m, \  #define MDOC_ARGS         const struct mdoc_meta *meta, \
                           const struct mdoc_node *n, \                            const struct mdoc_node *n, \
                           struct html *h                            struct html *h
   
Line 190  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 189  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {NULL, NULL}, /* Ec */ /* FIXME: no space */          {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 */          {mdoc_quote_pre, mdoc_quote_post}, /* Eo */
         {mdoc_xx_pre, NULL}, /* Fx */          {mdoc_xx_pre, NULL}, /* Fx */
         {mdoc_ms_pre, NULL}, /* Ms */          {mdoc_ms_pre, NULL}, /* Ms */
         {mdoc_igndelim_pre, NULL}, /* No */          {mdoc_igndelim_pre, NULL}, /* No */
Line 261  static const char * const lists[LIST_MAX] = {
Line 260  static const char * const lists[LIST_MAX] = {
 };  };
   
 void  void
 html_mdoc(void *arg, const struct mdoc *m)  html_mdoc(void *arg, const struct mdoc *mdoc)
 {  {
         struct html     *h;  
         struct tag      *t;  
   
         h = (struct html *)arg;          print_mdoc(mdoc_meta(mdoc), mdoc_node(mdoc),
                           (struct html *)arg);
         print_gen_decls(h);          putchar('\n');
         t = print_otag(h, TAG_HTML, 0, NULL);  
         print_mdoc(mdoc_meta(m), mdoc_node(m), h);  
         print_tagq(h, t);  
   
         printf("\n");  
 }  }
   
   
Line 288  a2width(const char *p, struct roffsu *su)
Line 280  a2width(const char *p, struct roffsu *su)
   
         if ( ! a2roffsu(p, su, SCALE_MAX)) {          if ( ! a2roffsu(p, su, SCALE_MAX)) {
                 su->unit = SCALE_BU;                  su->unit = SCALE_BU;
                 su->scale = (int)strlen(p);                  su->scale = html_strlen(p);
         }          }
 }  }
   
Line 353  a2offs(const char *p, struct roffsu *su)
Line 345  a2offs(const char *p, struct roffsu *su)
                 SCALE_HS_INIT(su, INDENT);                  SCALE_HS_INIT(su, INDENT);
         else if (0 == strcmp(p, "indent-two"))          else if (0 == strcmp(p, "indent-two"))
                 SCALE_HS_INIT(su, INDENT * 2);                  SCALE_HS_INIT(su, INDENT * 2);
         else if ( ! a2roffsu(p, su, SCALE_MAX)) {          else if ( ! a2roffsu(p, su, SCALE_MAX))
                 su->unit = SCALE_BU;                  SCALE_HS_INIT(su, html_strlen(p));
                 su->scale = (int)strlen(p);  
         }  
 }  }
   
   
 static void  static void
 print_mdoc(MDOC_ARGS)  print_mdoc(MDOC_ARGS)
 {  {
         struct tag      *t;          struct tag      *t, *tt;
           struct htmlpair  tag;
   
         t = print_otag(h, TAG_HEAD, 0, NULL);          PAIR_CLASS_INIT(&tag, "mandoc");
         print_mdoc_head(m, n, h);  
         print_tagq(h, t);  
   
         t = print_otag(h, TAG_BODY, 0, NULL);          if ( ! (HTML_FRAGMENT & h->oflags)) {
         print_mdoc_nodelist(m, n, h);                  print_gen_decls(h);
                   t = print_otag(h, TAG_HTML, 0, NULL);
                   tt = print_otag(h, TAG_HEAD, 0, NULL);
                   print_mdoc_head(meta, n, h);
                   print_tagq(h, tt);
                   print_otag(h, TAG_BODY, 0, NULL);
                   print_otag(h, TAG_DIV, 1, &tag);
           } else
                   t = print_otag(h, TAG_DIV, 1, &tag);
   
           print_mdoc_nodelist(meta, n, h);
         print_tagq(h, t);          print_tagq(h, t);
 }  }
   
Line 382  print_mdoc_head(MDOC_ARGS)
Line 381  print_mdoc_head(MDOC_ARGS)
   
         print_gen_head(h);          print_gen_head(h);
         bufinit(h);          bufinit(h);
         buffmt(h, "%s(%s)", m->title, m->msec);          bufcat_fmt(h, "%s(%s)", meta->title, meta->msec);
   
         if (m->arch) {          if (meta->arch)
                 bufcat(h, " (");                  bufcat_fmt(h, " (%s)", meta->arch);
                 bufcat(h, m->arch);  
                 bufcat(h, ")");  
         }  
   
         print_otag(h, TAG_TITLE, 0, NULL);          print_otag(h, TAG_TITLE, 0, NULL);
         print_text(h, h->buf);          print_text(h, h->buf);
Line 399  static void
Line 395  static void
 print_mdoc_nodelist(MDOC_ARGS)  print_mdoc_nodelist(MDOC_ARGS)
 {  {
   
         print_mdoc_node(m, n, h);          print_mdoc_node(meta, n, h);
         if (n->next)          if (n->next)
                 print_mdoc_nodelist(m, n->next, h);                  print_mdoc_nodelist(meta, n->next, h);
 }  }
   
   
Line 410  print_mdoc_node(MDOC_ARGS)
Line 406  print_mdoc_node(MDOC_ARGS)
 {  {
         int              child;          int              child;
         struct tag      *t;          struct tag      *t;
         struct htmlpair  tag;  
   
         child = 1;          child = 1;
         t = h->tags.head;          t = h->tags.head;
   
         bufinit(h);  
         switch (n->type) {          switch (n->type) {
         case (MDOC_ROOT):          case (MDOC_ROOT):
                 child = mdoc_root_pre(m, n, h);                  child = mdoc_root_pre(meta, n, h);
                 break;                  break;
         case (MDOC_TEXT):          case (MDOC_TEXT):
                 /* No tables in this mode... */                  /* No tables in this mode... */
Line 438  print_mdoc_node(MDOC_ARGS)
Line 432  print_mdoc_node(MDOC_ARGS)
                         h->flags |= HTML_NOSPACE;                          h->flags |= HTML_NOSPACE;
                 return;                  return;
         case (MDOC_EQN):          case (MDOC_EQN):
                 PAIR_CLASS_INIT(&tag, "eqn");                  print_eqn(h, n->eqn);
                 print_otag(h, TAG_SPAN, 1, &tag);  
                 print_text(h, n->eqn->data);  
                 break;                  break;
         case (MDOC_TBL):          case (MDOC_TBL):
                 /*                  /*
Line 463  print_mdoc_node(MDOC_ARGS)
Line 455  print_mdoc_node(MDOC_ARGS)
   
                 assert(NULL == h->tblt);                  assert(NULL == h->tblt);
                 if (mdocs[n->tok].pre && ENDBODY_NOT == n->end)                  if (mdocs[n->tok].pre && ENDBODY_NOT == n->end)
                         child = (*mdocs[n->tok].pre)(m, n, h);                          child = (*mdocs[n->tok].pre)(meta, n, h);
                 break;                  break;
         }          }
   
         if (HTML_KEEP & h->flags) {          if (HTML_KEEP & h->flags) {
                 if (n->prev && n->prev->line != n->line) {                  if (n->prev ? (n->prev->lastline != n->line) :
                       (n->parent && n->parent->line != n->line)) {
                         h->flags &= ~HTML_KEEP;                          h->flags &= ~HTML_KEEP;
                         h->flags |= HTML_PREKEEP;                          h->flags |= HTML_PREKEEP;
                 } else if (NULL == n->prev) {  
                         if (n->parent && n->parent->line != n->line) {  
                                 h->flags &= ~HTML_KEEP;  
                                 h->flags |= HTML_PREKEEP;  
                         }  
                 }                  }
         }          }
   
         if (child && n->child)          if (child && n->child)
                 print_mdoc_nodelist(m, n->child, h);                  print_mdoc_nodelist(meta, n->child, h);
   
         print_stagq(h, t);          print_stagq(h, t);
   
         bufinit(h);  
         switch (n->type) {          switch (n->type) {
         case (MDOC_ROOT):          case (MDOC_ROOT):
                 mdoc_root_post(m, n, h);                  mdoc_root_post(meta, n, h);
                 break;                  break;
         case (MDOC_EQN):          case (MDOC_EQN):
                 break;                  break;
         default:          default:
                 if (mdocs[n->tok].post && ENDBODY_NOT == n->end)                  if (mdocs[n->tok].post && ENDBODY_NOT == n->end)
                         (*mdocs[n->tok].post)(m, n, h);                          (*mdocs[n->tok].post)(meta, n, h);
                 break;                  break;
         }          }
 }  }
Line 507  mdoc_root_post(MDOC_ARGS)
Line 494  mdoc_root_post(MDOC_ARGS)
   
         PAIR_SUMMARY_INIT(&tag[0], "Document Footer");          PAIR_SUMMARY_INIT(&tag[0], "Document Footer");
         PAIR_CLASS_INIT(&tag[1], "foot");          PAIR_CLASS_INIT(&tag[1], "foot");
         if (NULL == h->style) {          PAIR_INIT(&tag[2], ATTR_WIDTH, "100%");
                 PAIR_INIT(&tag[2], ATTR_WIDTH, "100%");          t = print_otag(h, TAG_TABLE, 3, tag);
                 t = print_otag(h, TAG_TABLE, 3, tag);          PAIR_INIT(&tag[0], ATTR_WIDTH, "50%");
                 PAIR_INIT(&tag[0], ATTR_WIDTH, "50%");          print_otag(h, TAG_COL, 1, tag);
                 print_otag(h, TAG_COL, 1, tag);          print_otag(h, TAG_COL, 1, tag);
                 print_otag(h, TAG_COL, 1, tag);  
         } else  
                 t = print_otag(h, TAG_TABLE, 2, tag);  
   
         t = print_otag(h, TAG_TBODY, 0, NULL);          print_otag(h, TAG_TBODY, 0, NULL);
   
         tt = print_otag(h, TAG_TR, 0, NULL);          tt = print_otag(h, TAG_TR, 0, NULL);
   
         PAIR_CLASS_INIT(&tag[0], "foot-date");          PAIR_CLASS_INIT(&tag[0], "foot-date");
         print_otag(h, TAG_TD, 1, tag);          print_otag(h, TAG_TD, 1, tag);
           print_text(h, meta->date);
         print_text(h, m->date);  
         print_stagq(h, tt);          print_stagq(h, tt);
   
         PAIR_CLASS_INIT(&tag[0], "foot-os");          PAIR_CLASS_INIT(&tag[0], "foot-os");
         if (NULL == h->style) {          PAIR_INIT(&tag[1], ATTR_ALIGN, "right");
                 PAIR_INIT(&tag[1], ATTR_ALIGN, "right");          print_otag(h, TAG_TD, 2, tag);
                 print_otag(h, TAG_TD, 2, tag);          print_text(h, meta->os);
         } else  
                 print_otag(h, TAG_TD, 1, tag);  
   
         print_text(h, m->os);  
         print_tagq(h, t);          print_tagq(h, t);
 }  }
   
Line 546  mdoc_root_pre(MDOC_ARGS)
Line 525  mdoc_root_pre(MDOC_ARGS)
         struct tag      *t, *tt;          struct tag      *t, *tt;
         char             b[BUFSIZ], title[BUFSIZ];          char             b[BUFSIZ], title[BUFSIZ];
   
         strlcpy(b, m->vol, BUFSIZ);          strlcpy(b, meta->vol, BUFSIZ);
   
         if (m->arch) {          if (meta->arch) {
                 strlcat(b, " (", BUFSIZ);                  strlcat(b, " (", BUFSIZ);
                 strlcat(b, m->arch, BUFSIZ);                  strlcat(b, meta->arch, BUFSIZ);
                 strlcat(b, ")", BUFSIZ);                  strlcat(b, ")", BUFSIZ);
         }          }
   
         snprintf(title, BUFSIZ - 1, "%s(%s)", m->title, m->msec);          snprintf(title, BUFSIZ - 1, "%s(%s)", meta->title, meta->msec);
   
         PAIR_SUMMARY_INIT(&tag[0], "Document Header");          PAIR_SUMMARY_INIT(&tag[0], "Document Header");
         PAIR_CLASS_INIT(&tag[1], "head");          PAIR_CLASS_INIT(&tag[1], "head");
         if (NULL == h->style) {          PAIR_INIT(&tag[2], ATTR_WIDTH, "100%");
                 PAIR_INIT(&tag[2], ATTR_WIDTH, "100%");          t = print_otag(h, TAG_TABLE, 3, tag);
                 t = print_otag(h, TAG_TABLE, 3, tag);          PAIR_INIT(&tag[0], ATTR_WIDTH, "30%");
                 PAIR_INIT(&tag[0], ATTR_WIDTH, "30%");          print_otag(h, TAG_COL, 1, tag);
                 print_otag(h, TAG_COL, 1, tag);          print_otag(h, TAG_COL, 1, tag);
                 print_otag(h, TAG_COL, 1, tag);          print_otag(h, TAG_COL, 1, tag);
                 print_otag(h, TAG_COL, 1, tag);  
         } else  
                 t = print_otag(h, TAG_TABLE, 2, tag);  
   
         print_otag(h, TAG_TBODY, 0, NULL);          print_otag(h, TAG_TBODY, 0, NULL);
   
Line 574  mdoc_root_pre(MDOC_ARGS)
Line 550  mdoc_root_pre(MDOC_ARGS)
   
         PAIR_CLASS_INIT(&tag[0], "head-ltitle");          PAIR_CLASS_INIT(&tag[0], "head-ltitle");
         print_otag(h, TAG_TD, 1, tag);          print_otag(h, TAG_TD, 1, tag);
   
         print_text(h, title);          print_text(h, title);
         print_stagq(h, tt);          print_stagq(h, tt);
   
         PAIR_CLASS_INIT(&tag[0], "head-vol");          PAIR_CLASS_INIT(&tag[0], "head-vol");
         if (NULL == h->style) {          PAIR_INIT(&tag[1], ATTR_ALIGN, "center");
                 PAIR_INIT(&tag[1], ATTR_ALIGN, "center");          print_otag(h, TAG_TD, 2, tag);
                 print_otag(h, TAG_TD, 2, tag);  
         } else  
                 print_otag(h, TAG_TD, 1, tag);  
   
         print_text(h, b);          print_text(h, b);
         print_stagq(h, tt);          print_stagq(h, tt);
   
         PAIR_CLASS_INIT(&tag[0], "head-rtitle");          PAIR_CLASS_INIT(&tag[0], "head-rtitle");
         if (NULL == h->style) {          PAIR_INIT(&tag[1], ATTR_ALIGN, "right");
                 PAIR_INIT(&tag[1], ATTR_ALIGN, "right");          print_otag(h, TAG_TD, 2, tag);
                 print_otag(h, TAG_TD, 2, tag);  
         } else  
                 print_otag(h, TAG_TD, 1, tag);  
   
         print_text(h, title);          print_text(h, title);
         print_tagq(h, t);          print_tagq(h, t);
         return(1);          return(1);
Line 606  static int
Line 573  static int
 mdoc_sh_pre(MDOC_ARGS)  mdoc_sh_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         char             buf[BUFSIZ];  
   
         if (MDOC_BLOCK == n->type) {          if (MDOC_BLOCK == n->type) {
                 PAIR_CLASS_INIT(&tag, "section");                  PAIR_CLASS_INIT(&tag, "section");
Line 615  mdoc_sh_pre(MDOC_ARGS)
Line 581  mdoc_sh_pre(MDOC_ARGS)
         } else if (MDOC_BODY == n->type)          } else if (MDOC_BODY == n->type)
                 return(1);                  return(1);
   
         buf[0] = '\0';          bufinit(h);
         for (n = n->child; n; n = n->next) {          bufcat(h, "x");
                 html_idcat(buf, n->string, BUFSIZ);  
                 if (n->next)          for (n = n->child; n && MDOC_TEXT == n->type; ) {
                         html_idcat(buf, " ", BUFSIZ);                  bufcat_id(h, n->string);
                   if (NULL != (n = n->next))
                           bufcat_id(h, " ");
         }          }
   
         PAIR_ID_INIT(&tag, buf);          if (NULL == n) {
         print_otag(h, TAG_H1, 1, &tag);                  PAIR_ID_INIT(&tag, h->buf);
                   print_otag(h, TAG_H1, 1, &tag);
           } else
                   print_otag(h, TAG_H1, 0, NULL);
   
         return(1);          return(1);
 }  }
   
   
 /* ARGSUSED */  /* ARGSUSED */
 static int  static int
 mdoc_ss_pre(MDOC_ARGS)  mdoc_ss_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         char             buf[BUFSIZ];  
   
         if (MDOC_BLOCK == n->type) {          if (MDOC_BLOCK == n->type) {
                 PAIR_CLASS_INIT(&tag, "subsection");                  PAIR_CLASS_INIT(&tag, "subsection");
Line 642  mdoc_ss_pre(MDOC_ARGS)
Line 612  mdoc_ss_pre(MDOC_ARGS)
         } else if (MDOC_BODY == n->type)          } else if (MDOC_BODY == n->type)
                 return(1);                  return(1);
   
         buf[0] = '\0';          bufinit(h);
         for (n = n->child; n; n = n->next) {          bufcat(h, "x");
                 html_idcat(buf, n->string, BUFSIZ);  
                 if (n->next)          for (n = n->child; n && MDOC_TEXT == n->type; ) {
                         html_idcat(buf, " ", BUFSIZ);                  bufcat_id(h, n->string);
                   if (NULL != (n = n->next))
                           bufcat_id(h, " ");
         }          }
   
         PAIR_ID_INIT(&tag, buf);          if (NULL == n) {
         print_otag(h, TAG_H2, 1, &tag);                  PAIR_ID_INIT(&tag, h->buf);
                   print_otag(h, TAG_H2, 1, &tag);
           } else
                   print_otag(h, TAG_H2, 0, NULL);
   
         return(1);          return(1);
 }  }
   
Line 703  mdoc_nm_pre(MDOC_ARGS)
Line 679  mdoc_nm_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
         struct roffsu    su;          struct roffsu    su;
         size_t           len;          int              len;
   
         switch (n->type) {          switch (n->type) {
         case (MDOC_ELEM):          case (MDOC_ELEM):
                 synopsis_pre(h, n);                  synopsis_pre(h, n);
                 PAIR_CLASS_INIT(&tag, "name");                  PAIR_CLASS_INIT(&tag, "name");
                 print_otag(h, TAG_B, 1, &tag);                  print_otag(h, TAG_B, 1, &tag);
                 if (NULL == n->child && m->name)                  if (NULL == n->child && meta->name)
                         print_text(h, m->name);                          print_text(h, meta->name);
                 return(1);                  return(1);
         case (MDOC_HEAD):          case (MDOC_HEAD):
                 print_otag(h, TAG_TD, 0, NULL);                  print_otag(h, TAG_TD, 0, NULL);
                 if (NULL == n->child && m->name)                  if (NULL == n->child && meta->name)
                         print_text(h, m->name);                          print_text(h, meta->name);
                 return(1);                  return(1);
         case (MDOC_BODY):          case (MDOC_BODY):
                 print_otag(h, TAG_TD, 0, NULL);                  print_otag(h, TAG_TD, 0, NULL);
Line 731  mdoc_nm_pre(MDOC_ARGS)
Line 707  mdoc_nm_pre(MDOC_ARGS)
   
         for (len = 0, n = n->child; n; n = n->next)          for (len = 0, n = n->child; n; n = n->next)
                 if (MDOC_TEXT == n->type)                  if (MDOC_TEXT == n->type)
                         len += strlen(n->string);                          len += html_strlen(n->string);
   
         if (0 == len && m->name)          if (0 == len && meta->name)
                 len = strlen(m->name);                  len = html_strlen(meta->name);
   
         SCALE_HS_INIT(&su, (double)len);          SCALE_HS_INIT(&su, (double)len);
           bufinit(h);
         bufcat_su(h, "width", &su);          bufcat_su(h, "width", &su);
         PAIR_STYLE_INIT(&tag, h);          PAIR_STYLE_INIT(&tag, h);
         print_otag(h, TAG_COL, 1, &tag);          print_otag(h, TAG_COL, 1, &tag);
Line 899  mdoc_it_pre(MDOC_ARGS)
Line 876  mdoc_it_pre(MDOC_ARGS)
         assert(lists[type]);          assert(lists[type]);
         PAIR_CLASS_INIT(&tag[0], lists[type]);          PAIR_CLASS_INIT(&tag[0], lists[type]);
   
           bufinit(h);
   
         if (MDOC_HEAD == n->type) {          if (MDOC_HEAD == n->type) {
                 switch (type) {                  switch (type) {
                 case(LIST_bullet):                  case(LIST_bullet):
Line 1017  mdoc_bl_pre(MDOC_ARGS)
Line 996  mdoc_bl_pre(MDOC_ARGS)
                  */                   */
   
                 for (i = 0; i < (int)n->norm->Bl.ncols; i++) {                  for (i = 0; i < (int)n->norm->Bl.ncols; i++) {
                         a2width(n->norm->Bl.cols[i], &su);  
                         bufinit(h);                          bufinit(h);
                           a2width(n->norm->Bl.cols[i], &su);
                         if (i < (int)n->norm->Bl.ncols - 1)                          if (i < (int)n->norm->Bl.ncols - 1)
                                 bufcat_su(h, "width", &su);                                  bufcat_su(h, "width", &su);
                         else                          else
Line 1031  mdoc_bl_pre(MDOC_ARGS)
Line 1010  mdoc_bl_pre(MDOC_ARGS)
         }          }
   
         SCALE_VS_INIT(&su, 0);          SCALE_VS_INIT(&su, 0);
           bufinit(h);
         bufcat_su(h, "margin-top", &su);          bufcat_su(h, "margin-top", &su);
         bufcat_su(h, "margin-bottom", &su);          bufcat_su(h, "margin-bottom", &su);
         PAIR_STYLE_INIT(&tag[0], h);          PAIR_STYLE_INIT(&tag[0], h);
Line 1147  mdoc_d1_pre(MDOC_ARGS)
Line 1127  mdoc_d1_pre(MDOC_ARGS)
                 return(1);                  return(1);
   
         SCALE_VS_INIT(&su, 0);          SCALE_VS_INIT(&su, 0);
           bufinit(h);
         bufcat_su(h, "margin-top", &su);          bufcat_su(h, "margin-top", &su);
         bufcat_su(h, "margin-bottom", &su);          bufcat_su(h, "margin-bottom", &su);
         PAIR_STYLE_INIT(&tag[0], h);          PAIR_STYLE_INIT(&tag[0], h);
Line 1171  static int
Line 1152  static int
 mdoc_sx_pre(MDOC_ARGS)  mdoc_sx_pre(MDOC_ARGS)
 {  {
         struct htmlpair  tag[2];          struct htmlpair  tag[2];
         char             buf[BUFSIZ];  
   
         strlcpy(buf, "#", BUFSIZ);          bufinit(h);
         for (n = n->child; n; n = n->next) {          bufcat(h, "#x");
                 html_idcat(buf, n->string, BUFSIZ);  
                 if (n->next)          for (n = n->child; n; ) {
                         html_idcat(buf, " ", BUFSIZ);                  bufcat_id(h, n->string);
                   if (NULL != (n = n->next))
                           bufcat_id(h, " ");
         }          }
   
         PAIR_CLASS_INIT(&tag[0], "link-sec");          PAIR_CLASS_INIT(&tag[0], "link-sec");
         PAIR_HREF_INIT(&tag[1], buf);          PAIR_HREF_INIT(&tag[1], h->buf);
   
         print_otag(h, TAG_I, 1, tag);          print_otag(h, TAG_I, 1, tag);
         print_otag(h, TAG_A, 2, tag);          print_otag(h, TAG_A, 2, tag);
Line 1219  mdoc_bd_pre(MDOC_ARGS)
Line 1201  mdoc_bd_pre(MDOC_ARGS)
         SCALE_HS_INIT(&su, 0);          SCALE_HS_INIT(&su, 0);
         if (n->norm->Bd.offs)          if (n->norm->Bd.offs)
                 a2offs(n->norm->Bd.offs, &su);                  a2offs(n->norm->Bd.offs, &su);
   
           bufinit(h);
         bufcat_su(h, "margin-left", &su);          bufcat_su(h, "margin-left", &su);
         PAIR_STYLE_INIT(&tag[0], h);          PAIR_STYLE_INIT(&tag[0], h);
   
Line 1239  mdoc_bd_pre(MDOC_ARGS)
Line 1222  mdoc_bd_pre(MDOC_ARGS)
         h->flags |= HTML_LITERAL;          h->flags |= HTML_LITERAL;
   
         for (nn = n->child; nn; nn = nn->next) {          for (nn = n->child; nn; nn = nn->next) {
                 print_mdoc_node(m, nn, h);                  print_mdoc_node(meta, nn, h);
                 /*                  /*
                  * If the printed node flushes its own line, then we                   * If the printed node flushes its own line, then we
                  * needn't do it here as well.  This is hacky, but the                   * needn't do it here as well.  This is hacky, but the
Line 1438  mdoc_fd_pre(MDOC_ARGS)
Line 1421  mdoc_fd_pre(MDOC_ARGS)
                         buf[sz - 1] = '\0';                          buf[sz - 1] = '\0';
   
                 PAIR_CLASS_INIT(&tag[0], "link-includes");                  PAIR_CLASS_INIT(&tag[0], "link-includes");
                 bufinit(h);  
   
                 i = 1;                  i = 1;
                 if (h->base_includes) {                  if (h->base_includes) {
Line 1558  mdoc_fn_pre(MDOC_ARGS)
Line 1540  mdoc_fn_pre(MDOC_ARGS)
   
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
         print_text(h, "(");          print_text(h, "(");
           h->flags |= HTML_NOSPACE;
   
         bufinit(h);  
         PAIR_CLASS_INIT(&tag[0], "farg");          PAIR_CLASS_INIT(&tag[0], "farg");
           bufinit(h);
         bufcat_style(h, "white-space", "nowrap");          bufcat_style(h, "white-space", "nowrap");
         PAIR_STYLE_INIT(&tag[1], h);          PAIR_STYLE_INIT(&tag[1], h);
   
Line 1634  mdoc_sp_pre(MDOC_ARGS)
Line 1617  mdoc_sp_pre(MDOC_ARGS)
         SCALE_VS_INIT(&su, 1);          SCALE_VS_INIT(&su, 1);
   
         if (MDOC_sp == n->tok) {          if (MDOC_sp == n->tok) {
                 if (n->child)                  if (NULL != (n = n->child))
                         a2roffsu(n->child->string, &su, SCALE_VS);                          if ( ! a2roffsu(n->string, &su, SCALE_VS))
                                   SCALE_VS_INIT(&su, atoi(n->string));
         } else          } else
                 su.scale = 0;                  su.scale = 0;
   
           bufinit(h);
         bufcat_su(h, "height", &su);          bufcat_su(h, "height", &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);
Line 1666  mdoc_lk_pre(MDOC_ARGS)
Line 1651  mdoc_lk_pre(MDOC_ARGS)
   
         print_otag(h, TAG_A, 2, tag);          print_otag(h, TAG_A, 2, tag);
   
         for (n = n->next; n; n = n->next) {          if (NULL == n->next)
                 assert(MDOC_TEXT == n->type);  
                 print_text(h, n->string);                  print_text(h, n->string);
         }  
   
           for (n = n->next; n; n = n->next)
                   print_text(h, n->string);
   
         return(0);          return(0);
 }  }
   
Line 1775  mdoc_in_pre(MDOC_ARGS)
Line 1761  mdoc_in_pre(MDOC_ARGS)
                 assert(MDOC_TEXT == n->type);                  assert(MDOC_TEXT == n->type);
   
                 PAIR_CLASS_INIT(&tag[0], "link-includes");                  PAIR_CLASS_INIT(&tag[0], "link-includes");
                 bufinit(h);  
   
                 i = 1;                  i = 1;
   
                 if (h->base_includes) {                  if (h->base_includes) {
                         buffmt_includes(h, n->string);                          buffmt_includes(h, n->string);
                         PAIR_HREF_INIT(&tag[i], h->buf);                          PAIR_HREF_INIT(&tag[i], h->buf);
Line 1917  mdoc_bf_pre(MDOC_ARGS)
Line 1901  mdoc_bf_pre(MDOC_ARGS)
          * We want this to be inline-formatted, but needs to be div to           * We want this to be inline-formatted, but needs to be div to
          * accept block children.           * accept block children.
          */           */
           bufinit(h);
         bufcat_style(h, "display", "inline");          bufcat_style(h, "display", "inline");
         SCALE_HS_INIT(&su, 1);          SCALE_HS_INIT(&su, 1);
         /* Needs a left-margin for spacing. */          /* Needs a left-margin for spacing. */
Line 1984  mdoc_li_pre(MDOC_ARGS)
Line 1969  mdoc_li_pre(MDOC_ARGS)
         struct htmlpair tag;          struct htmlpair tag;
   
         PAIR_CLASS_INIT(&tag, "lit");          PAIR_CLASS_INIT(&tag, "lit");
         print_otag(h, TAG_SPAN, 1, &tag);          print_otag(h, TAG_CODE, 1, &tag);
         return(1);          return(1);
 }  }
   
Line 2197  mdoc_quote_pre(MDOC_ARGS)
Line 2182  mdoc_quote_pre(MDOC_ARGS)
                 PAIR_CLASS_INIT(&tag, "opt");                  PAIR_CLASS_INIT(&tag, "opt");
                 print_otag(h, TAG_SPAN, 1, &tag);                  print_otag(h, TAG_SPAN, 1, &tag);
                 break;                  break;
           case (MDOC_Eo):
                   break;
         case (MDOC_Do):          case (MDOC_Do):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (MDOC_Dq):          case (MDOC_Dq):
Line 2212  mdoc_quote_pre(MDOC_ARGS)
Line 2199  mdoc_quote_pre(MDOC_ARGS)
                 print_text(h, "(");                  print_text(h, "(");
                 break;                  break;
         case (MDOC_Ql):          case (MDOC_Ql):
                 /* FALLTHROUGH */                  print_text(h, "\\(oq");
                   h->flags |= HTML_NOSPACE;
                   PAIR_CLASS_INIT(&tag, "lit");
                   print_otag(h, TAG_CODE, 1, &tag);
                   break;
         case (MDOC_So):          case (MDOC_So):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (MDOC_Sq):          case (MDOC_Sq):
Line 2258  mdoc_quote_post(MDOC_ARGS)
Line 2249  mdoc_quote_post(MDOC_ARGS)
         case (MDOC_Bq):          case (MDOC_Bq):
                 print_text(h, "\\(rB");                  print_text(h, "\\(rB");
                 break;                  break;
           case (MDOC_Eo):
                   break;
         case (MDOC_Qo):          case (MDOC_Qo):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (MDOC_Qq):          case (MDOC_Qq):
Line 2277  mdoc_quote_post(MDOC_ARGS)
Line 2270  mdoc_quote_post(MDOC_ARGS)
         case (MDOC_So):          case (MDOC_So):
                 /* FALLTHROUGH */                  /* FALLTHROUGH */
         case (MDOC_Sq):          case (MDOC_Sq):
                 print_text(h, "\\(aq");                  print_text(h, "\\(cq");
                 break;                  break;
         default:          default:
                 abort();                  abort();

Legend:
Removed from v.1.162  
changed lines
  Added in v.1.186

CVSweb