blob: 3a7cfae61247cc1fb22c949f4368b33a5279ce42 (
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
|
This example shows how to parse XML vocabularies with multiple root
elements using the Embedded C++/Hybrid mapping.
The example consists of the following files:
protocol.xsd
XML Schema which defines a simple bank account protocol with
requests such as withdraw and deposit.
balance.xml
withdraw.xml
deposit.xml
Sample XML instances for the protocol requests.
protocol.hxx
protocol.cxx
protocol-pskel.hxx
protocol-pskel.cxx
protocol-pimpl.hxx
protocol-pimpl.cxx
Object model (the first pair of files), parser skeletons (the
second pair) and parser implementations (the third pair). These
files are generated by the XSD/e compiler from protocol.xsd. The
--generate-parser and --generate-aggregate options were used to
request the generation of the parsing code.
driver.cxx
Driver for the example. It implements a custom document parser
that determines which request is being parsed and uses the
corresponding parser implementation. The document parser
intentionally does not support the deposit request to show how
to handle unknown documents. The driver first calls the parser
that constructs the object model from the input XML file. It
then prints the content of the object model to STDERR.
To run the example on the sample XML request documents simply
execute:
$ ./driver balance.xml
$ ./driver withdraw.xml
$ ./driver deposit.xml
The example reads from STDIN if input file is not specified:
$ ./driver <balance.xml
$ ./driver <withdraw.xml
$ ./driver <deposit.xml
|