blob: 23ace6f75a1ec92aceb84198b2c8342c8e783359 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
This example shows how to handle raw, "type-less content" such as
mixed content models, anyType/anySimpleType, and any/anyAttribute
in the C++/Parser mapping.
In this example we use mixed content model to describe text
with embedded links, e.g.,
This paragraph talks about <a href="uri">time</a>.
The example transforms such text into plain text with
references, e.g.,
This paragraph talks about time[0].
[0] uri
The example consists of the following files:
text.xsd
XML Schema which describes "text with links" instance
documents.
text.xml
Sample XML instance document.
anchor.hxx
Anchor type that captures the information about a link.
text.map
Type map. It maps XML Schema anchor types defined in
text.xsd to C++ anchor class defined in anchor.hxx.
text-pskel.hxx
text-pskel.cxx
Parser skeletons generated by XSD from text.xsd and
text.map.
driver.cxx
A parser implementation and a driver for the example. The
parser implementation prints the transformed text to STDOUT.
The driver first constructs a parser instance from the parser
implementation mentioned above and a couple of predefined
parsers for the XML Schema built-in types. In then invokes
this parser instance to parse the input file.
To run the example on the sample XML instance document simply
execute:
$ ./driver text.xml
|