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

Diff for /mandoc/eqn_html.c between version 1.11 and 1.17

version 1.11, 2017/01/17 01:47:51 version 1.17, 2017/07/14 13:32:35
Line 20 
Line 20 
 #include <sys/types.h>  #include <sys/types.h>
   
 #include <assert.h>  #include <assert.h>
   #include <ctype.h>
 #include <stdio.h>  #include <stdio.h>
 #include <stdlib.h>  #include <stdlib.h>
 #include <string.h>  #include <string.h>
Line 33  eqn_box(struct html *p, const struct eqn_box *bp)
Line 34  eqn_box(struct html *p, const struct eqn_box *bp)
 {  {
         struct tag      *post, *row, *cell, *t;          struct tag      *post, *row, *cell, *t;
         const struct eqn_box *child, *parent;          const struct eqn_box *child, *parent;
           const char      *cp;
         size_t           i, j, rows;          size_t           i, j, rows;
           enum htmltag     tag;
           enum eqn_fontt   font;
   
         if (NULL == bp)          if (NULL == bp)
                 return;                  return;
Line 47  eqn_box(struct html *p, const struct eqn_box *bp)
Line 51  eqn_box(struct html *p, const struct eqn_box *bp)
         if (EQN_MATRIX == bp->type) {          if (EQN_MATRIX == bp->type) {
                 if (NULL == bp->first)                  if (NULL == bp->first)
                         goto out;                          goto out;
                 if (EQN_LIST != bp->first->type) {                  if (bp->first->type != EQN_LIST ||
                       bp->first->expectargs == 1) {
                         eqn_box(p, bp->first);                          eqn_box(p, bp->first);
                         goto out;                          goto out;
                 }                  }
Line 87  eqn_box(struct html *p, const struct eqn_box *bp)
Line 92  eqn_box(struct html *p, const struct eqn_box *bp)
         }          }
   
         switch (bp->pos) {          switch (bp->pos) {
         case (EQNPOS_TO):          case EQNPOS_TO:
                 post = print_otag(p, TAG_MOVER, "");                  post = print_otag(p, TAG_MOVER, "");
                 break;                  break;
         case (EQNPOS_SUP):          case EQNPOS_SUP:
                 post = print_otag(p, TAG_MSUP, "");                  post = print_otag(p, TAG_MSUP, "");
                 break;                  break;
         case (EQNPOS_FROM):          case EQNPOS_FROM:
                 post = print_otag(p, TAG_MUNDER, "");                  post = print_otag(p, TAG_MUNDER, "");
                 break;                  break;
         case (EQNPOS_SUB):          case EQNPOS_SUB:
                 post = print_otag(p, TAG_MSUB, "");                  post = print_otag(p, TAG_MSUB, "");
                 break;                  break;
         case (EQNPOS_OVER):          case EQNPOS_OVER:
                 post = print_otag(p, TAG_MFRAC, "");                  post = print_otag(p, TAG_MFRAC, "");
                 break;                  break;
         case (EQNPOS_FROMTO):          case EQNPOS_FROMTO:
                 post = print_otag(p, TAG_MUNDEROVER, "");                  post = print_otag(p, TAG_MUNDEROVER, "");
                 break;                  break;
         case (EQNPOS_SUBSUP):          case EQNPOS_SUBSUP:
                 post = print_otag(p, TAG_MSUBSUP, "");                  post = print_otag(p, TAG_MSUBSUP, "");
                 break;                  break;
         case (EQNPOS_SQRT):          case EQNPOS_SQRT:
                 post = print_otag(p, TAG_MSQRT, "");                  post = print_otag(p, TAG_MSQRT, "");
                 break;                  break;
         default:          default:
Line 127  eqn_box(struct html *p, const struct eqn_box *bp)
Line 132  eqn_box(struct html *p, const struct eqn_box *bp)
   
         if (EQN_PILE == bp->type) {          if (EQN_PILE == bp->type) {
                 assert(NULL == post);                  assert(NULL == post);
                 if (bp->first != NULL && bp->first->type == EQN_LIST)                  if (bp->first != NULL &&
                       bp->first->type == EQN_LIST &&
                       bp->first->expectargs > 1)
                         post = print_otag(p, TAG_MTABLE, "");                          post = print_otag(p, TAG_MTABLE, "");
         } else if (bp->type == EQN_LIST &&          } else if (bp->type == EQN_LIST && bp->expectargs > 1 &&
             bp->parent && bp->parent->type == EQN_PILE) {              bp->parent && bp->parent->type == EQN_PILE) {
                 assert(NULL == post);                  assert(NULL == post);
                 post = print_otag(p, TAG_MTR, "");                  post = print_otag(p, TAG_MTR, "");
                 print_otag(p, TAG_MTD, "");                  print_otag(p, TAG_MTD, "");
         }          }
   
         if (NULL != bp->text) {          if (bp->text != NULL) {
                 assert(NULL == post);                  assert(post == NULL);
                 post = print_otag(p, TAG_MI, "");                  tag = TAG_MI;
                   cp = bp->text;
                   if (isdigit((unsigned char)cp[0]) ||
                       (cp[0] == '.' && isdigit((unsigned char)cp[1]))) {
                           tag = TAG_MN;
                           while (*++cp != '\0') {
                                   if (*cp != '.' &&
                                       isdigit((unsigned char)*cp) == 0) {
                                           tag = TAG_MI;
                                           break;
                                   }
                           }
                   } else if (*cp != '\0' && isalpha((unsigned char)*cp) == 0) {
                           tag = TAG_MO;
                           while (*cp != '\0') {
                                   if (cp[0] == '\\' && cp[1] != '\0') {
                                           cp++;
                                           mandoc_escape(&cp, NULL, NULL);
                                   } else if (isalnum((unsigned char)*cp)) {
                                           tag = TAG_MI;
                                           break;
                                   } else
                                           cp++;
                           }
                   }
                   font = bp->font;
                   if (bp->text[0] != '\0' &&
                       (((tag == TAG_MN || tag == TAG_MO) &&
                         font == EQNFONT_ROMAN) ||
                        (tag == TAG_MI && font == (bp->text[1] == '\0' ?
                         EQNFONT_ITALIC : EQNFONT_ROMAN))))
                           font = EQNFONT_NONE;
                   switch (font) {
                   case EQNFONT_NONE:
                           post = print_otag(p, tag, "");
                           break;
                   case EQNFONT_ROMAN:
                           post = print_otag(p, tag, "?", "fontstyle", "normal");
                           break;
                   case EQNFONT_BOLD:
                   case EQNFONT_FAT:
                           post = print_otag(p, tag, "?", "fontweight", "bold");
                           break;
                   case EQNFONT_ITALIC:
                           post = print_otag(p, tag, "?", "fontstyle", "italic");
                           break;
                   default:
                           abort();
                   }
                 print_text(p, bp->text);                  print_text(p, bp->text);
         } else if (NULL == post) {          } else if (NULL == post) {
                 if (NULL != bp->left || NULL != bp->right)                  if (NULL != bp->left || NULL != bp->right)
Line 172  out:
Line 227  out:
 }  }
   
 void  void
 print_eqn(struct html *p, const struct eqn *ep)  print_eqn(struct html *p, const struct eqn_box *bp)
 {  {
         struct tag      *t;          struct tag      *t;
   
           if (bp->first == NULL)
                   return;
   
         t = print_otag(p, TAG_MATH, "c", "eqn");          t = print_otag(p, TAG_MATH, "c", "eqn");
   
         p->flags |= HTML_NONOSPACE;          p->flags |= HTML_NONOSPACE;
         eqn_box(p, ep->root);          eqn_box(p, bp);
         p->flags &= ~HTML_NONOSPACE;          p->flags &= ~HTML_NONOSPACE;
   
         print_tagq(p, t);          print_tagq(p, t);

Legend:
Removed from v.1.11  
changed lines
  Added in v.1.17

CVSweb