cascade
Libraries to implement a transpect cascade configuration
Git URL | https://github.com/transpect/cascade.git |
SVN URL | https://github.com/transpect/cascade |
Base URI | http://transpect.io/cascade/ |
tr:clades-from-filename-stdout
This step provides the clades of one filename as separated tokens.
Import
<p:import href="http://transpect.io/cascade/xpl/clades-from-filename-stdout.xpl"/>
Dependencies
Synopsis
<tr:clades-from-filename-stdout xmlns:tr="http://transpect.io">
<p:input port="conf"/>
<p:output port="result" sequence="true"/>
<p:option name="filename"/>
<p:option name="separator" select="'
'"/>
<p:option name="get-full-path" select="'no'"/>
<p:option name="order" select="'ascending'"/>
<p:option name="exclude-filter" select="''"/>
<p:option name="debug" select="'yes'"/>
<p:option name="debug-dir-uri" select="'debug'"/>
<p:option name="status-dir-uri" select="'status'"/>
</tr:clades-from-filename-stdout>
tr:directory-loop
The step performs a recursive directory listing and looks for parameter documents named 'params.xml'. The parameter documents are included in the XML directory listing.
Import
<p:import href="http://transpect.io/cascade/xpl/directory-loop.xpl"/>
Dependencies
Synopsis
<tr:directory-loop xmlns:tr="http://transpect.io">
<p:output port="result"/>
<p:option name="depth" select="-1"/>
<p:option name="path" required="true"/>
<p:option name="exclude-filter"/>
</tr:directory-loop>
tr:identity-fallback
Import
<p:import href="http://transpect.io/cascade/xpl/dynamic-transformation-identity-fallback.xpl"/>
Synopsis
<tr:identity-fallback xmlns:tr="http://transpect.io">
<p:input port="source" primary="true"/>
<p:input port="stylesheet"/>
<p:input port="meta"/>
<p:input port="parameters" primary="true"/>
<p:output port="result" primary="true"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri"/>
</tr:identity-fallback>
tr:dynamic-transformation-pipeline
This encapsulates the dynamic loading of an XSLT stylesheet and an XPL pipeline and
execution of the
pipeline. Dynamic loading means that the most specific (specificity tr: work, series,
publisher, common) XSL and XPL
files will be loaded. The pipeline usually consists of transformations with the same
dynamically loaded stylesheet in different
modes, according to the dynamically loaded pipeline (that consists of tr:xslt-mode
steps). The pipeline may have multiple
documents on the source and result ports. The transformation will be applied to each
document in turn.
Additional input files that will be passed to each transformation may be sent
to the additional-input port. They must be
wrapped in cx:document with the appropriate port name of the dynamically executed
pipeline. Even if you don’t have additional
inputs, make sure to always include the additional-inputs port when invoking tr:dynamic-transformation-pipeline.
Connect it to
p:empty by default. Please note the difference between a sequence of source documents
(will be transformed one by one) and a
sequence of additional files (will be available to the dynamically loaded pipeline
and will typically be used as additional
input documents for some of the tr:xslt-mode steps therein, thus making it available
via the default collection in each
transformation).
There is a limitation that additional inputs are limited to single documents per
port. If you have a sequence, you’ll have
to wrap it into a custom element before wrapping it in the cx:document.
There is also an options port. You may submit options in a cx:options document
with cx:option entries (with name and value
attributes). These options will be merged with the debug and debug-dir-uri options
and passed on to the dynamically loaded
pipeline. Before preparing a cx:options document, check whether the options can be
read in the dynamically invoked pipeline
from the primary parameter port.
Import
<p:import href="http://transpect.io/cascade/xpl/dynamic-transformation-pipeline.xpl"/>
Dependencies
Synopsis
<tr:dynamic-transformation-pipeline xmlns:tr="http://transpect.io">
<p:input port="source" sequence="true" primary="true"/>
<p:input port="additional-inputs" sequence="true" primary="false"/>
<p:input port="options" sequence="true"/>
<p:input port="paths" primary="true"/>
<p:output port="report" sequence="true"/>
<p:output port="result" sequence="true" primary="true"/>
<p:option name="load"/>
<p:option name="fallback-xsl" required="false" select="'http://transpect.io/cascade/xsl/dynamic-transformation-identity-fallback.xsl'"/>
<p:option name="fallback-xpl" required="false" select="''"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri" required="false" select="'debug'"/>
</tr:dynamic-transformation-pipeline>
tr:get-clades-from-dirs
This step converts a transpect clades document from the output
of tr:directory-loop
. The clades document can be used
as input for the tr:paths
step.
Parameter sets can be stored as params.xml
in the corresponding
directory. There are predefined parameters which are used to control how the
clades are generated.
<c:param-set xmlns:c="http://www.w3.org/ns/xproc-step">
<c:param name="exclude-filter" value="'(xsl|xpl|schematron)'"/><-- exclude directories from cascade -->
<c:param name="clade-role" value="global"/><-- assign a specific clade role to the directory -->
</c:param-set>
Import
<p:import href="http://transpect.io/cascade/xpl/get-clades-from-dirs.xpl"/>
Dependencies
Synopsis
<tr:get-clades-from-dirs xmlns:tr="http://transpect.io">
<p:input port="params"/>
<p:output port="result" primary="true"/>
<p:output port="directory-param-sets" primary="false"/>
<p:option name="resolve-params" select="'yes'"/>
<p:option name="debug" select="'yes'"/>
<p:option name="debug-dir-uri" select="'debug'"/>
<p:option name="status-dir-uri" select="concat($debug-dir-uri, '/status')"/>
</tr:get-clades-from-dirs>
tr:load-cascaded
Loads the most specific XML file $filename from a sequence of paths, supplied as parameters on the paths port ($s9y1-path, $s9y2-path, …, in descending specificity). The XML file can be an XProc pipeline, an XSLT stylesheet, a Schematron schema, an XHTML file, whatever. If no document named {$filename} is found at a given path, it checks whether {$filename}.xsl exists. If it exist, the main template of this XSL is invoked and this should return the document that was originally expected at {$filename}. If neither a proper {$filename} nor {$filename}.xsl can be found under any of the paths, and if a non-empty option $fallback is specified, the fallback file will be used.
Import
<p:import href="http://transpect.io/cascade/xpl/load-cascaded.xpl"/>
Dependencies
Synopsis
<tr:load-cascaded xmlns:tr="http://transpect.io">
<p:input port="paths" primary="true"/>
<p:input port="source" sequence="true" primary="true"/>
<p:input port="catalog" sequence="true"/>
<p:output port="result" primary="true"/>
<p:option name="filename" required="true"/>
<p:option name="required" required="false" select="'yes'"/>
<p:option name="fallback" required="false" select="''"/>
<p:option name="set-xml-base-attribute" required="false" select="'yes'"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri"/>
</tr:load-cascaded>
tr:load-cascaded-binary
Import
<p:import href="http://transpect.io/cascade/xpl/load-cascaded.xpl"/>
Dependencies
Synopsis
<tr:load-cascaded-binary xmlns:tr="http://transpect.io">
<p:input port="paths" primary="true"/>
<p:output port="result" primary="true"/>
<p:option name="filename" required="true"/>
<p:option name="required" required="false" select="'yes'"/>
<p:option name="fallback" required="false" select="''"/>
<p:option name="result-with-file-prefix" required="false" select="'no'"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri"/>
</tr:load-cascaded-binary>
tr:load-whole-cascade
Loads all documents of a specific name from the path cascade. With the default order of 'least-specific-first', the most generic document will be first, the most specific last. The option 'order' may be set to 'most-specific-first'.
Import
<p:import href="http://transpect.io/cascade/xpl/load-cascaded.xpl"/>
Synopsis
<tr:load-whole-cascade xmlns:tr="http://transpect.io">
<p:input port="paths" primary="true"/>
<p:output port="result" sequence="true" primary="true"/>
<p:option name="filename" required="true"/>
<p:option name="order" select="'least-specific-first'"/>
</tr:load-whole-cascade>
tr:paths-for-files-xml
An implementation of paths-for-files which provides XML output
Import
<p:import href="http://transpect.io/cascade/xpl/paths-for-files-xml.xpl"/>
Dependencies
Synopsis
<tr:paths-for-files-xml xmlns:tr="http://transpect.io">
<p:input port="conf"/>
<p:output port="result"/>
<p:option name="filenames"/>
<p:option name="clades" select="''"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri" required="false" select="resolve-uri('debug')"/>
<p:option name="status-dir-uri" required="false" select="'status?enabled=false'"/>
<p:option name="fail-on-error" select="'false'"/>
</tr:paths-for-files-xml>
tr:paths-for-files
Will calculate the content repository locations for a space separated sequence of flat filenames. The filenames must adhere to the naming conventions, e.g., 101026_04711_RAT.idml or 101027_00123_ADHOC_fig_2-3.pdf.
Import
<p:import href="http://transpect.io/cascade/xpl/paths-for-files.xpl"/>
Dependencies
Synopsis
<tr:paths-for-files xmlns:tr="http://transpect.io">
<p:input port="conf" primary="true"/>
<p:output port="result" primary="true"/>
<p:option name="filenames" required="true"/>
<p:option name="clades" select="''"/>
<p:option name="debug" required="false" select="'no'"/>
<p:option name="debug-dir-uri" required="false" select="resolve-uri('debug')"/>
<p:option name="status-dir-uri" required="false" select="'status?enabled=false'"/>
<p:option name="fail-on-error" select="'false'"/>
</tr:paths-for-files>
tr:paths
This step provides the transpect cascade paths document for a given filename.
The filename is passed with the file
option.
The step takes two inputs. First, the step expects a transpect clades
configuration. Clades are a hierarchical structure of configuration layers.
These layers are typically represented as directories on the filesystem, where
transpect steps search for overrides. Second, the step takes an XSLT stylesheet. The
stylesheet imports the paths.xsl
and is used to override some of its functions, especially for
detecting clades based upon file names or other strings.
A RelaxNG schema for the clades configuration is here: ../schema/cascade.rng
.
Import
<p:import href="http://transpect.io/cascade/xpl/paths.xpl"/>
Dependencies
Synopsis
<tr:paths xmlns:tr="http://transpect.io">
<p:input port="conf"/>
<p:input port="stylesheet" primary="true"/>
<p:input port="params" sequence="true"/>
<p:output port="result" primary="true"/>
<p:output port="report" sequence="true" primary="false"/>
<p:option name="debug" select="'no'"/>
<p:option name="debug-dir-uri" select="'debug'"/>
<p:option name="status-dir-uri" select="'status?enabled=false'"/>
<p:option name="interface-language" select="'en'"/>
<p:option name="clades" select="''"/>
<p:option name="file" required="true"/>
<p:option name="pipeline" select="'unknown'"/>
<p:option name="progress" select="'no'"/>
<p:option name="progress-to-stdout" required="false" select="'no'"/>
<p:option name="determine-transpect-project-version" required="false" select="'no'"/>
</tr:paths>
GitHub sync date: 2025-01-08+01:00