Package net.sf.saxon.expr.instruct
Class TemplateRule
java.lang.Object
net.sf.saxon.expr.instruct.TemplateRule
- All Implemented Interfaces:
SourceLocator
,ExpressionOwner
,Locatable
,Location
,Traceable
,TraceableComponent
,RuleTarget
,Locator
- Direct Known Subclasses:
TemplateRuleEE
public class TemplateRule
extends Object
implements RuleTarget, Location, ExpressionOwner, TraceableComponent
The runtime object corresponding to an xsl:template element in the stylesheet.
Note that the Template object no longer has precedence information associated with it; this is now only in the Rule object that references this Template. This allows two rules to share the same template, with different precedences. This occurs when a stylesheet module is imported more than once, from different places, with different import precedences.
From Saxon 9.7, the old Template class is split into NamedTemplate and TemplateRule.
From Saxon 9.8, a subclass is used in Saxon-EE
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected Expression
protected PushEvaluator
protected Pattern
protected Mode
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoid
apply
(Outputter output, XPathContextMajor context) Process the template, without returning any tail calls.applyLeavingTail
(Outputter output, XPathContext context) Process this template, with the possibility of returning a tail call package if the template contains any tail calls that are to be performed by the caller.protected void
copyTo
(TemplateRule tr) void
explainProperties
(ExpressionPresenter presenter) void
export
(ExpressionPresenter presenter) Output diagnostic explanation to an ExpressionPresentervoid
gatherProperties
(BiConsumer<String, Object> consumer) Get the properties of this object to be included in trace messages, by supplying the property values to a supplied consumer functiongetBody()
Get the expression at the root of the expression tree used to evaluate this constructint
Get the column number.int
int
int
Get the line number.Get the location of the constructGet the match pattern used with this templategetMode()
Get the mode used by this template ruleGet a name identifying the object of the expression, for example a function name, template name, variable name, key name, element name, etc.Get the Public IDGet the required type to be returned by this templategetRules()
Get the rules that use this template.Get the system ID.Get a string to identify the type of componentvoid
Ensure that any first-time initialization has been done.boolean
boolean
void
prepareInitializer
(Compilation compilation, ComponentDeclaration decl) Prepare for JIT compilation.void
registerRule
(Rule rule) Register a rule for which this is the targetGet an immutable copy of this Location object.void
setBody
(Expression body) Set the expression that forms the body of the templatevoid
setChildExpression
(Expression expr) void
setColumnNumber
(int col) void
setContextItemRequirements
(ItemType type, boolean absentFocus) Set the required context item type.void
setDeclaredStreamable
(boolean streamable) Say whether or not this template is declared as streamablevoid
setLineNumber
(int line) void
setMatchPattern
(Pattern pattern) Set the match pattern used with this templatevoid
Set the mode used by this template rulevoid
setPackageData
(PackageData data) void
setRequiredType
(SequenceType type) Set the required type to be returned by this templatevoid
void
setSystemId
(String id)
-
Field Details
-
Constructor Details
-
Method Details
-
setMatchPattern
Set the match pattern used with this template- Parameters:
pattern
- the match pattern (may be null for a named template)
-
setMode
Set the mode used by this template rule- Parameters:
m
- the mode
-
getMode
Get the mode used by this template rule- Returns:
- the mode
-
getBody
Description copied from interface:TraceableComponent
Get the expression at the root of the expression tree used to evaluate this construct- Specified by:
getBody
in interfaceTraceableComponent
- Returns:
- the root expression
-
getChildExpression
- Specified by:
getChildExpression
in interfaceExpressionOwner
-
getLocation
Description copied from interface:Locatable
Get the location of the construct- Specified by:
getLocation
in interfaceLocatable
- Returns:
- the location. If no location information is available, the method should return
Loc.NONE
rather than returning null. However, callers would be well advised to check for the result being null.
-
gatherProperties
Get the properties of this object to be included in trace messages, by supplying the property values to a supplied consumer function- Specified by:
gatherProperties
in interfaceTraceable
- Parameters:
consumer
- the function to which the properties should be supplied, as (property name, value) pairs.
-
setContextItemRequirements
Set the required context item type. Used when there is an xsl:context-item child element- Parameters:
type
- the required context item typeabsentFocus
- true if the context item is treated as absent even if supplied (use="absent")
-
getComponentKind
public int getComponentKind() -
getMatchPattern
Get the match pattern used with this template- Returns:
- the match pattern, or null if this is a named template with no match pattern. In the case of a template rule whose pattern is a union pattern, this will be the original union pattern; the individual Rule objects contain the branches of the union pattern.
-
setBody
Set the expression that forms the body of the template- Specified by:
setBody
in interfaceTraceableComponent
- Parameters:
body
- the body of the template
-
setStackFrameMap
-
getStackFrameMap
-
setRequiredType
Set the required type to be returned by this template- Parameters:
type
- the required type as defined in the "as" attribute on the xsl:template element
-
getRequiredType
Get the required type to be returned by this template- Returns:
- the required type as defined in the "as" attribute on the xsl:template element
-
registerRule
Register a rule for which this is the target- Specified by:
registerRule
in interfaceRuleTarget
- Parameters:
rule
- a rule in which this is the target
-
getRules
Get the rules that use this template. For a template with no match pattern, this will be an empty list. For a union pattern, there will be one rule for each branch of the union.- Returns:
- the rules corresponding to this template.
-
getContainerGranularity
public int getContainerGranularity() -
getPackageData
-
setPackageData
-
getPublicId
Description copied from interface:Location
Get the Public ID- Specified by:
getPublicId
in interfaceLocation
- Specified by:
getPublicId
in interfaceLocator
- Specified by:
getPublicId
in interfaceSourceLocator
- Returns:
- usually null
-
getSystemId
Description copied from interface:Location
Get the system ID. This should be the system identifier of an XML external entity; if a stylesheet module comprises multiple external entities, the distinction should be retained. This means, for example, that an instruction in a stylesheet can have a different system identifier from its parent instruction. However, SAX parsers only provide location information at the element level, so when part of an XPath expression is in a different external entity from other parts of the same expression, this distinction is lost.The system identifier of a node is in general not the same as its base URI. The base URI is affected by xml:base attributes; the system identifier is not.
- Specified by:
getSystemId
in interfaceLocation
- Specified by:
getSystemId
in interfaceLocator
- Specified by:
getSystemId
in interfaceSourceLocator
- Returns:
- the system ID, or null if the information is not available.
-
setSystemId
-
getLineNumber
public int getLineNumber()Description copied from interface:Location
Get the line number. This line number is relative to the external entity identified by the system identifier. Line numbers start at 1. The value may be an approximation; SAX parsers only provide line number information at the level of element nodes.- Specified by:
getLineNumber
in interfaceLocation
- Specified by:
getLineNumber
in interfaceLocator
- Specified by:
getLineNumber
in interfaceSourceLocator
- Returns:
- the line number, or -1 if the information is not available.
-
setLineNumber
public void setLineNumber(int line) -
setColumnNumber
public void setColumnNumber(int col) -
getColumnNumber
public int getColumnNumber()Description copied from interface:Location
Get the column number. This column number is relative to the line identified by the line number. Column numbers start at 1.- Specified by:
getColumnNumber
in interfaceLocation
- Specified by:
getColumnNumber
in interfaceLocator
- Specified by:
getColumnNumber
in interfaceSourceLocator
- Returns:
- the column number, or -1 if the information is not available.
-
saveLocation
Get an immutable copy of this Location object. By default Location objects may be mutable, so they should not be saved for later use. The result of this operation holds the same location information, but in an immutable form.- Specified by:
saveLocation
in interfaceLocation
- Returns:
- an immutable copy (which may be the original object, if it is already immutable)
-
getRequiredContextItemType
-
isAbsentFocus
public boolean isAbsentFocus() -
getLocalParams
-
prepareInitializer
Prepare for JIT compilation.- Parameters:
compilation
- the XSLT compilationdecl
- the component declaration of this template rule
-
initialize
Ensure that any first-time initialization has been done. Used in Saxon-EE to do JIT compilation- Throws:
XPathException
- if any error occurs
-
apply
Process the template, without returning any tail calls. This path is used by xsl:apply-imports and xsl:next-match- Parameters:
output
- the destination for the resultcontext
- The dynamic context, giving access to the current node,- Throws:
XPathException
- if a dynamic error occurs while evaluating the template
-
applyLeavingTail
Process this template, with the possibility of returning a tail call package if the template contains any tail calls that are to be performed by the caller.- Parameters:
output
- the destination for the resultcontext
- the XPath dynamic context- Returns:
- null if the template exited normally; but if it was a tail call, details of the call that hasn't been made yet and needs to be made by the caller
- Throws:
XPathException
- if a dynamic error occurs while evaluating the template
-
export
Output diagnostic explanation to an ExpressionPresenter- Specified by:
export
in interfaceRuleTarget
- Parameters:
presenter
- the destination for the explanation- Throws:
XPathException
- if output fails
-
setDeclaredStreamable
public void setDeclaredStreamable(boolean streamable) Say whether or not this template is declared as streamable- Parameters:
streamable
- true if the template belongs to a streamable mode; set to false if it does not belong to a streamable mode, or if it is found that the template is not actually streamable, and fallback to non-streaming has been requested.
-
isDeclaredStreamable
public boolean isDeclaredStreamable() -
explainProperties
- Throws:
XPathException
-
copyTo
-
setChildExpression
- Specified by:
setChildExpression
in interfaceExpressionOwner
-
getObjectName
Description copied from interface:Traceable
Get a name identifying the object of the expression, for example a function name, template name, variable name, key name, element name, etc. This is used only where the name is known statically.- Specified by:
getObjectName
in interfaceTraceable
- Returns:
- the QName of the object declared or manipulated by this instruction or expression
-
getTracingTag
Description copied from interface:TraceableComponent
Get a string to identify the type of component- Specified by:
getTracingTag
in interfaceTraceableComponent
- Returns:
- an identifying string
-