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

Diff for /mandoc/html.c between version 1.248 and 1.253

version 1.248, 2019/01/05 09:14:44 version 1.253, 2019/03/01 10:57:17
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011-2015, 2017, 2018 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2011-2015, 2017-2019 Ingo Schwarze <schwarze@openbsd.org>
  *   *
  * 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 63  static const struct htmldata htmltags[TAG_MAX] = {
Line 63  static const struct htmldata htmltags[TAG_MAX] = {
         {"title",       HTML_NLAROUND},          {"title",       HTML_NLAROUND},
         {"div",         HTML_NLAROUND},          {"div",         HTML_NLAROUND},
         {"div",         0},          {"div",         0},
           {"section",     HTML_NLALL},
         {"h1",          HTML_NLAROUND},          {"h1",          HTML_NLAROUND},
         {"h2",          HTML_NLAROUND},          {"h2",          HTML_NLAROUND},
         {"span",        0},          {"span",        0},
Line 78  static const struct htmldata htmltags[TAG_MAX] = {
Line 79  static const struct htmldata htmltags[TAG_MAX] = {
         {"dl",          HTML_NLALL | HTML_INDENT},          {"dl",          HTML_NLALL | HTML_INDENT},
         {"dt",          HTML_NLAROUND},          {"dt",          HTML_NLAROUND},
         {"dd",          HTML_NLAROUND | HTML_INDENT},          {"dd",          HTML_NLAROUND | HTML_INDENT},
           {"p",           HTML_NLAROUND | HTML_INDENT},
         {"pre",         HTML_NLALL | HTML_NOINDENT},          {"pre",         HTML_NLALL | HTML_NOINDENT},
         {"var",         0},          {"var",         0},
         {"cite",        0},          {"cite",        0},
Line 265  print_metaf(struct html *h, enum mandoc_esc deco)
Line 267  print_metaf(struct html *h, enum mandoc_esc deco)
         }          }
 }  }
   
   void
   html_close_paragraph(struct html *h)
   {
           struct tag      *t;
   
           for (t = h->tag; t != NULL && t->closed == 0; t = t->next) {
                   switch(t->tag) {
                   case TAG_P:
                   case TAG_PRE:
                           print_tagq(h, t);
                           break;
                   case TAG_A:
                           print_tagq(h, t);
                           continue;
                   default:
                           continue;
                   }
                   break;
           }
   }
   
 /*  /*
  * ROFF_nf switches to no-fill mode, ROFF_fi to fill mode.   * ROFF_nf switches to no-fill mode, ROFF_fi to fill mode.
  * TOKEN_NONE does not switch.  The old mode is returned.   * TOKEN_NONE does not switch.  The old mode is returned.
Line 287  html_fillmode(struct html *h, enum roff_tok want)
Line 310  html_fillmode(struct html *h, enum roff_tok want)
                         print_tagq(h, t);                          print_tagq(h, t);
                         break;                          break;
                 case ROFF_nf:                  case ROFF_nf:
                           html_close_paragraph(h);
                         print_otag(h, TAG_PRE, "");                          print_otag(h, TAG_PRE, "");
                         break;                          break;
                 case TOKEN_NONE:                  case TOKEN_NONE:
Line 564  print_otag(struct html *h, enum htmltag tag, const cha
Line 588  print_otag(struct html *h, enum htmltag tag, const cha
                 t = mandoc_malloc(sizeof(struct tag));                  t = mandoc_malloc(sizeof(struct tag));
                 t->tag = tag;                  t->tag = tag;
                 t->next = h->tag;                  t->next = h->tag;
                   t->refcnt = 0;
                   t->closed = 0;
                 h->tag = t;                  h->tag = t;
         } else          } else
                 t = NULL;                  t = NULL;
Line 642  print_otag(struct html *h, enum htmltag tag, const cha
Line 668  print_otag(struct html *h, enum htmltag tag, const cha
                         print_encode(h, arg1, NULL, 1);                          print_encode(h, arg1, NULL, 1);
                         fmt++;                          fmt++;
                         break;                          break;
                 case 'T':  
                         print_encode(h, arg1, NULL, 1);  
                         print_word(h, "\" title=\"");  
                         print_encode(h, arg1, NULL, 1);  
                         fmt++;  
                         break;  
                 default:                  default:
                         print_encode(h, arg1, NULL, 1);                          print_encode(h, arg1, NULL, 1);
                         break;                          break;
Line 702  print_ctag(struct html *h, struct tag *tag)
Line 722  print_ctag(struct html *h, struct tag *tag)
 {  {
         int      tflags;          int      tflags;
   
         /*          if (tag->closed == 0) {
          * Remember to close out and nullify the current                  tag->closed = 1;
          * meta-font and table, if applicable.                  if (tag == h->metaf)
          */                          h->metaf = NULL;
         if (tag == h->metaf)                  if (tag == h->tblt)
                 h->metaf = NULL;                          h->tblt = NULL;
         if (tag == h->tblt)  
                 h->tblt = NULL;  
   
         tflags = htmltags[tag->tag].flags;                  tflags = htmltags[tag->tag].flags;
                   if (tflags & HTML_INDENT)
         if (tflags & HTML_INDENT)                          h->indent--;
                 h->indent--;                  if (tflags & HTML_NOINDENT)
         if (tflags & HTML_NOINDENT)                          h->noindent--;
                 h->noindent--;                  if (tflags & HTML_NLEND)
         if (tflags & HTML_NLEND)                          print_endline(h);
                 print_endline(h);                  print_indent(h);
         print_indent(h);                  print_byte(h, '<');
         print_byte(h, '<');                  print_byte(h, '/');
         print_byte(h, '/');                  print_word(h, htmltags[tag->tag].name);
         print_word(h, htmltags[tag->tag].name);                  print_byte(h, '>');
         print_byte(h, '>');                  if (tflags & HTML_NLAFTER)
         if (tflags & HTML_NLAFTER)                          print_endline(h);
                 print_endline(h);          }
           if (tag->refcnt == 0) {
         h->tag = tag->next;                  h->tag = tag->next;
         free(tag);                  free(tag);
           }
 }  }
   
 void  void
