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

Diff for /mandoc/html.c between version 1.171 and 1.180

version 1.171, 2014/09/27 10:56:18 version 1.180, 2014/10/28 17:36:19
Line 1 
Line 1 
 /*      $Id$ */  /*      $Id$ */
 /*  /*
  * Copyright (c) 2008, 2009, 2010, 2011 Kristaps Dzonsons <kristaps@bsd.lv>   * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011, 2012, 2013, 2014 Ingo Schwarze <schwarze@openbsd.org>   * Copyright (c) 2011, 2012, 2013, 2014 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
Line 74  static const struct htmldata htmltags[TAG_MAX] = {
Line 74  static const struct htmldata htmltags[TAG_MAX] = {
         {"code",        0 }, /* TAG_CODE */          {"code",        0 }, /* TAG_CODE */
         {"small",       0 }, /* TAG_SMALL */          {"small",       0 }, /* TAG_SMALL */
         {"style",       HTML_CLRLINE}, /* TAG_STYLE */          {"style",       HTML_CLRLINE}, /* TAG_STYLE */
           {"math",        HTML_CLRLINE}, /* TAG_MATH */
           {"mrow",        0}, /* TAG_MROW */
           {"mi",          0}, /* TAG_MI */
           {"mo",          0}, /* TAG_MO */
           {"msup",        0}, /* TAG_MSUP */
           {"msub",        0}, /* TAG_MSUB */
           {"msubsup",     0}, /* TAG_MSUBSUP */
           {"mfrac",       0}, /* TAG_MFRAC */
           {"msqrt",       0}, /* TAG_MSQRT */
           {"mfenced",     0}, /* TAG_MFENCED */
           {"mtable",      0}, /* TAG_MTABLE */
           {"mtr",         0}, /* TAG_MTR */
           {"mtd",         0}, /* TAG_MTD */
           {"munderover",  0}, /* TAG_MUNDEROVER */
           {"munder",      0}, /* TAG_MUNDER*/
           {"mover",       0}, /* TAG_MOVER*/
 };  };
   
 static  const char      *const htmlattrs[ATTR_MAX] = {  static  const char      *const htmlattrs[ATTR_MAX] = {
Line 87  static const char *const htmlattrs[ATTR_MAX] = {
Line 103  static const char *const htmlattrs[ATTR_MAX] = {
         "id", /* ATTR_ID */          "id", /* ATTR_ID */
         "colspan", /* ATTR_COLSPAN */          "colspan", /* ATTR_COLSPAN */
         "charset", /* ATTR_CHARSET */          "charset", /* ATTR_CHARSET */
           "open", /* ATTR_OPEN */
           "close", /* ATTR_CLOSE */
           "mathvariant", /* ATTR_MATHVARIANT */
 };  };
   
 static  const char      *const roffscales[SCALE_MAX] = {  static  const char      *const roffscales[SCALE_MAX] = {
Line 108  static int  print_escape(char);
Line 127  static int  print_escape(char);
 static  int      print_encode(struct html *, const char *, int);  static  int      print_encode(struct html *, const char *, int);
 static  void     print_metaf(struct html *, enum mandoc_esc);  static  void     print_metaf(struct html *, enum mandoc_esc);
 static  void     print_attr(struct html *, const char *, const char *);  static  void     print_attr(struct html *, const char *, const char *);
 static  void     *ml_alloc(char *, enum htmltype);  
   
   
 static void *  void *
 ml_alloc(char *outopts, enum htmltype type)  html_alloc(const struct mchars *mchars, char *outopts)
 {  {
         struct html     *h;          struct html     *h;
         const char      *toks[5];          const char      *toks[5];
Line 126  ml_alloc(char *outopts, enum htmltype type)
Line 144  ml_alloc(char *outopts, enum htmltype type)
   
         h = mandoc_calloc(1, sizeof(struct html));          h = mandoc_calloc(1, sizeof(struct html));
   
         h->type = type;  
         h->tags.head = NULL;          h->tags.head = NULL;
         h->symtab = mchars_alloc();          h->symtab = mchars;
   
         while (outopts && *outopts)          while (outopts && *outopts)
                 switch (getsubopt(&outopts, UNCONST(toks), &v)) {                  switch (getsubopt(&outopts, UNCONST(toks), &v)) {
Line 151  ml_alloc(char *outopts, enum htmltype type)
Line 168  ml_alloc(char *outopts, enum htmltype type)
         return(h);          return(h);
 }  }
   
 void *  
 html_alloc(char *outopts)  
 {  
   
         return(ml_alloc(outopts, HTML_HTML_4_01_STRICT));  
 }  
   
 void *  
 xhtml_alloc(char *outopts)  
 {  
   
         return(ml_alloc(outopts, HTML_XHTML_1_0_STRICT));  
 }  
   
 void  void
 html_free(void *p)  html_free(void *p)
 {  {
Line 178  html_free(void *p)
Line 181  html_free(void *p)
                 free(tag);                  free(tag);
         }          }
   
         if (h->symtab)  
                 mchars_free(h->symtab);  
   
         free(h);          free(h);
 }  }
   
Line 419  print_encode(struct html *h, const char *p, int norecu
Line 419  print_encode(struct html *h, const char *p, int norecu
                 case ESCAPE_UNICODE:                  case ESCAPE_UNICODE:
                         /* Skip past "u" header. */                          /* Skip past "u" header. */
                         c = mchars_num2uc(seq + 1, len - 1);                          c = mchars_num2uc(seq + 1, len - 1);
                         if ('\0' != c)  
                                 printf("&#x%x;", c);  
                         break;                          break;
                 case ESCAPE_NUMBERED:                  case ESCAPE_NUMBERED:
                         c = mchars_num2char(seq, len);                          c = mchars_num2char(seq, len);
                         if ( ! ('\0' == c || print_escape(c)))  
                                 putchar(c);  
                         break;                          break;
                 case ESCAPE_SPECIAL:                  case ESCAPE_SPECIAL:
                         c = mchars_spec2cp(h->symtab, seq, len);                          c = mchars_spec2cp(h->symtab, seq, len);
                         if (c > 0)  
                                 printf("&#%d;", c);  
                         else if (-1 == c && 1 == len &&  
                             !print_escape(*seq))  
                                 putchar((int)*seq);  
                         break;                          break;
                 case ESCAPE_NOSPACE:                  case ESCAPE_NOSPACE:
                         if ('\0' == *p)                          if ('\0' == *p)
                                 nospace = 1;                                  nospace = 1;
                         break;                          continue;
                 default:                  default:
                         break;                          continue;
                 }                  }
                   if (c <= 0)
                           continue;
                   if (c < 0x20 || (c > 0x7E && c < 0xA0))
                           c = 0xFFFD;
                   if (c > 0x7E)
                           printf("&#%d;", c);
                   else if ( ! print_escape(c))
                           putchar(c);
         }          }
   
         return(nospace);          return(nospace);
Line 494  print_otag(struct html *h, enum htmltag tag,
Line 493  print_otag(struct html *h, enum htmltag tag,
         for (i = 0; i < sz; i++)          for (i = 0; i < sz; i++)
                 print_attr(h, htmlattrs[p[i].key], p[i].val);                  print_attr(h, htmlattrs[p[i].key], p[i].val);
   
         /* Accommodate for XML "well-formed" singleton escaping. */          /* Accommodate for "well-formed" singleton escaping. */
   
         if (HTML_AUTOCLOSE & htmltags[tag].flags)          if (HTML_AUTOCLOSE & htmltags[tag].flags)
                 switch (h->type) {                  putchar('/');
                 case HTML_XHTML_1_0_STRICT:  
                         putchar('/');  
                         break;  
                 default:  
                         break;  
                 }  
   
         putchar('>');          putchar('>');
   

Legend:
Removed from v.1.171  
changed lines
  Added in v.1.180

CVSweb