Write text boxes as <mi>, <mn>, or <mo> as appropriate,
authorschwarze <schwarze@openbsd.org>
Fri, 23 Jun 2017 02:31:39 +0000 (02:31 +0000)
committerschwarze <schwarze@openbsd.org>
Fri, 23 Jun 2017 02:31:39 +0000 (02:31 +0000)
and write fontstyle or fontweight attributes where required.
Missing features reported by bentley@.

usr.bin/mandoc/eqn_html.c
usr.bin/mandoc/html.c
usr.bin/mandoc/html.h

index 4b29457..7ac73b4 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: eqn_html.c,v 1.8 2017/06/20 17:24:09 schwarze Exp $ */
+/*     $OpenBSD: eqn_html.c,v 1.9 2017/06/23 02:31:39 schwarze Exp $ */
 /*
  * Copyright (c) 2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -18,6 +18,7 @@
 #include <sys/types.h>
 
 #include <assert.h>
+#include <ctype.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
@@ -31,7 +32,10 @@ eqn_box(struct html *p, const struct eqn_box *bp)
 {
        struct tag      *post, *row, *cell, *t;
        const struct eqn_box *child, *parent;
+       const unsigned char *cp;
        size_t           i, j, rows;
+       enum htmltag     tag;
+       enum eqn_fontt   font;
 
        if (NULL == bp)
                return;
@@ -134,9 +138,51 @@ eqn_box(struct html *p, const struct eqn_box *bp)
                print_otag(p, TAG_MTD, "");
        }
 
-       if (NULL != bp->text) {
-               assert(NULL == post);
-               post = print_otag(p, TAG_MI, "");
+       if (bp->text != NULL) {
+               assert(post == NULL);
+               tag = TAG_MI;
+               cp = (unsigned char *)bp->text;
+               if (isdigit(cp[0]) || (cp[0] == '.' && isdigit(cp[1]))) {
+                       tag = TAG_MN;
+                       while (*++cp != '\0') {
+                               if (*cp != '.' && !isdigit(*cp)) {
+                                       tag = TAG_MI;
+                                       break;
+                               }
+                       }
+               } else if (*cp != '\0' && isalpha(*cp) == 0) {
+                       tag = TAG_MO;
+                       while (*++cp != '\0') {
+                               if (isalnum(*cp)) {
+                                       tag = TAG_MI;
+                                       break;
+                               }
+                       }
+               }
+               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);
        } else if (NULL == post) {
                if (NULL != bp->left || NULL != bp->right)
index 5857624..169bed9 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: html.c,v 1.84 2017/06/14 01:31:19 schwarze Exp $ */
+/*     $OpenBSD: html.c,v 1.85 2017/06/23 02:31:39 schwarze Exp $ */
 /*
  * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2011-2015, 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -85,6 +85,7 @@ static        const struct htmldata htmltags[TAG_MAX] = {
        {"math",        HTML_NLALL | HTML_INDENT},
        {"mrow",        0},
        {"mi",          0},
+       {"mn",          0},
        {"mo",          0},
        {"msup",        0},
        {"msub",        0},
index b4a4c35..94fd059 100644 (file)
@@ -1,4 +1,4 @@
-/*     $OpenBSD: html.h,v 1.47 2017/05/04 22:07:44 schwarze Exp $ */
+/*     $OpenBSD: html.h,v 1.48 2017/06/23 02:31:39 schwarze Exp $ */
 /*
  * Copyright (c) 2008-2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
  * Copyright (c) 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -51,6 +51,7 @@ enum  htmltag {
        TAG_MATH,
        TAG_MROW,
        TAG_MI,
+       TAG_MN,
        TAG_MO,
        TAG_MSUP,
        TAG_MSUB,