summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorschwarze <schwarze@openbsd.org>2017-06-23 22:59:27 +0000
committerschwarze <schwarze@openbsd.org>2017-06-23 22:59:27 +0000
commit005cddddb051646ac36b5f3baf515aac8304fd59 (patch)
tree4d2d49879727331508ed1d795284b8533a60237f
parentsplitting a text box sometimes requires wrapping it in a list (diff)
downloadwireguard-openbsd-005cddddb051646ac36b5f3baf515aac8304fd59.tar.xz
wireguard-openbsd-005cddddb051646ac36b5f3baf515aac8304fd59.zip
Consistently treat character escape sequences as operators,
not as letters, even if their names contain letters. This is certainly not perfect, but code to recognize that \(*a is not an operator but a letter would need a huge table, or Unicode character property support, which won't happen at this time.
-rw-r--r--usr.bin/mandoc/eqn_html.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/usr.bin/mandoc/eqn_html.c b/usr.bin/mandoc/eqn_html.c
index 7ac73b44be1..1f16ac77f85 100644
--- a/usr.bin/mandoc/eqn_html.c
+++ b/usr.bin/mandoc/eqn_html.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: eqn_html.c,v 1.9 2017/06/23 02:31:39 schwarze Exp $ */
+/* $OpenBSD: eqn_html.c,v 1.10 2017/06/23 22:59:27 schwarze Exp $ */
/*
* Copyright (c) 2011, 2014 Kristaps Dzonsons <kristaps@bsd.lv>
* Copyright (c) 2017 Ingo Schwarze <schwarze@openbsd.org>
@@ -32,7 +32,7 @@ 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;
+ const char *cp;
size_t i, j, rows;
enum htmltag tag;
enum eqn_fontt font;
@@ -141,22 +141,28 @@ eqn_box(struct html *p, const struct eqn_box *bp)
if (bp->text != NULL) {
assert(post == NULL);
tag = TAG_MI;
- cp = (unsigned char *)bp->text;
- if (isdigit(cp[0]) || (cp[0] == '.' && isdigit(cp[1]))) {
+ 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(*cp)) {
+ if (*cp != '.' &&
+ isdigit((unsigned char)*cp) == 0) {
tag = TAG_MI;
break;
}
}
- } else if (*cp != '\0' && isalpha(*cp) == 0) {
+ } else if (*cp != '\0' && isalpha((unsigned char)*cp) == 0) {
tag = TAG_MO;
- while (*++cp != '\0') {
- if (isalnum(*cp)) {
+ 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;