[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.254 and 1.256

version 1.254, 2017/01/19 15:48:39 version 1.256, 2017/01/20 19:58:07
Line 242  static const struct htmlmdoc mdocs[MDOC_MAX] = {
Line 242  static const struct htmlmdoc mdocs[MDOC_MAX] = {
         {mdoc_skip_pre, NULL}, /* ll */          {mdoc_skip_pre, NULL}, /* ll */
 };  };
   
 static  const char * const lists[LIST_MAX] = {  
         NULL,  
         "list-bul",  
         "list-col",  
         "list-dash",  
         "list-diag",  
         "list-enum",  
         "list-hang",  
         "list-hyph",  
         "list-inset",  
         "list-item",  
         "list-ohang",  
         "list-tag"  
 };  
   
   
 /*  /*
  * See the same function in mdoc_term.c for documentation.   * See the same function in mdoc_term.c for documentation.
  */   */
Line 683  mdoc_xx_pre(MDOC_ARGS)
Line 668  mdoc_xx_pre(MDOC_ARGS)
 static int  static int
 mdoc_it_pre(MDOC_ARGS)  mdoc_it_pre(MDOC_ARGS)
 {  {
         enum mdoc_list   type;          const struct roff_node  *bl;
         const struct roff_node *bl;          const char              *cattr;
           enum mdoc_list           type;
   
         bl = n->parent;          bl = n->parent;
         while (bl && MDOC_Bl != bl->tok)          while (bl != NULL && bl->tok != MDOC_Bl)
                 bl = bl->parent;                  bl = bl->parent;
         type = bl->norm->Bl.type;          type = bl->norm->Bl.type;
   
         if (n->type == ROFFT_HEAD) {          switch (type) {
                 switch (type) {          case LIST_bullet:
                 case LIST_bullet:                  cattr = "It-bullet";
                 case LIST_dash:                  break;
                 case LIST_item:          case LIST_dash:
                 case LIST_hyphen:          case LIST_hyphen:
                 case LIST_enum:                  cattr = "It-dash";
                   break;
           case LIST_item:
                   cattr = "It-item";
                   break;
           case LIST_enum:
                   cattr = "It-enum";
                   break;
           case LIST_diag:
                   cattr = "It-diag";
                   break;
           case LIST_hang:
                   cattr = "It-hang";
                   break;
           case LIST_inset:
                   cattr = "It-inset";
                   break;
           case LIST_ohang:
                   cattr = "It-ohang";
                   break;
           case LIST_tag:
                   cattr = "It-tag";
                   break;
           case LIST_column:
                   cattr = "It-column";
                   break;
           default:
                   break;
           }
   
           switch (type) {
           case LIST_bullet:
           case LIST_dash:
           case LIST_hyphen:
           case LIST_item:
           case LIST_enum:
                   switch (n->type) {
                   case ROFFT_HEAD:
                         return 0;                          return 0;
                 case LIST_diag:                  case ROFFT_BODY:
                 case LIST_hang:                          print_otag(h, TAG_LI, "csvt", cattr,
                 case LIST_inset:  
                 case LIST_ohang:  
                 case LIST_tag:  
                         print_otag(h, TAG_DT, "csvt", lists[type],  
                             !bl->norm->Bl.comp);                              !bl->norm->Bl.comp);
                         if (LIST_diag != type)  
                                 break;  
                         print_otag(h, TAG_B, "c", "diag");  
                         break;                          break;
                 case LIST_column:  
                         break;  
                 default:                  default:
                         break;                          break;
                 }                  }
         } else if (n->type == ROFFT_BODY) {                  break;
                 switch (type) {          case LIST_diag:
                 case LIST_bullet:          case LIST_hang:
                 case LIST_hyphen:          case LIST_inset:
                 case LIST_dash:          case LIST_ohang:
                 case LIST_enum:          case LIST_tag:
                 case LIST_item:                  switch (n->type) {
                         print_otag(h, TAG_LI, "csvt", lists[type],                  case ROFFT_HEAD:
                           print_otag(h, TAG_DT, "csvt", cattr,
                             !bl->norm->Bl.comp);                              !bl->norm->Bl.comp);
                           if (type == LIST_diag)
                                   print_otag(h, TAG_B, "c", cattr);
                         break;                          break;
                 case LIST_diag:                  case ROFFT_BODY:
                 case LIST_hang:                          if (bl->norm->Bl.width == NULL)
                 case LIST_inset:                                  print_otag(h, TAG_DD, "c", cattr);
                 case LIST_ohang:                          else
                 case LIST_tag:                                  print_otag(h, TAG_DD, "cswl", cattr,
                         if (NULL == bl->norm->Bl.width) {                                      bl->norm->Bl.width);
                                 print_otag(h, TAG_DD, "c", lists[type]);  
                                 break;  
                         }  
                         print_otag(h, TAG_DD, "cswl", lists[type],  
                             bl->norm->Bl.width);  
                         break;                          break;
                 case LIST_column:  
                         print_otag(h, TAG_TD, "csvt", lists[type],  
                             !bl->norm->Bl.comp);  
                         break;  
                 default:                  default:
                         break;                          break;
                 }                  }
         } else {                  break;
                 switch (type) {          case LIST_column:
                 case LIST_column:                  switch (n->type) {
                         print_otag(h, TAG_TR, "c", lists[type]);                  case ROFFT_HEAD:
                         break;                          break;
                 default:                  case ROFFT_BODY:
                           print_otag(h, TAG_TD, "csvt", cattr,
                               !bl->norm->Bl.comp);
                         break;                          break;
                   default:
                           print_otag(h, TAG_TR, "c", cattr);
                 }                  }
           default:
                   break;
         }          }
   
         return 1;          return 1;
Line 760  mdoc_it_pre(MDOC_ARGS)
Line 774  mdoc_it_pre(MDOC_ARGS)
 static int  static int
 mdoc_bl_pre(MDOC_ARGS)  mdoc_bl_pre(MDOC_ARGS)
 {  {
           const char      *cattr;
         int              i;          int              i;
         char             buf[BUFSIZ];  
         enum htmltag     elemtype;          enum htmltag     elemtype;
   
         if (n->type == ROFFT_BODY) {          if (n->type == ROFFT_BODY) {
Line 788  mdoc_bl_pre(MDOC_ARGS)
Line 802  mdoc_bl_pre(MDOC_ARGS)
                 return 0;                  return 0;
         }          }
   
         assert(lists[n->norm->Bl.type]);  
         (void)strlcpy(buf, "list ", BUFSIZ);  
         (void)strlcat(buf, lists[n->norm->Bl.type], BUFSIZ);  
   
         switch (n->norm->Bl.type) {          switch (n->norm->Bl.type) {
         case LIST_bullet:          case LIST_bullet:
                   elemtype = TAG_UL;
                   cattr = "Bl-bullet";
                   break;
         case LIST_dash:          case LIST_dash:
         case LIST_hyphen:          case LIST_hyphen:
                   elemtype = TAG_UL;
                   cattr = "Bl-dash";
                   break;
         case LIST_item:          case LIST_item:
                 elemtype = TAG_UL;                  elemtype = TAG_UL;
                   cattr = "Bl-item";
                 break;                  break;
         case LIST_enum:          case LIST_enum:
                 elemtype = TAG_OL;                  elemtype = TAG_OL;
                   cattr = "Bl-enum";
                 break;                  break;
         case LIST_diag:          case LIST_diag:
                   elemtype = TAG_DL;
                   cattr = "Bl-diag";
                   break;
         case LIST_hang:          case LIST_hang:
                   elemtype = TAG_DL;
                   cattr = "Bl-hang";
                   break;
         case LIST_inset:          case LIST_inset:
                   elemtype = TAG_DL;
                   cattr = "Bl-inset";
                   break;
         case LIST_ohang:          case LIST_ohang:
                   elemtype = TAG_DL;
                   cattr = "Bl-ohang";
                   break;
         case LIST_tag:          case LIST_tag:
                 elemtype = TAG_DL;                  elemtype = TAG_DL;
                   cattr = "Bl-tag";
                 break;                  break;
         case LIST_column:          case LIST_column:
                 elemtype = TAG_TABLE;                  elemtype = TAG_TABLE;
                   cattr = "Bl-column";
                 break;                  break;
         default:          default:
                 abort();                  abort();
         }          }
   
         if (n->norm->Bl.offs)          if (n->norm->Bl.offs)
                 print_otag(h, elemtype, "csvtvbwl", buf, 0, 0,                  print_otag(h, elemtype, "csvtvbwl", cattr, 0, 0,
                     n->norm->Bl.offs);                      n->norm->Bl.offs);
         else          else
                 print_otag(h, elemtype, "csvtvb", buf, 0, 0);                  print_otag(h, elemtype, "csvtvb", cattr, 0, 0);
   
         return 1;          return 1;
 }  }
Line 846  mdoc_d1_pre(MDOC_ARGS)
Line 878  mdoc_d1_pre(MDOC_ARGS)
         if (n->type != ROFFT_BLOCK)          if (n->type != ROFFT_BLOCK)
                 return 1;                  return 1;
   
         print_otag(h, TAG_BLOCKQUOTE, "svtvb", 0, 0);          print_otag(h, TAG_DIV, "c", "D1");
   
         /* BLOCKQUOTE needs a block body. */          if (n->tok == MDOC_Dl)
                   print_otag(h, TAG_CODE, "c", "Li");
   
         print_otag(h, TAG_DIV, "c", "display");  
   
         if (MDOC_Dl == n->tok)  
                 print_otag(h, TAG_CODE, "c", "lit");  
   
         return 1;          return 1;
 }  }
   
Line 909  mdoc_bd_pre(MDOC_ARGS)
Line 937  mdoc_bd_pre(MDOC_ARGS)
                 offs = -1;                  offs = -1;
   
         if (offs == -1)          if (offs == -1)
                 print_otag(h, TAG_DIV, "cswl", "display", n->norm->Bd.offs);                  print_otag(h, TAG_DIV, "cswl", "Bd", n->norm->Bd.offs);
         else          else
                 print_otag(h, TAG_DIV, "cshl", "display", offs);                  print_otag(h, TAG_DIV, "cshl", "Bd", offs);
   
         if (n->norm->Bd.type != DISP_unfilled &&          if (n->norm->Bd.type != DISP_unfilled &&
             n->norm->Bd.type != DISP_literal)              n->norm->Bd.type != DISP_literal)
                 return 1;                  return 1;
   
         print_otag(h, TAG_PRE, "c", "lit");          print_otag(h, TAG_PRE, "c", "Li");
   
         /* This can be recursive: save & set our literal state. */          /* This can be recursive: save & set our literal state. */
   
Line 1414  mdoc_bf_pre(MDOC_ARGS)
Line 1442  mdoc_bf_pre(MDOC_ARGS)
         else if (FONT_Sy == n->norm->Bf.font)          else if (FONT_Sy == n->norm->Bf.font)
                 cattr = "symb";                  cattr = "symb";
         else if (FONT_Li == n->norm->Bf.font)          else if (FONT_Li == n->norm->Bf.font)
                 cattr = "lit";                  cattr = "Li";
         else          else
                 cattr = "none";                  cattr = "none";
   
Line 1473  mdoc_no_pre(MDOC_ARGS)
Line 1501  mdoc_no_pre(MDOC_ARGS)
 static int  static int
 mdoc_li_pre(MDOC_ARGS)  mdoc_li_pre(MDOC_ARGS)
 {  {
         print_otag(h, TAG_CODE, "c", "lit");          print_otag(h, TAG_CODE, "c", "Li");
         return 1;          return 1;
 }  }
   
Line 1656  mdoc_quote_pre(MDOC_ARGS)
Line 1684  mdoc_quote_pre(MDOC_ARGS)
         case MDOC_Ql:          case MDOC_Ql:
                 print_text(h, "\\(oq");                  print_text(h, "\\(oq");
                 h->flags |= HTML_NOSPACE;                  h->flags |= HTML_NOSPACE;
                 print_otag(h, TAG_CODE, "c", "lit");                  print_otag(h, TAG_CODE, "c", "Li");
                 break;                  break;
         case MDOC_So:          case MDOC_So:
         case MDOC_Sq:          case MDOC_Sq:

Legend:
Removed from v.1.254  
changed lines
  Added in v.1.256

CVSweb