Software und Dokumentation werden unter den Regeln der GNU LGPL LIzenz unter Ausschluss jeglicher Garantien und Gewährleistungen veröffentlicht.
2008-03-03
Table of Contents
yax ist eine Java Implementiierung der XProc Spezifikation, einer XML Pipeline Sprache (XProc: An XML Pipeline Language W3C Working Draft 17 November 2006), mit der XProc Skripte wie das folgende verarbeitet werden können.
<?xml version="1.0" encoding="UTF-8"?> <xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT" yax:description="transforms 'a*' elements to 'b*' elmenents."> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="trans2" type="xproc:XSLT" yax:description="transforms 'b*' elements to 'c*' elmenents."> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> <xproc:parameter name="transformer" value="Saxon6" /> </xproc:step> <xproc:step name="trans3" type="xproc:XSLT" yax:description="transforms 'c*' elements to 'd*' elmenents."> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> <xproc:parameter name="transformer" value="XSLTC" /> </xproc:step> </xproc:pipeline>
Folgende Software muss verfügbar (installiert) sein:
Graphviz - Graph Visualization Software,
if want to use the visualisation features (pipeline trace, port trace).
further XSLT processors ( like saxon, xalan et al),
if you want to use other processor(s) than the one (XSLTC), which comes with java.
Laden Sie yax http://yax.sourceforge.net (hier der Menüpunkt 'download') herunter und entpacken Sie die Datei in ein beliebiges <yax-installation-directory>.
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax examples/example1.xproc examples/example1.xml
default transformer is set to system transformer. automaticOutput of pipe trace is set to 'yes'. automaticOutput of port trace is set to 'yes'. suppress of process is set to 'no'. step 'trans1': transformer Apache Software Foundation (Xalan XSLTC)(Version 1.0) is used. step 'trans2': transformer Apache Software Foundation (Xalan XSLTC)(Version 1.0) is used. step 'trans3': transformer Apache Software Foundation (Xalan XSLTC)(Version 1.0) is used. Yax run sucessful completed.
2) <pipeline filename>.config.xml
<yax:configuration xmlns:yax="http://www.opsdesign.eu/yax/1.0"> <!--configuration description generated by Yax - Do not edit by hand--> <pipeline name="pipe1"> .. <step name="trans1"> <output port="out" sequence="no" yax:creator="implementation.xproc.standard"/> <input port="in" sequence="no" yax:creator="implementation.xproc.standard"> <yax:connection port="in" yax:component="pipe1"/> </input> <input port="stylesheet" sequence="no" yax:creator="implementation.xproc.standard"/> <input href="examples/transformation1.xsl" port="stylesheet" yax:creator="pipeline"/> </step> ... </pipeline> <xproc:pipeline-library name="xproc.options" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0"> <xproc:declare-step-type type="Rename" yax:description=""> <xproc:output port="out" select="" sequence="no" yax:bySourceRequired="no"/> <xproc:input port="in" select="" sequence="no" yax:bySourceRequired="no"/> <xproc:parameter name="name" required="yes" yax:values="{$any}"/> <xproc:parameter name="select" required="yes" yax:values="{$xpathExpression}"/> </xproc:declare-step-type> ... </xproc:pipeline-library> <xproc:pipeline-library name="xproc.standard" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0"> ... </xproc:pipeline-library> <xproc:pipeline-library name="yax.standard" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0"> ... </xproc:pipeline-library> </yax:configuration>
3) <pipeline filename>.pipeTrace.png
4) <pipeline filename>.portTrace.png
Der Kerngedanke von yax ...ToDo
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="validate1" type="xproc:Validate"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> <xproc:step name="validate2" type="xproc:Validate"/> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> <xproc:choose name="choose1"> <xproc:when name="choose1when1"> <xproc:step name="trans3.1.1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> <xproc:step name="trans3.1.2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:when> <xproc:when name="choose1when2"> <xproc:step name="trans3.2.1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> <xproc:step name="trans3.2.2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:when> <xproc:otherwise name="choose1otherwise"> <xproc:step name="trans3.9.1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> <xproc:step name="trans3.9.2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:otherwise> </xproc:choose> <xproc:step name="trans4" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation4.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> <xproc:step name="store1" type="xproc:Store"/> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation4.xsl"/> </xproc:step> <xproc:step name="trans4" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation4.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> <xproc:step name="load1" type="xproc:Load"/> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation4.xsl"/> </xproc:step> <xproc:step name="trans4" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation4.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1"
xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0"
xmlns:yax="http://opsdesign.eu/yax/1.0">
<xproc:step name="trans1" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation1.xsl"/>
</xproc:step>
<xproc:step name="trans2" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation2.xsl"/>
</xproc:step>
<xproc:step name="load1" type="xproc:Load"/>
<xproc:step name="trans3" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation4.xsl"/>
</xproc:step>
<xproc:step name="trans4" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation4.xsl"/>
<xproc:input port="in" step="trans2" source="out"/>
</xproc:step>
</xproc:pipeline>
offene Punkte zur Spezifikation
Associating Documents with Ports / Specified by source
<p:step name="expand" type="p:xinclude"> <p:input port="document" step="otherstep" source="result"/> </p:step>
should become something like (better with a more handsome term for 'component'):
<p:step name="expand" type="p:xinclude">
<p:input port="document" component="otherComponent" source="result"/>
</p:step>
context of choose/when/otherwise
the context should also be provided by a (e.g. reference) port.
are there important reasons to differenciate between steps and constructs?
Should a 'declare-construct-type' exists?
One can define custom 'step's. So should one also be able to define constructs.
what expression language(s) (el) should be used in XProc scripts?
Folgende Software muss an einem frei wählbaren Ort verfügbar (installiert) sein:
Table 3. Notwendige Packages
Package |
Nutzung |
---|---|
Java (Version 5 or above) |
Since Version 1.4 Java contains a default transformation processor (XSLTC). This processor will be used if no other processors are visible (in the classpath). yax assumes the presence of this processor. So at least Java 1.4 is necessary for using yax. As yas is developed under Java 5 it is the recommended Java version. |
Ant(Version 1.7.0 or above) |
yax comes with an ant task, so you can use yax also under ant. An ant installation is only needed if you want to use the yax ant task. |
Log4j(Version 1.2.14 or above) |
log4j is the recommended logging system. If log4j is not installed (resp. not reachable) yax uses its own ConsoleLogger. If you yax only under ant from yax perspective a log4j installation is not necessary because all log messages will be redirected to the ant logger. |
Saxon(xls1: Version 6.5.3 or above, xls2: Version 8.6. or above) |
yax provides the usage of different XSL processors. The saxon processors builds the preferred test environment for the yax development. (Obviously you can use any xsl processor which is reachable vie JAXP). The preferences file still includes the Saxon processors. If you want to use it follow Saxonias instruction how to obtain and install them. If no xsl processor is installed yax uses the system default transformer which comes with JRE (XSLTC). |
Xalan /(XSLTC)(Version 2.7.0 or above) |
yax provides the usage of different XSL processors. Xalan comes from Apache. The preferences file still includes the Xalan and the XSLTC processor. If you want to use them follow Apaches instruction how to obtain and install them. If no xsl processor is installed yax uses the system default transformer which comes with JRE (XSLTC). |
Laden Sie yax http://yax.sourceforge.net (hier der Menüpunkt 'download') herunter und entpacken Sie die Datei in ein beliebiges <yax-installation-directory>.
Feel free to place yax-*.jar files somewhere in your system and make it/them accessable by the right classpath entry. But at least keep a copy of the main jar file within the <yax-installation-directory>/lib for retrieving the implemented components. The minimal installation can be:
<yax-installation-directory>/lib
|
+--- lib
|
+--- yax-<n.m>.jar (<n.m> = Version Number)
An XML catalog maps (usually remote) URIs to other (usually local) URIs.
yax uses Norman Walsh's resolver. You can configure the resolver - especially the link to your catalog file - by editing the config/CatalogManager.properties file. How to configure the the resolver is explained in an excellent manner on the resolver's site
For your confinience the yax distribution contains the recent resolver library (lib/resolver.jar). If you want to use the xml catalog feature the config directory and the resolver.jar have to be part of your the classpath. Start yax with the '-noCatalog' option If you want to suppress the xml catalog usage.
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax -Dexample.dir=examples -Dtest.dir=test -DoutputFilename=output1.xml example1.xproc
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="Load1" type="xproc:Load" href="${examples.dir}/${inputFilename}"/> <xproc:step name="Store1" type="xproc:Store" href="${test.dir}/${outputFilename}"/> </xproc:pipeline>
All I/O effects by start parameters (or other interface input) is called outer I/O.
java -classpath lib/yax-0.8.jar net.sf.yax.Yax examples/example1.xproc examples/example1.xml
path/to/input/resource/inputname.xml
derived from that input location yax generates the output location:
path/to/input/resource/inputname.output.xml
java -classpath lib/yax-0.8.jar net.sf.yax.Yax examples/example1.xproc input/inputname.xml output/outputname.xml
... <target name="pipeline1" description="uses different multiple input files" > <yax verbose="yes" script="test/pipeline00.xproc" outDir="test" outPattern="${inputName}.out.${inputExtension}" > <fileset dir="examples" includes=" example*.xml " excludes=" example2.xml " /> </yax> </target> ...
java -classpath lib/yax-0.8.jar net.sf.yax.Yax examples/example1.xproc -inList={input/inputname1.xml;input/inputname1.xml} outDir=test outPattern="${inputName}.out.${inputExtension}
Assuming you are using the pattern:
outPattern="${inputName}.out.${inputExtension}
and you are processing the input files example1.xml and example3.xml by using ant's fileset
... <fileset dir="examples" includes=" example*.xml " excludes=" example2.xml " /> ...
yax will created the two file:
... examples | +-- example1.out.xml example2.out.xml
... outDir="test" outPattern="${inputName}.out.${inputExtension}" ...
yax writes the two files to the 'test' directory:
... test | +-- example1.out.xml example2.out.xml
... <target name="runExample5.1" description="uses inner and outer I/O" > <yax script="examples/example5.xproc" > ... </yax> </target> ...
You will get two times the same output in different files:
... INFO [Load:Load1] Reading input file '...\examples\xincludeArticle.xml' into Context '2'. ... INFO [Store:Store1] Writing output file '...\test\example5.output.cmd.xml' from Context '2'. ... INFO [root:yax.root] Writing output file '...\yaxOutput.xml' from Context '2'. ...
The p:Store step creates a side branch but yax ports the content through the hole pipeline to the root container which is manages the outer I/O.
To avoid such undesired output behaviour (assuming in this case the outer output is undesired) you can use the -noOutputfile parameter:
...
<target
name="runExample5.2"
description="uses only inner I/O"
>
<yax
noOutputfile="yes"
script="examples/example5.xproc"
>
...
</yax>
</target>
...
In this case the content on the output port of root will be discarded.
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax [options]pipeline file location [XML input data file location [XML output data file location]]
element 'yax:transformers' has ...something about transformer preference ... step 'step name': something about transformer which will be used ... messages from each step ... Yax run sucessful completed.
Usage: java yax [options] pipelineURI [inputfileURI [outputfileURI]] Options: -h, -help print this message (and exit) -version print version information (and exit) -quiet, -q be extra quiet -verbose, -v be extra verbose (quiet takes precedence) -debug, -d print debugging information -baseURI=<value> set the baseURI to value -noOutputfile suppress generation of an outputfile (overrides all other output parameters) (make sense if output is created within the pipeline) -D<property>=<value> provide property for using within the xproc script as '${property}' -propertyfile <name> load properties from file (-D<property>s take precedence) (for further usage alternatives see http://yax.sourceforge.net/)
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:step name="validate1" type="xproc:Validate"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> <xproc:step name="validate2" type="xproc:Validate"/> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> </xproc:pipeline>
... Construct 'pipe1' is empty and will be bridged. ...
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:pipeline name="pipe1.1"> <xproc:step name="step1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation1.xsl"/> </xproc:step> <xproc:pipeline name="pipe1.1.1"> <xproc:step name="step1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation2.xsl"/> </xproc:step> <xproc:pipeline name="pipe1.1.1.1"> <xproc:step name="step1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation3.xsl"/> </xproc:step> </xproc:pipeline> </xproc:pipeline> </xproc:pipeline> </xproc:pipeline>
<xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step>
<xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> <xproc:parameter name="transformer" value="Saxon8"/> </xproc:step>
... <xproc:step name="Load1" type="xproc:Load" href="examples/example1.xml"/> ...
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax [options]pipeline file location
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax -Dexample.dir=examples -Dtest.dir=test -DoutputFilename=output1.xml example1.xproc
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="Load1" type="xproc:Load" href="${examples.dir}/${inputFilename}"/> <xproc:step name="Store1" type="xproc:Store" href="${test.dir}/${outputFilename}"/> </xproc:pipeline>
... <xproc:step name="Store1" type="xproc:Store" href="examples/output.xml"/> ...
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax [options]pipeline file location
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax -Dexample.dir=examples -Dtest.dir=test -DoutputFilename=output1.xml example1.xproc
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="Load1" type="xproc:Load" href="${examples.dir}/${inputFilename}"/> <xproc:step name="Store1" type="xproc:Store" href="${test.dir}/${outputFilename}"/> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:choose name="choose1" type="xproc:XSLT"> <xproc:input port="ref" href="test/chooseInput0.xml"/> <xproc:when name="when1" test="/test1"> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:when name="when2" test="/test2"> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:otherwise name="otherwise"> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:otherwise> </xproc:choose> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:choose name="choose1" type="xproc:XSLT"> <xproc:when name="when1" test="/test1"> <xproc:input port="ref" href="test/chooseInput1.xml"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:when name="when2" test="/test2"> <xproc:input port="ref" href="test/chooseInput2.xml"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:otherwise name="otherwise"> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:otherwise> </xproc:choose> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1"
xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0"
xmlns:yax="http://opsdesign.eu/yax/1.0">
<xproc:step name="trans1" type="xproc:XSLT">
</xproc:step>
<xproc:choose name="choose1" type="xproc:XSLT">
<xproc:input port="ref" href="test/chooseInput0.xml"/>
<xproc:when name="when1" test="/test1">
<xproc:step name="trans2" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation2.xsl"/>
</xproc:step>
</xproc:when>
<xproc:when name="when2" test="/test2">
<xproc:step name="trans2" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation2.xsl"/>
</xproc:step>
</xproc:when>
<xproc:otherwise name="otherwise">
<xproc:step name="trans2" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation2.xsl"/>
</xproc:step>
</xproc:otherwise>
</xproc:choose>
<xproc:step name="trans3" type="xproc:XSLT">
<xproc:input port="stylesheet" href="test/transformation3.xsl"/>
</xproc:step>
</xproc:pipeline>
construct 'when1': reference port not found.
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:step name="trans1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation1.xsl"/> </xproc:step> <xproc:choose name="choose1" type="xproc:XSLT"> <xproc:input port="ref" href="test/chooseInput0.xml"/> <xproc:when name="when1" test="/test1"> <xproc:input port="ref" href="test/chooseInput1.xml"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:when name="when2" test="/test2"> <xproc:input port="ref" href="test/chooseInput2.xml"/> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:when> <xproc:otherwise name="otherwise"> <xproc:step name="trans2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation2.xsl"/> </xproc:step> </xproc:otherwise> </xproc:choose> <xproc:step name="trans3" type="xproc:XSLT"> <xproc:input port="stylesheet" href="test/transformation3.xsl"/> </xproc:step> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:try name="try1"> <xproc:group name="group1"> <xproc:step name="group1step1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation2.xsl"/> </xproc:step> </xproc:group> <xproc:catch name="catch"> <xproc:step name="catchstep2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation1.xsl"/> </xproc:step> </xproc:catch> </xproc:try> </xproc:pipeline>
<xproc:pipeline name="pipe1" xmlns:xproc="http://www.w3.org/TR/2006/xproc/1.0" xmlns:yax="http://opsdesign.eu/yax/1.0"> <xproc:try name="try1"> <xproc:group name="group1"> <xproc:step name="group1step1" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation2.xsl"/> </xproc:step> </xproc:group> <xproc:catch name="catch1" exception="EmptyResult"> <xproc:step name="catch1step2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation1.xsl"/> </xproc:step> </xproc:catch> <xproc:catch name="catch2" exception="FileNotFound"> <xproc:step name="catch2step2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation1.xsl"/> </xproc:step> </xproc:catch> <xproc:catch name="catch"> <xproc:step name="catchstep2" type="xproc:XSLT"> <xproc:input port="stylesheet" href="examples/transformation1.xsl"/> </xproc:step> </xproc:catch> </xproc:try> </xproc:pipeline>
This is an example with real data coming from the docbook.sml project. It collects all sections distributed over several files into the output file. Start yax with:
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax -Dparam1=passedFromProgramStart example7.xproc examples/xincludeArticle.xml test/output1.xml
# java -classpath lib/yax-0.7.jar net.sf.yax.Yax -Dparam1=passedFromProgramStart example6.xproc examples/example1.xml test/output1.xml
The output file test/output1.xml will consist of:
<?xml version="1.0" encoding="UTF-8"?> <result> <param1>passedFromProgramStart</param1> <param2>${param2}</param2> <param3>notPassedToScript</param3> </result>
Software und Dokumenation wird unter den Bedingungen der GNU LGPL Lizenz (see http://www.gnu.org/copyleft/lesser.html) unter Ausschluss jeglicher Garantien und Gewährleistungen veröffentlicht.
Copyright © 2006 - 2008 joerg.moebius@opsdesign.de