summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorKristaps Dzonsons <kristaps@bsd.lv>2010-01-30 06:55:56 +0000
committerKristaps Dzonsons <kristaps@bsd.lv>2010-01-30 06:55:56 +0000
commit2debde16583c6e330407391e74591b82ec962814 (patch)
tree9c2c4dede8cfd0196f0f5cdf356f7698f3ead198
parent69a80825be62eeca6a77c1f0a38955d29e30cd03 (diff)
downloadmandoc-2debde16583c6e330407391e74591b82ec962814.tar.gz
mandoc-2debde16583c6e330407391e74591b82ec962814.tar.zst
mandoc-2debde16583c6e330407391e74591b82ec962814.zip
Mandate html attributes for xhtml.
-rw-r--r--html.c34
1 files changed, 28 insertions, 6 deletions
diff --git a/html.c b/html.c
index 70641b72..a2da5931 100644
--- a/html.c
+++ b/html.c
@@ -1,4 +1,4 @@
-/* $Id: html.c,v 1.93 2010/01/29 14:39:37 kristaps Exp $ */
+/* $Id: html.c,v 1.94 2010/01/30 06:55:56 kristaps Exp $ */
/*
* Copyright (c) 2008, 2009 Kristaps Dzonsons <kristaps@kth.se>
*
@@ -96,6 +96,8 @@ static void print_doctype(struct html *);
static void print_xmltype(struct html *);
static int print_encode(struct html *, const char *, int);
static void print_metaf(struct html *, enum roffdeco);
+static void print_attr(struct html *,
+ const char *, const char *);
static void *ml_alloc(char *, enum htmltype);
@@ -310,6 +312,7 @@ print_encode(struct html *h, const char *p, int norecurse)
} else if ('>' == *p) {
printf("&gt;");
continue;
+ /* FIXME: already escaped? */
} else if ('&' == *p) {
printf("&amp;");
continue;
@@ -351,6 +354,15 @@ print_encode(struct html *h, const char *p, int norecurse)
}
+static void
+print_attr(struct html *h, const char *key, const char *val)
+{
+ printf(" %s=\"", key);
+ (void)print_encode(h, val, 1);
+ putchar('\"');
+}
+
+
struct tag *
print_otag(struct html *h, enum htmltag tag,
int sz, const struct htmlpair *p)
@@ -358,6 +370,8 @@ print_otag(struct html *h, enum htmltag tag,
int i;
struct tag *t;
+ /* Push this tags onto the stack of open scopes. */
+
if ( ! (HTML_NOSTACK & htmltags[tag].flags)) {
t = malloc(sizeof(struct tag));
if (NULL == t) {
@@ -374,14 +388,22 @@ print_otag(struct html *h, enum htmltag tag,
if ( ! (HTML_CLRLINE & htmltags[tag].flags))
putchar(' ');
+ /* Print out the tag name and attributes. */
+
printf("<%s", htmltags[tag].name);
- for (i = 0; i < sz; i++) {
- printf(" %s=\"", htmlattrs[p[i].key]);
- assert(p->val);
- (void)print_encode(h, p[i].val, 1);
- putchar('\"');
+ for (i = 0; i < sz; i++)
+ print_attr(h, htmlattrs[p[i].key], p[i].val);
+
+ /* Add non-overridable attributes. */
+
+ if (TAG_HTML == tag && HTML_XHTML_1_0_STRICT == h->type) {
+ print_attr(h, "xmlns", "http://www.w3.org/1999/xhtml");
+ print_attr(h, "xml:lang", "en");
+ print_attr(h, "lang", "en");
}
+ /* Accomodate for XML "well-formed" singleton escaping. */
+
if (HTML_AUTOCLOSE & htmltags[tag].flags)
switch (h->type) {
case (HTML_XHTML_1_0_STRICT):