Basic Schematron Quick Fix Operations
There are four basic operations that can be executed in a Schematron Quick Fix: Add, Delete, Replace, and String Replace.
- Add
-
The
<sqf:add>
element allows you to add a node to the instance. An anchor node is required to select the position for the new node. The anchor node can be selected by thematch
attribute. Otherwise, it is selected by thecontext
attribute of the rule.The
target
attribute defines the name of the node to be added. It is required if the value of thenode-type
attribute is set to anything other than "comment".The
<sqf:add>
element has aposition
attribute and it determines the position relative to the anchor node. The new node could be specified as the first child of the anchor node, the last child of the anchor node, before the anchor node, or after the anchor node (first-child
is the default value). If you want to add an attribute to the anchor node, do not use theposition
attribute.Note
If you insert an element and its content is empty, Oxygen XML Author will insert the required element content.An Example of the
<sqf:add>
Element:<schema xmlns="http://purl.oclc.org/dsdl/schematron" xmlns:sqf="http://www.schematron-quickfix.com/validator/process" queryBinding="xslt2"> <pattern> <rule context="head"> <assert test="title" sqf:fix="addTitle">title element missing.</assert> <sqf:fix id="addTitle"> <sqf:description> <sqf:title>Insert title element.</sqf:title> </sqf:description> <sqf:add target="title" node-type="element">Title text</sqf:add> </sqf:fix> </rule> </pattern> </schema>
- Insert Element - To insert an element, use the
<sqf:add>
element, set the value of thenode-type
to "element", and specify the element QName with thetarget
attribute. If the element has a prefix, it must be defined in the Schematron using a namespace declaration (<ns uri="namespace" prefix="prefix"/>
). - Insert Attribute - To insert an attribute, use the
<sqf:add>
element, set the value of thenode-type
to "attribute", and specify the attribute QName with thetarget
attribute. If the attribute has a prefix, it must be defined in the Schematron using a namespace declaration (<ns uri="namespace" prefix="prefix"/>
). - Insert Fragment - If the
node-type
is not specified, the<sqf:add>
element will insert an XML fragment. The XML fragment must be well formed. You can specify the fragment in theadd
element or by using theselect
attribute. - Insert Comment - To insert a comment, use the
<sqf:add>
element and set the value of thenode-type
to "comment". - Insert Processing Instruction - To insert a processing instruction, use the
<sqf:add>
element, set the value of thenode-type
to "pi" or "processing-instruction", and specify the name of the processing instruction in thetarget
attribute.
- Insert Element - To insert an element, use the
- Delete
- The
<sqf:delete>
element allows you to remove any type of node (such as elements, attributes, text, comments, or processing instructions). To specify nodes for deletion the<sqf:delete>
element can include amatch
attribute that is an XPath expression (the default value is.
). If thematch
attribute is not included, it deletes the context node of the Schematron rule.An Example of the
<sqf:delete>
Element:<schema xmlns="http://purl.oclc.org/dsdl/schematron" queryBinding="xslt2" xmlns:sqf="http://www.schematron-quickfix.com/validator/process"> <pattern> <rule context="*[@xml:lang]"> <report test="@xml:lang" sqf:fix="remove_lang"> The attribute "xml:lang" is forbidden.</report> <sqf:fix id="remove_lang"> <sqf:description> <sqf:title>Remove "xml:lang" attribute</sqf:title> </sqf:description> <sqf:delete match="@xml:lang"/> </sqf:fix> </rule> </pattern> </schema>
- Replace
- The
<sqf:replace>
element allows you to replace nodes. Similar to the<sqf:delete>
element, it can include amatch
attribute. Otherwise, it replaces the context node of the rule. The<sqf:replace>
element has three tasks. It identifies the nodes to be replaced, defines the replacing nodes, and defines their content.An Example of the
<sqf:replace>
Element:<schema xmlns="http://purl.oclc.org/dsdl/schematron" xmlns:sqf="http://www.schematron-quickfix.com/validator/process" queryBinding="xslt2"> <pattern> <rule context="title"> <report test="exists(ph)" sqf:fix="resolvePh" role="warn"> ph element is not allowed in title.</report> <sqf:fix id="resolvePh"> <sqf:description> <sqf:title>Change the ph element into text</sqf:title> </sqf:description> <sqf:replace match="ph"> <value-of select="."/> </sqf:replace> </sqf:fix> </rule> </pattern> </schema>
Other Attributes for Replace Operations:
node-type
- Determines the type of the replacing node. The permitted values include:keep
- Keeps the node type of the node to be replaced.element
- Replaces the node with an element.attribute
- Replaces the node with an attribute.pi
- Replaces the node with a processing instruction.comment
- Replaces the node with a comment.
target
- By using a QName it gives the replacing node a name. This is necessary when the value of thenode-type
attribute is anything other than "comment".select
- Allows you to choose the content of the replacing nodes. You can use XPath expressions with theselect
attribute. If theselect
attribute is not specified then the content of the<sqf:replace>
element is used instead.
- String Replace
- The
<sqf:stringReplace>
element is different from the others. It can be used to find a sub-string of text content and replace it with nodes or other strings.Attributes for the String Replace Operation:
match
- Allows you to select text nodes that contain the sub-strings you want to replace.select
- Allows you to select the replacing fragment, in case you do not want to set it in the content of thestringReplace
element.regex
- Matches the sub-strings using a regular expression.Note
Consider the following information about using regular expressions in thestringReplace
element:- The regular expressions from this operation are compiled as Java regular expressions. For more information, see https://docs.oracle.com/javase/7/docs/api/java/util/regex/Pattern.html.
- The j flag allows you to use the standard Java regular
expression engine, which allows native Java regular expression syntax. This
allows, for example, the use of
\b
in a regular expression to match word boundaries. For more information, see http://www.saxonica.com/html/documentation/functions/fn/matches.html. - Regular expressions in the
<sqf:stringReplace>
element always have the dot matches all flag set to "true". Therefore, the line terminator will also be matched by the regular expression.
Attention
The context of the content within the<sqf:stringReplace>
element is set to the whole text node, rather than the current sub-string.An Example of the
<sqf:stringReplace>
Element:<?xml version="1.0" encoding="UTF-8"?> <sch:schema xmlns:sch="http://purl.oclc.org/dsdl/schematron" xmlns:sqf="http://www.schematron-quickfix.com/validator/process" queryBinding="xslt2"> <sch:pattern> <sch:rule context="text()"> <sch:report test="matches(., '[oO][xX]ygen')" sqf:fix="changeWord">The oXygen word is not allowed</sch:report> <sqf:fix id="changeWord"> <sqf:description> <sqf:title>Replace word with product</sqf:title> </sqf:description> <sqf:stringReplace regex="[oO][xX]ygen"><ph keyref="product"/> </sqf:stringReplace> </sqf:fix> </sch:rule> </sch:pattern> </sch:schema>