summaryrefslogtreecommitdiff
path: root/xsd-examples/cxx/parser/polymorphism
diff options
context:
space:
mode:
Diffstat (limited to 'xsd-examples/cxx/parser/polymorphism')
-rw-r--r--xsd-examples/cxx/parser/polymorphism/README26
-rw-r--r--xsd-examples/cxx/parser/polymorphism/buildfile4
2 files changed, 24 insertions, 6 deletions
diff --git a/xsd-examples/cxx/parser/polymorphism/README b/xsd-examples/cxx/parser/polymorphism/README
index 60a97e9..a25464e 100644
--- a/xsd-examples/cxx/parser/polymorphism/README
+++ b/xsd-examples/cxx/parser/polymorphism/README
@@ -13,7 +13,15 @@ supermen.xml
supermen-pskel.hxx
supermen-pskel.cxx
- Parser skeletons generated by the XSD compiler from supermen.xsd.
+ Parser skeletons generated by the XSD compiler from supermen.xsd using
+ the following command line:
+
+ xsd cxx-parser --generate-polymorphic supermen.xsd
+
+ Or if using Expat instead of Xerces-C++ as the underlying XML parser:
+
+ xsd cxx-parser --xml-parser=expat --generate-polymorphic supermen.xsd
+
Note the use of the --generate-polymorphic command line option.
supermen-pimpl.hxx
@@ -25,6 +33,18 @@ driver.cxx
all the individual parsers found in supermen-pimpl.hxx. It then invokes
this parser instance to parse the input file.
-To run the example on the sample XML instance document simply execute:
+To compile and link the example manually from the command line we can use
+the following commands (replace 'c++' with your C++ compiler name):
+
+c++ -c supermen-pskel.cxx
+c++ -c supermen-pimpl.cxx
+c++ -c driver.cxx
+c++ -o driver driver.o supermen-pskel.o supermen-pimpl.o -lxerces-c
+
+Or if using Expat as the underlying XML parser:
+
+c++ -o driver driver.o supermen-pskel.o supermen-pimpl.o -lexpat
+
+To run the example on the sample XML instance document execute:
-$ ./driver supermen.xml
+./driver supermen.xml
diff --git a/xsd-examples/cxx/parser/polymorphism/buildfile b/xsd-examples/cxx/parser/polymorphism/buildfile
index de088cf..2fad7dd 100644
--- a/xsd-examples/cxx/parser/polymorphism/buildfile
+++ b/xsd-examples/cxx/parser/polymorphism/buildfile
@@ -12,9 +12,7 @@ exe{driver}: xml{supermen}: test.input = true
<{hxx ixx cxx}{supermen-pskel}>: xsd{supermen} $xsd
{{
- diag xsd ($<[0]) # @@ TMP
-
- $xsd cxx-parser --std c++11 \
+ $xsd cxx-parser \
--generate-inline \
--skel-file-suffix -pskel \
--generate-polymorphic \