471,082 Members | 995 Online
Bytes | Software Development & Data Engineering Community
Post +

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 471,082 software developers and data experts.

MathML weirdness

I'm experimenting with MathML, and have run into difficulty.

Given the simple XML:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE component SYSTEM "mathml2.dtd">
<mathDisplay>
<math>
<msub>
<mi>z</mi>
<mn>2</mn>
</msub>
</math>
</mathDisplay>
and the simple XSLT stylesheet given below, I expect the output
<?xml version="1.0" encoding="utf-8"?>
<mathML><xmathDisplay><xmath><xmsub><xmi>z</xmi>
<xmn>2</xmn></xmsub></xmath></xmathDisplay></mathML>
Instead, I get
<?xml version="1.0" encoding="utf-8"?>
<mathML><xmathDisplay>z2</xmathDisplay></mathML>
I get the results I expect if I delete the DOCTYPE line from the xml
file.

I can also get the results I expect if I change the names of the MathML
elements to, say, <a>, <b>, <c>, ...

In what way is the behavior of an XSLT stylesheet dependent upon the
details
of an XML document's doctype?

Thanks!

The spreadsheet:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
version="1.0">
<xsl:strip-space elements="*"/>
<xsl:output method="xml" encoding="utf-8"/>
<xsl:template match="/">
<mathML>
<xsl:apply-templates/>
</mathML>
</xsl:template>
<xsl:template match="mathDisplay">
<xmathDisplay>
<xsl:apply-templates/>
</xmathDisplay>
</xsl:template>
<xsl:template match="math">
<xmath>
<xsl:apply-templates/>
</xmath>
</xsl:template>
<xsl:template match="msub">
<xmsub>
<xsl:apply-templates/>
</xmsub>
</xsl:template>
<xsl:template match="mi">
<xmi>
<xsl:apply-templates/>
</xmi>
</xsl:template>
<xsl:template match="mn">
<xmn>
<xsl:apply-templates/>
</xmn>
</xsl:template>
</xsl:stylesheet>

May 17 '06 #1
3 1292
Try it without specifying the DTD. If that produces the right output,
check whether the MathML DTD is automatically setting default namespaces
for those elements. If so, your stylesheet has to be made namespace-aware.

May 17 '06 #2
Adding xmlns:m="http://www.w3.org/1998/Math/MathML" to xsl:stylesheet
and prefixing all the MathML element names in the xsl:templates with
"m:" worked. Thanks!

I don't quite understand why it's necessary to specify the namespace if
one isn't going to be using the prefixed form of the element names in
the XML documents ... nor does a quick scan of Kay's book help. Could
you point me to an explanation of this phenomenon?

Thanks again,
Fred

May 17 '06 #3
Fred wrote:
I don't quite understand why it's necessary to specify the namespace if
one isn't going to be using the prefixed form of the element names in
the XML documents


The meaningful thing isn't the prefix, or lack of one -- it's whether
the element and/or attribute is bound to a namespace. In your case, the
DTD is indeed asserting such a binding, via a default namespace
declaration (xmlns=).

XPath, and XSLT, are always namespace-aware. This means all element and
attribute names they refer to have to be in the correct namespace, or
they won't match. Since XPath 1.0 has no concept of default namespaces
in its own syntax, that means that the only way to refer to namespaced
names is to use a prefix bound to the correct namespace.

Don't confuse syntax and semantics. Prefixes are syntax. Namespaces are
the semantic they represent.
May 17 '06 #4

This discussion thread is closed

Replies have been disabled for this discussion.

Similar topics

2 posts views Thread by Joachim Spoerhase | last post: by
2 posts views Thread by Florian Huber | last post: by
2 posts views Thread by Jon Thackray | last post: by
4 posts views Thread by Jon Thackray | last post: by
1 post views Thread by Stefan Behnel | last post: by
3 posts views Thread by Michel de Becdelièvre | last post: by
3 posts views Thread by BakedBean | last post: by

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.