blob: 84a684d0dbe19d4b4905682db4e423e520b39e06 [file] [log] [blame]
<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" href="DFDLTutorialStylesheet.xsl"?>
<tdml:testSuite description="A Sample TDML File Illustrating that a HTML Tutorial Page Can Be Directly Created."
suiteName="test tutorial"
xmlns:tdml="http://www.ibm.com/xmlns/dfdl/testData"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:dfdl="http://www.ogf.org/dfdl/dfdl-1.0/"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
xmlns:tns="http://example.com"
xmlns:ex="http://example.com"
xmlns="http://www.w3.org/1999/xhtml">
<tdml:tutorial>
<p>This content is before any of the other content in the TDML file.
</p>
<p>Here is some sample content. Anything XHTML works here.</p>
<p>
DFDL has this <a href='http://opensource.ncsa.illinois.edu/projects/artifacts/DFDL/latest/documentation/Manual/#_Toc398030723'>bitOrder property</a>. Let's talk about that.
Here's a quote from the spec., something I expect many TDML tutorials to want to do so as to highlight specific phrasing or language.
</p>
<blockquote cite='http://opensource.ncsa.illinois.edu/projects/artifacts/DFDL/latest/documentation/Manual/#_Toc398030723'>
The bits of a byte each have a place value or significance of 2
<sup>n</sup>
, for n from 0 to 7.
Hence, the byte value 255 = 2
<sup>7</sup>
+ 2
<sup>6</sup>
+ 2
<sup>5</sup>
+ 2
<sup>4</sup>
+ 2
<sup>3</sup>
+ 2
<sup>2</sup>
+ 2
<sup>1</sup>
+ 2
<sup>0</sup>
.
A bit can always be unambiguously identified as the 2
<sup>n</sup>
-bit.
The bit order is the correspondence of a bit's numeric significance to the bit position (1 to 8) within the byte.
</blockquote>
Now I can think of 36 decimal as a polynomial in any base I want e.g.
<p>
0x
<sup>2 </sup>
+ 3x
<sup>1</sup>
+ 6x
<sup>0</sup>
= 36 if x is 10.
</p>
<p>
equivalently, this polynomial:
</p>
<p>
0x
<sup>7 </sup>
+ 0x
<sup>6 </sup>
+ 1x
<sup>5 </sup>
+ 0x
<sup>4 </sup>
+ 0x
<sup>3 </sup>
+ 1x
<sup>2 </sup>
+ 0x
<sup>1 </sup>
+ 0x
<sup>0</sup>
= 36 when x is 2.
</p>
<p>
Note that the above is only mathematics. No bits have any "positions". They just have their associated mathematical place value that they are being multiplied-by to get a total value.
</p>
<p>
That's enough. Now let's look at the first schema in this demo file. It has nothing whatsoever to do with the above discussion of bit-order.
</p>
</tdml:tutorial>
<tdml:defineSchema name="mySchema">
<dfdl:format ref="tns:daffodilTest1"/>
<xs:element name="data" type="xs:int" dfdl:lengthKind="explicit" dfdl:length="{ xs:unsignedInt(2) }"/>
<xs:element tdml:tutorialInclude="no" name="shouldNotShowInTutorial" type="xs:int" dfdl:inputValueCalc="{ 5 }"/>
</tdml:defineSchema>
<tdml:defineSchema name="shouldNotAppearInTutorial" tdml:tutorialInclude="no">
<dfdl:format ref="tns:daffodilTest1"/>
<xs:element name="shouldNotAppearInTutorial" type="xs:int" dfdl:lengthKind="explicit" dfdl:length="{ xs:unsignedInt(2) }"/>
</tdml:defineSchema>
<tdml:tutorial>
<p>This content is after the first define schema. A schema doesn't have to be first, it just is in this example.</p>
</tdml:tutorial>
<tdml:parserTestCase name="testTutorialElementsParse" root="data" model="mySchema">
<tdml:tutorial>
<p>Start of a parser test case.</p>
</tdml:tutorial>
<tdml:document>37</tdml:document>
<tdml:tutorial>
<p>After the document element of a parser test case. This would be a common place for some diagrams, so here's examples of two ways of doing that.</p>
<p>First we have an image that came from a PNG graphics file drawn somehow. Anything that can create a PNG can work.
Also, commonly web files will have links to images in other files, but what we're doing here is including the image data directly in the XHTML of this
tutorial TDML file.</p>
<img
src=''/>
<p>Next we have an SVG diagram. A great thing about HTML5 is that SVG is part of it, so you can just put diagrams
directly into your HTML.</p>
<svg width="100%" height="80" xmlns="http://www.w3.org/2000/svg" xmlns:svg="http://www.w3.org/2000/svg">
<g>
<title>Layer 1</title>
<rect id="svg_1" height="55" width="87" y="10" x="44" stroke-width="5" stroke="#000000" fill="#FF0000"/>
<rect id="svg_2" height="58" width="131" y="10" x="172" stroke-width="5" stroke="#000000" fill="#FF0000"/>
<rect id="svg_3" height="58" width="96" y="10" x="353" stroke-width="5" stroke="#000000" fill="#FF0000"/>
<rect id="svg_4" height="61" width="103" y="10" x="488" stroke-width="5" stroke="#000000" fill="#FF0000"/>
</g>
</svg>
<p>Well that was fun. Now let's look at the Infoset.</p>
</tdml:tutorial>
<tdml:infoset>
<tdml:dfdlInfoset>
<ex:data>37</ex:data>
</tdml:dfdlInfoset>
</tdml:infoset>
<tdml:tutorial>
<p>After the infoset element of a parser test case we're going to summarize here about the example (parserTestCase) above.</p>
</tdml:tutorial>
</tdml:parserTestCase>
<tdml:tutorial>
<p>This is between the above example, and the next DFDL schema in the tutorial. Here's another DFDL schema. This one will be an unparsing
example.</p>
</tdml:tutorial>
<tdml:defineSchema name="s">
<xs:include schemaLocation="xsd/built-in-formats.xsd"/>
<dfdl:format ref="ex:daffodilTest1"/>
<xs:element name="bar" dfdl:lengthKind="explicit" dfdl:length="5" type="xs:string"/>
</tdml:defineSchema>
<tdml:tutorial>
<p>Ok, that was a pretty dull schema. Now let's look at the example that uses it.</p>
</tdml:tutorial>
<tdml:unparserTestCase name="testTutorialElementsUnparse" root="bar" model="s">
<tdml:tutorial>
<p>At the begining of the unparserTestCase we would explain the infoset we're going to unparse. But we want to show
that we can suppress them if we want. So there should NOT be an infoset below.</p>
</tdml:tutorial>
<tdml:infoset tdml:tutorialInclude="no">
<tdml:dfdlInfoset>
<ex:bar>Hello</ex:bar>
</tdml:dfdlInfoset>
</tdml:infoset>
<tdml:tutorial>
<p>That was NOT a pretty nice little infoset. Now we'll discuss the data we expect to be produced from it by unparsing.</p>
</tdml:tutorial>
<tdml:document>Hello</tdml:document>
<tdml:tutorial>
<p>But enough about data. Let's talk about how cool it is to create tutorials directly from TDML.</p>
</tdml:tutorial>
</tdml:unparserTestCase>
<tdml:tutorial>
<p>After that unparser example (before whatever is next - another schema, another test case/example. In this case we're just going to end here.</p>
</tdml:tutorial>
</tdml:testSuite>