X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/5f92f5a341c58a30c0a5c0d64ba3ed498bb9db85..1f8cf8e0244045ed2b2a8efcff5d6db967ac2b11:/librarian/embeds/mathml.py?ds=sidebyside diff --git a/librarian/embeds/mathml.py b/librarian/embeds/mathml.py index f99f979..564a9f4 100644 --- a/librarian/embeds/mathml.py +++ b/librarian/embeds/mathml.py @@ -1,10 +1,26 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + from lxml import etree +import six from librarian import get_resource -from . import TreeEmbed, create_embed, downgrades_to, converts_to +from . import TreeEmbed, create_embed, downgrades_to + class MathML(TreeEmbed): @downgrades_to('application/x-latex') def to_latex(self): + """ + >>> print(MathML(etree.fromstring('a < b')).to_latex().data.strip()) + a < b + + >>> print(MathML(etree.fromstring('< & &lt; A')).to_latex().data.strip()) + < & < A + + """ xslt = etree.parse(get_resource('res/embeds/mathml/mathml2latex.xslt')) output = self.tree.xslt(xslt) - return create_embed('application/x-latex', data=unicode(output)) + text = six.text_type(output) + # Workaround for entities being preserved in output. But there should be a better way. + text = text.replace('<', '<').replace('&', '&') + return create_embed('application/x-latex', data=text)