Line 815  print_text(struct html *h, const char *word)
Line 834  print_text(struct html *h, const char *word)
 void  void
 print_tagq(struct html *h, const struct tag *until)  print_tagq(struct html *h, const struct tag *until)
 {  {
         struct tag      *tag;          struct tag      *this, *next;
   
         while ((tag = h->tag) != NULL) {          for (this = h->tag; this != NULL; this = next) {
                 print_ctag(h, tag);                  next = this == until ? NULL : this->next;
                 if (until && tag == until)                  print_ctag(h, this);
                         return;  
         }          }
 }  }
   
   /*
    * Close out all open elements up to but excluding suntil.
    * Note that a paragraph just inside stays open together with it
    * because paragraphs include subsequent phrasing content.
    */
 void  void
 print_stagq(struct html *h, const struct tag *suntil)  print_stagq(struct html *h, const struct tag *suntil)
 {  {
         struct tag      *tag;          struct tag      *this, *next;
   
         while ((tag = h->tag) != NULL) {          for (this = h->tag; this != NULL; this = next) {
                 if (suntil && tag == suntil)                  next = this->next;
                         return;                  if (this == suntil || (next == suntil &&
                 print_ctag(h, tag);                      (this->tag == TAG_P || this->tag == TAG_PRE)))
                           break;
                   print_ctag(h, this);
         }          }
 }  
   
 void  
 print_paragraph(struct html *h)  
 {  
         struct tag      *t;  
   
         t = print_otag(h, TAG_DIV, "c", "Pp");  
         print_tagq(h, t);  
 }  }
   
   

Legend:
Removed from v.1.248  
changed lines
  Added in v.1.253

CVSweb