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

Diff for /src/usr.bin/mandoc/mdoc_html.c between version 1.101 and 1.102

version 1.101, 2015/03/03 21:09:25 version 1.102, 2015/04/02 21:03:18
Line 7 
Line 7 
  * purpose with or without fee is hereby granted, provided that the above   * purpose with or without fee is hereby granted, provided that the above
  * copyright notice and this permission notice appear in all copies.   * copyright notice and this permission notice appear in all copies.
  *   *
  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES   * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHORS DISCLAIM ALL WARRANTIES
  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF   * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR   * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR
  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES   * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN   * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF   * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
Line 25 
Line 25 
 #include <unistd.h>  #include <unistd.h>
   
 #include "mandoc_aux.h"  #include "mandoc_aux.h"
   #include "roff.h"
 #include "mdoc.h"  #include "mdoc.h"
 #include "out.h"  #include "out.h"
 #include "html.h"  #include "html.h"
Line 388 
Line 389 
         n->flags &= ~MDOC_ENDED;          n->flags &= ~MDOC_ENDED;
   
         switch (n->type) {          switch (n->type) {
         case MDOC_ROOT:          case ROFFT_ROOT:
                 child = mdoc_root_pre(meta, n, h);                  child = mdoc_root_pre(meta, n, h);
                 break;                  break;
         case MDOC_TEXT:          case ROFFT_TEXT:
                 /* No tables in this mode... */                  /* No tables in this mode... */
                 assert(NULL == h->tblt);                  assert(NULL == h->tblt);
   
Line 408 
Line 409 
                 if (MDOC_DELIMO & n->flags)                  if (MDOC_DELIMO & n->flags)
                         h->flags |= HTML_NOSPACE;                          h->flags |= HTML_NOSPACE;
                 return;                  return;
         case MDOC_EQN:          case ROFFT_EQN:
                 if (n->flags & MDOC_LINE)                  if (n->flags & MDOC_LINE)
                         putchar('\n');                          putchar('\n');
                 print_eqn(h, n->eqn);                  print_eqn(h, n->eqn);
                 break;                  break;
         case MDOC_TBL:          case ROFFT_TBL:
                 /*                  /*
                  * This will take care of initialising all of the table                   * This will take care of initialising all of the table
                  * state data for the first table, then tearing it down                   * state data for the first table, then tearing it down
Line 448 
Line 449 
         print_stagq(h, t);          print_stagq(h, t);
   
         switch (n->type) {          switch (n->type) {
         case MDOC_ROOT:          case ROFFT_ROOT:
                 mdoc_root_post(meta, n, h);                  mdoc_root_post(meta, n, h);
                 break;                  break;
         case MDOC_EQN:          case ROFFT_EQN:
                 break;                  break;
         default:          default:
                 if ( ! mdocs[n->tok].post || n->flags & MDOC_ENDED)                  if ( ! mdocs[n->tok].post || n->flags & MDOC_ENDED)
Line 541 
Line 542 
         struct htmlpair  tag;          struct htmlpair  tag;
   
         switch (n->type) {          switch (n->type) {
         case MDOC_BLOCK:          case ROFFT_BLOCK:
                 PAIR_CLASS_INIT(&tag, "section");                  PAIR_CLASS_INIT(&tag, "section");
                 print_otag(h, TAG_DIV, 1, &tag);                  print_otag(h, TAG_DIV, 1, &tag);
                 return(1);                  return(1);
         case MDOC_BODY:          case ROFFT_BODY:
                 if (n->sec == SEC_AUTHORS)                  if (n->sec == SEC_AUTHORS)
                         h->flags &= ~(HTML_SPLIT|HTML_NOSPLIT);                          h->flags &= ~(HTML_SPLIT|HTML_NOSPLIT);
                 return(1);                  return(1);
Line 556 
Line 557 
         bufinit(h);          bufinit(h);
         bufcat(h, "x");          bufcat(h, "x");
   
         for (n = n->child; n && MDOC_TEXT == n->type; ) {          for (n = n->child; n != NULL && n->type == ROFFT_TEXT; ) {
                 bufcat_id(h, n->string);                  bufcat_id(h, n->string);
                 if (NULL != (n = n->next))                  if (NULL != (n = n->next))
                         bufcat_id(h, " ");                          bufcat_id(h, " ");
Line 576 
Line 577 
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
   
         if (MDOC_BLOCK == n->type) {          if (n->type == ROFFT_BLOCK) {
                 PAIR_CLASS_INIT(&tag, "subsection");                  PAIR_CLASS_INIT(&tag, "subsection");
                 print_otag(h, TAG_DIV, 1, &tag);                  print_otag(h, TAG_DIV, 1, &tag);
                 return(1);                  return(1);
         } else if (MDOC_BODY == n->type)          } else if (n->type == ROFFT_BODY)
                 return(1);                  return(1);
   
         bufinit(h);          bufinit(h);
         bufcat(h, "x");          bufcat(h, "x");
   
         for (n = n->child; n && MDOC_TEXT == n->type; ) {          for (n = n->child; n != NULL && n->type == ROFFT_TEXT; ) {
                 bufcat_id(h, n->string);                  bufcat_id(h, n->string);
                 if (NULL != (n = n->next))                  if (NULL != (n = n->next))
                         bufcat_id(h, " ");                          bufcat_id(h, " ");
Line 618 
Line 619 
   
         if ( ! (n->nchild == 0 &&          if ( ! (n->nchild == 0 &&
             (n->next == NULL ||              (n->next == NULL ||
              n->next->type == MDOC_TEXT ||               n->next->type == ROFFT_TEXT ||
              n->next->flags & MDOC_LINE)))               n->next->flags & MDOC_LINE)))
                 h->flags |= HTML_NOSPACE;                  h->flags |= HTML_NOSPACE;
   
Line 630 
Line 631 
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
   
         if (MDOC_BODY != n->type)          if (n->type != ROFFT_BODY)
                 return(1);                  return(1);
   
         /* XXX: this tag in theory can contain block elements. */          /* XXX: this tag in theory can contain block elements. */
Line 649 
Line 650 
         int              len;          int              len;
   
         switch (n->type) {          switch (n->type) {
         case MDOC_ELEM:          case ROFFT_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 && meta->name)                  if (NULL == n->child && meta->name)
                         print_text(h, meta->name);                          print_text(h, meta->name);
                 return(1);                  return(1);
         case MDOC_HEAD:          case ROFFT_HEAD:
                 print_otag(h, TAG_TD, 0, NULL);                  print_otag(h, TAG_TD, 0, NULL);
                 if (NULL == n->child && meta->name)                  if (NULL == n->child && meta->name)
                         print_text(h, meta->name);                          print_text(h, meta->name);
                 return(1);                  return(1);
         case MDOC_BODY:          case ROFFT_BODY:
                 print_otag(h, TAG_TD, 0, NULL);                  print_otag(h, TAG_TD, 0, NULL);
                 return(1);                  return(1);
         default:          default:
Line 673 
Line 674 
         print_otag(h, TAG_TABLE, 1, &tag);          print_otag(h, TAG_TABLE, 1, &tag);
   
         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 (n->type == ROFFT_TEXT)
                         len += html_strlen(n->string);                          len += html_strlen(n->string);
   
         if (0 == len && meta->name)          if (0 == len && meta->name)
Line 834 
Line 835 
   
         bufinit(h);          bufinit(h);
   
         if (MDOC_HEAD == n->type) {          if (n->type == ROFFT_HEAD) {
                 switch (type) {                  switch (type) {
                 case LIST_bullet:                  case LIST_bullet:
                         /* FALLTHROUGH */                          /* FALLTHROUGH */
Line 869 
Line 870 
                 default:                  default:
                         break;                          break;
                 }                  }
         } else if (MDOC_BODY == n->type) {          } else if (n->type == ROFFT_BODY) {
                 switch (type) {                  switch (type) {
                 case LIST_bullet:                  case LIST_bullet:
                         /* FALLTHROUGH */                          /* FALLTHROUGH */
Line 933 
Line 934 
         struct roffsu    su;          struct roffsu    su;
         char             buf[BUFSIZ];          char             buf[BUFSIZ];
   
         if (MDOC_BODY == n->type) {          if (n->type == ROFFT_BODY) {
                 if (LIST_column == n->norm->Bl.type)                  if (LIST_column == n->norm->Bl.type)
                         print_otag(h, TAG_TBODY, 0, NULL);                          print_otag(h, TAG_TBODY, 0, NULL);
                 return(1);                  return(1);
         }          }
   
         if (MDOC_HEAD == n->type) {          if (n->type == ROFFT_HEAD) {
                 if (LIST_column != n->norm->Bl.type)                  if (LIST_column != n->norm->Bl.type)
                         return(0);                          return(0);
   
Line 1033 
Line 1034 
   
         nchild = n->nchild;          nchild = n->nchild;
         for (n = n->child; n; n = n->next) {          for (n = n->child; n; n = n->next) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
   
                 t = print_otag(h, TAG_B, 1, &tag);                  t = print_otag(h, TAG_B, 1, &tag);
                 print_text(h, n->string);                  print_text(h, n->string);
Line 1073 
Line 1074 
         struct htmlpair  tag[2];          struct htmlpair  tag[2];
         struct roffsu    su;          struct roffsu    su;
   
         if (MDOC_BLOCK != n->type)          if (n->type != ROFFT_BLOCK)
                 return(1);                  return(1);
   
         SCALE_VS_INIT(&su, 0);          SCALE_VS_INIT(&su, 0);
Line 1126 
Line 1127 
         struct mdoc_node        *nn;          struct mdoc_node        *nn;
         struct roffsu            su;          struct roffsu            su;
   
         if (MDOC_HEAD == n->type)          if (n->type == ROFFT_HEAD)
                 return(0);                  return(0);
   
         if (MDOC_BLOCK == n->type) {          if (n->type == ROFFT_BLOCK) {
                 comp = n->norm->Bd.comp;                  comp = n->norm->Bd.comp;
                 for (nn = n; nn && ! comp; nn = nn->parent) {                  for (nn = n; nn && ! comp; nn = nn->parent) {
                         if (MDOC_BLOCK != nn->type)                          if (nn->type != ROFFT_BLOCK)
                                 continue;                                  continue;
                         if (MDOC_Ss == nn->tok || MDOC_Sh == nn->tok)                          if (MDOC_Ss == nn->tok || MDOC_Sh == nn->tok)
                                 comp = 1;                                  comp = 1;
Line 1351 
Line 1352 
         if (NULL == (n = n->child))          if (NULL == (n = n->child))
                 return(0);                  return(0);
   
         assert(MDOC_TEXT == n->type);          assert(n->type == ROFFT_TEXT);
   
         if (strcmp(n->string, "#include")) {          if (strcmp(n->string, "#include")) {
                 PAIR_CLASS_INIT(&tag[0], "macro");                  PAIR_CLASS_INIT(&tag[0], "macro");
Line 1364 
Line 1365 
         print_text(h, n->string);          print_text(h, n->string);
   
         if (NULL != (n = n->next)) {          if (NULL != (n = n->next)) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
   
                 /*                  /*
                  * XXX This is broken and not easy to fix.                   * XXX This is broken and not easy to fix.
Line 1398 
Line 1399 
         }          }
   
         for ( ; n; n = n->next) {          for ( ; n; n = n->next) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
                 print_text(h, n->string);                  print_text(h, n->string);
         }          }
   
Line 1410 
Line 1411 
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
   
         if (MDOC_BLOCK == n->type) {          if (n->type == ROFFT_BLOCK) {
                 synopsis_pre(h, n);                  synopsis_pre(h, n);
                 return(1);                  return(1);
         } else if (MDOC_ELEM == n->type) {          } else if (n->type == ROFFT_ELEM) {
                 synopsis_pre(h, n);                  synopsis_pre(h, n);
         } else if (MDOC_HEAD == n->type)          } else if (n->type == ROFFT_HEAD)
                 return(0);                  return(0);
   
         PAIR_CLASS_INIT(&tag, "type");          PAIR_CLASS_INIT(&tag, "type");
Line 1594 
Line 1595 
         if (NULL == (n = n->child))          if (NULL == (n = n->child))
                 return(0);                  return(0);
   
         assert(MDOC_TEXT == n->type);          assert(n->type == ROFFT_TEXT);
   
         PAIR_CLASS_INIT(&tag[0], "link-ext");          PAIR_CLASS_INIT(&tag[0], "link-ext");
         PAIR_HREF_INIT(&tag[1], n->string);          PAIR_HREF_INIT(&tag[1], n->string);
Line 1619 
Line 1620 
         PAIR_CLASS_INIT(&tag[0], "link-mail");          PAIR_CLASS_INIT(&tag[0], "link-mail");
   
         for (n = n->child; n; n = n->next) {          for (n = n->child; n; n = n->next) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
   
                 bufinit(h);                  bufinit(h);
                 bufcat(h, "mailto:");                  bufcat(h, "mailto:");
Line 1640 
Line 1641 
         struct htmlpair  tag;          struct htmlpair  tag;
         struct tag      *t;          struct tag      *t;
   
         if (MDOC_BODY == n->type) {          if (n->type == ROFFT_BODY) {
                 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 (n->type == ROFFT_BLOCK) {
                 synopsis_pre(h, n);                  synopsis_pre(h, n);
                 return(1);                  return(1);
         }          }
Line 1666 
Line 1667 
 mdoc_fo_post(MDOC_ARGS)  mdoc_fo_post(MDOC_ARGS)
 {  {
   
         if (MDOC_BODY != n->type)          if (n->type != ROFFT_BODY)
                 return;                  return;
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
         print_text(h, ")");          print_text(h, ")");
Line 1700 
Line 1701 
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
   
         if (NULL != (n = n->child)) {          if (NULL != (n = n->child)) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
   
                 PAIR_CLASS_INIT(&tag[0], "link-includes");                  PAIR_CLASS_INIT(&tag[0], "link-includes");
   
Line 1722 
Line 1723 
         print_text(h, ">");          print_text(h, ">");
   
         for ( ; n; n = n->next) {          for ( ; n; n = n->next) {
                 assert(MDOC_TEXT == n->type);                  assert(n->type == ROFFT_TEXT);
                 print_text(h, n->string);                  print_text(h, n->string);
         }          }
   
Line 1821 
Line 1822 
         struct htmlpair  tag[2];          struct htmlpair  tag[2];
         struct roffsu    su;          struct roffsu    su;
   
         if (MDOC_HEAD == n->type)          if (n->type == ROFFT_HEAD)
                 return(0);                  return(0);
         else if (MDOC_BODY != n->type)          else if (n->type != ROFFT_BODY)
                 return(1);                  return(1);
   
         if (FONT_Em == n->norm->Bf.font)          if (FONT_Em == n->norm->Bf.font)
Line 1880 
Line 1881 
 {  {
         struct htmlpair  tag;          struct htmlpair  tag;
   
         if (MDOC_BLOCK != n->type)          if (n->type != ROFFT_BLOCK)
                 return(1);                  return(1);
   
         if (n->prev && SEC_SEE_ALSO == n->sec)          if (n->prev && SEC_SEE_ALSO == n->sec)
Line 2046 
Line 2047 
 {  {
   
         switch (n->type) {          switch (n->type) {
         case MDOC_BLOCK:          case ROFFT_BLOCK:
                 break;                  break;
         case MDOC_HEAD:          case ROFFT_HEAD:
                 return(0);                  return(0);
         case MDOC_BODY:          case ROFFT_BODY:
                 if (n->parent->args || 0 == n->prev->nchild)                  if (n->parent->args || 0 == n->prev->nchild)
                         h->flags |= HTML_PREKEEP;                          h->flags |= HTML_PREKEEP;
                 break;                  break;
Line 2066 
Line 2067 
 mdoc_bk_post(MDOC_ARGS)  mdoc_bk_post(MDOC_ARGS)
 {  {
   
         if (MDOC_BODY == n->type)          if (n->type == ROFFT_BODY)
                 h->flags &= ~(HTML_KEEP | HTML_PREKEEP);                  h->flags &= ~(HTML_KEEP | HTML_PREKEEP);
 }  }
   
Line 2075 
Line 2076 
 {  {
         struct htmlpair tag;          struct htmlpair tag;
   
         if (MDOC_BODY != n->type)          if (n->type != ROFFT_BODY)
                 return(1);                  return(1);
   
         switch (n->tok) {          switch (n->tok) {
Line 2147 
Line 2148 
 mdoc_quote_post(MDOC_ARGS)  mdoc_quote_post(MDOC_ARGS)
 {  {
   
         if (n->type != MDOC_BODY && n->type != MDOC_ELEM)          if (n->type != ROFFT_BODY && n->type != ROFFT_ELEM)
                 return;                  return;
   
         h->flags |= HTML_NOSPACE;          h->flags |= HTML_NOSPACE;
Line 2212 
Line 2213 
 mdoc_eo_pre(MDOC_ARGS)  mdoc_eo_pre(MDOC_ARGS)
 {  {
   
         if (n->type != MDOC_BODY)          if (n->type != ROFFT_BODY)
                 return(1);                  return(1);
   
         if (n->end == ENDBODY_NOT &&          if (n->end == ENDBODY_NOT &&
Line 2232 
Line 2233 
 {  {
         int      body, tail;          int      body, tail;
   
         if (n->type != MDOC_BODY)          if (n->type != ROFFT_BODY)
                 return;                  return;
   
         if (n->end != ENDBODY_NOT) {          if (n->end != ENDBODY_NOT) {

Legend:
Removed from v.1.101  
changed lines
  Added in v.1.102