]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blob - doc/bugs/HTML_inlined_into_Atom_not_necessarily_well-formed.mdwn
7ba95fb4b116788469e6fb049788f05884f51706
[git.ikiwiki.info.git] / doc / bugs / HTML_inlined_into_Atom_not_necessarily_well-formed.mdwn
1 If a blog entry contains a HTML named entity, such as the `—` produced by [[plugins/rst]] for blockquote citations, it's pasted into the Atom feed as-is. However, Atom feeds don't have a DTD, so named entities beyond `<`, `>`, `"`, `&` and `'` aren't well-formed XML.
3 Possible solutions:
5 * Put HTML in Atom feeds as type="html" (and use ESCAPE=HTML) instead
7 > Are there any particular downsides to doing that ..? --[[Joey]]
9 >> It's the usual XHTML/HTML distinction. type="html" will always be interpreted as "tag soup", I believe - this may lead to it being rendered differently in some browsers. In general ikiwiki seems to claim to produce XHTML (at least, the default page.tmpl makes it claim to be XHTML Strict). On the other hand, this is a much simpler solution... see escape-feed-html branch in my repository, which I'm now using instead --[[smcv]]
11 * Keep HTML in Atom feeds as type="xhtml", but replace named entities with numeric ones,
12   like in the re-escape-entities branch in my repository ([diff here](http://git.debian.org/?p=users/smcv/ikiwiki.git;a=commitdiff;h=c0eb041c65d0653bacf0d4acb7a602e9bda8888e))
14 >> I can see why you think this is excessively complex! --[[smcv]]
16 (Also, the HTML in RSS feeds would probably get better interoperability if it was escaped with ESCAPE=HTML rather than being in a CDATA section?)
18 > Can't see why? --[[Joey]]
20 >> For a start, `]]>` in content wouldn't break the feed :-) but I was really thinking of non-XML, non-SGML parsers (more tag soup) that don't understand CDATA (I've suffered from CDATA damage when feeding generated code through gtkdoc, for instance). --[[smcv]]