Package net.sf.saxon.style
Class XSLFunction
- All Implemented Interfaces:
Source,SourceLocator,ActiveSource,GroundedValue,Item,MutableNodeInfo,NamespaceResolver,NodeInfo,Sequence,Location,StylesheetComponent,SteppingNode,SiblingCountingNode,Locator
Handler for xsl:function elements in stylesheet (XSLT 2.0).
Attributes:
name gives the name of the function saxon:memo-function=yes|no indicates whether it acts as a memo function.
Attributes:
name gives the name of the function saxon:memo-function=yes|no indicates whether it acts as a memo function.
-
Nested Class Summary
Nested classes/interfaces inherited from class net.sf.saxon.style.StyleElement
StyleElement.OnFailure -
Field Summary
Fields inherited from class net.sf.saxon.style.StyleElement
ACTION_COMPILE, ACTION_FIXUP, ACTION_OPTIMIZE, ACTION_PROCESS_ATTRIBUTES, ACTION_TYPECHECK, ACTION_VALIDATE, actionsCompleted, defaultCollationName, defaultMode, defaultXPathNamespace, expandText, extensionNamespaces, reportingCircumstances, staticContext, validationError, version, YES_NOFields inherited from class net.sf.saxon.tree.linked.NodeImpl
NODE_LETTER -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidcheckCompatibility(Component component) Check the compatibility of this component with another component that it is overridingvoidcompileDeclaration(Compilation compilation, ComponentDeclaration decl) Compile the function definition to create an executable representation The compileDeclaration() method has the side-effect of binding all references to the function to the executable representation (a UserFunction object)getActor()Get the corresponding Procedure object that results from the compilation of this StylesheetProcedureGet the argument typesGet the compiled functionintGet the number of optional parameters declared by this functionintGet the number of parameters declared by this function (that is, its arity).Get a name identifying the object of the expression, for example a function name, template name, variable name, key name, element name, etc.Get the type of value returned by this functionGet associated stack frame details.Get the symbolic name of the component, that is, the combination of the component kind and the qualified nameGet the visibility of the component.voidindex(ComponentDeclaration decl, PrincipalStylesheetModule top) Method supplied by declaration elements to add themselves to a stylesheet-level indexbooleanAsk whether this node is a declaration, that is, a permitted child of xsl:stylesheet (including xsl:include and xsl:import).booleanIs override-extension-function="yes"?.protected booleanisPermittedChild(StyleElement child) Specify that xsl:param is a permitted childbooleanprotected booleanDetermine whether this type of element is allowed to contain an xsl:param elementprotected booleanDetermine whether this type of element is allowed to contain a template-body.voidoptimize(ComponentDeclaration declaration) Optimize the stylesheet constructprotected voidSet the attribute list for the element.voidSet the definitions of the parameters in the compiled function, as an array.voidvalidate(ComponentDeclaration decl) Check that the stylesheet element is valid.Methods inherited from class net.sf.saxon.style.StyleElement
allocateLocation, bindLocalVariable, bindVariable, checkEmpty, checkTopLevel, checkUnknownAttribute, compile, compileError, compileError, compileError, compileError, compileError, compileError, compileErrorInAttribute, compileErrorInAttribute, compileSequenceConstructor, compileSequenceConstructor, compileWarning, compileWarning, fixupReferences, generateId, getAttributeValue, getBaseURI, getBindingInformation, getCompilation, getConfiguration, getContainingPackage, getContainingSlotManager, getDeclaredVisibility, getDefaultCollationName, getDefaultXPathNamespace, getNamespaceResolver, getPackageData, getPrincipalStylesheetModule, getProperties, getSchemaType, getStaticContext, getStaticContext, getTypeAnnotation, getUsedPackage, getWithParamInstructions, getXslOriginal, hasImplicitBinding, invalidAttribute, isExtensionAttributeAllowed, isExtensionNamespace, isInstruction, isInXsltNamespace, isNo, isSchemaAware, issueWarning, issueWarning, isTopLevel, isWithinDeclaredStreamableConstruct, isYes, makeAttributeValueTemplate, makeExpression, makeExpressionVisitor, makeQName, makeRetainedStaticContext, makeSequenceType, mapToSequence, markTailCalls, mayContainFallback, postValidate, processAllAttributes, processAttributes, processBooleanAttribute, processStandardAttributes, processVersionAttribute, reportAbsence, requireXslt40Attribute, requireXslt40Element, seesAvuncularVariables, setCompilation, setInstructionLocation, setObjectName, setValidationError, substituteFor, typeCheck, typeCheck, validateChildren, validateSubtree, validateValidationAttributeMethods inherited from class net.sf.saxon.tree.linked.ElementImpl
addAttribute, addNamespace, addNamespace, attributes, checkNotNamespaceSensitiveElement, copy, delete, fixupInsertedNamespaces, generateId, getAllNamespaces, getAttributeValue, getColumnNumber, getDeclaredNamespaces, getLineNumber, getNodeKind, getNodeName, getRoot, getSchemaType, getSystemId, getURIForPrefix, initialise, isId, isIdref, isIdRefNode, isInScopeNamespace, isNilled, iteratePrefixes, removeAttribute, removeNamespace, removeTypeAnnotation, rename, replaceStringValue, setAttributeInfo, setAttributes, setLocation, setNamespaceMap, setNilled, setNodeName, setSystemId, setTypeAnnotationMethods inherited from class net.sf.saxon.tree.linked.ParentNodeImpl
addChild, compact, getFirstChild, getLastChild, getNthChild, getNumberOfChildren, getRawSequenceNumber, getSequenceNumber, getUnicodeStringValue, hasChildNodes, insertChildren, insertChildrenAt, iterateChildren, removeChild, replaceChildrenAt, setChildren, setRawSequenceNumberMethods inherited from class net.sf.saxon.tree.linked.NodeImpl
atomize, compareOrder, effectiveBooleanValue, equals, getDisplayName, getFingerprint, getLocalPart, getNamePool, getNamespaceUri, getNextInDocument, getNextSibling, getParent, getPhysicalRoot, getPrefix, getPreviousInDocument, getPreviousSibling, getRawParent, getSiblingPosition, getSuccessorElement, getTreeInfo, hasFingerprint, hashCode, head, insertSiblings, isDeleted, iterateAxis, iterateAxis, newBuilder, replace, saveLocation, setRawParent, setSiblingPositionMethods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface net.sf.saxon.om.GroundedValue
asIterable, concatenate, containsNode, materializeMethods inherited from interface net.sf.saxon.om.Item
getLength, getStringValue, itemAt, iterate, reduce, subsequenceMethods inherited from interface net.sf.saxon.om.NodeInfo
asActiveSource, children, children, deliver, getAttributeValue, getGenre, getPublicId, getURI, isSameNodeInfo, isStreamed, toShortStringMethods inherited from interface net.sf.saxon.om.Sequence
makeRepeatable
-
Constructor Details
-
XSLFunction
public XSLFunction()
-
-
Method Details
-
getActor
Get the corresponding Procedure object that results from the compilation of this StylesheetProcedure- Specified by:
getActorin interfaceStylesheetComponent- Returns:
- the compiled ComponentCode
-
isDeclaration
public boolean isDeclaration()Ask whether this node is a declaration, that is, a permitted child of xsl:stylesheet (including xsl:include and xsl:import).- Overrides:
isDeclarationin classStyleElement- Returns:
- true for this element
-
prepareAttributes
protected void prepareAttributes()Description copied from class:StyleElementSet the attribute list for the element. This is called to process the attributes (note the distinction from processAttributes in the superclass). Must be supplied in a subclass- Specified by:
prepareAttributesin classStyleElement
-
getObjectName
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. If there is no name, the value will be -1.- Overrides:
getObjectNamein classStyleElement- Returns:
- the name of the object declared in this element, if any
-
mayContainSequenceConstructor
protected boolean mayContainSequenceConstructor()Determine whether this type of element is allowed to contain a template-body.- Overrides:
mayContainSequenceConstructorin classStyleElement- Returns:
- true: yes, it may contain a general template-body
-
mayContainParam
protected boolean mayContainParam()Description copied from class:StyleElementDetermine whether this type of element is allowed to contain an xsl:param element- Overrides:
mayContainParamin classStyleElement- Returns:
- true if this element is allowed to contain an xsl:param
-
isPermittedChild
Specify that xsl:param is a permitted child- Overrides:
isPermittedChildin classStyleElement- Parameters:
child- the child that may or may not be permitted- Returns:
- true if the child is permitted.
-
getVisibility
Description copied from class:StyleElementGet the visibility of the component. Returns the actual value of the visibility attribute, after validation, unless this is absent, in which case it returns the default value of PRIVATE. InvokesStyleElement.invalidAttribute(String, String)if the value is invalid.- Overrides:
getVisibilityin classStyleElement- Returns:
- the declared visibility of the component, or
Visibility.PRIVATEif the visibility attribute is absent.
-
getSymbolicName
Description copied from interface:StylesheetComponentGet the symbolic name of the component, that is, the combination of the component kind and the qualified name- Specified by:
getSymbolicNamein interfaceStylesheetComponent- Returns:
- the component's symbolic name
-
checkCompatibility
Description copied from interface:StylesheetComponentCheck the compatibility of this component with another component that it is overriding- Specified by:
checkCompatibilityin interfaceStylesheetComponent- Parameters:
component- the overridden component
-
isOverrideExtensionFunction
public boolean isOverrideExtensionFunction()Is override-extension-function="yes"?.- Returns:
- true if override-extension-function="yes" was specified, otherwise false
-
isUpdating
public boolean isUpdating() -
index
Description copied from class:StyleElementMethod supplied by declaration elements to add themselves to a stylesheet-level index- Overrides:
indexin classStyleElement- Parameters:
decl- the Declaration being indexed. (This corresponds to the StyleElement object except in cases where one module is imported several times with different precedence.)top- represents the outermost XSLStylesheet or XSLPackage element
-
validate
Description copied from class:StyleElementCheck that the stylesheet element is valid. This is called once for each element, after the entire tree has been built. As well as validation, it can perform first-time initialisation. The default implementation does nothing; it is normally overriden in subclasses.- Overrides:
validatein classStyleElement- Parameters:
decl- the declaration to be validated- Throws:
XPathException- if any error is found during validation
-
compileDeclaration
public void compileDeclaration(Compilation compilation, ComponentDeclaration decl) throws XPathException Compile the function definition to create an executable representation The compileDeclaration() method has the side-effect of binding all references to the function to the executable representation (a UserFunction object)- Overrides:
compileDeclarationin classStyleElement- Parameters:
compilation- the compilation episodedecl- the containing top-level declaration, for example xsl:function or xsl:template- Throws:
XPathException- if compilation fails
-
optimize
Description copied from interface:StylesheetComponentOptimize the stylesheet construct- Specified by:
optimizein interfaceStylesheetComponent- Parameters:
declaration- the combination of the source XSLT element defining the component, and the module in which it appears- Throws:
XPathException- if an error is found at this stage (which shouldn't really happen)
-
getSlotManager
Get associated stack frame details.- Specified by:
getSlotManagerin interfaceStylesheetComponent- Returns:
- the associated SlotManager object
-
getResultType
Get the type of value returned by this function- Returns:
- the declared result type, or the inferred result type if this is more precise
-
getNumberOfParameters
public int getNumberOfParameters()Get the number of parameters declared by this function (that is, its arity).- Returns:
- the arity of the function
-
getNumberOfOptionalParameters
public int getNumberOfOptionalParameters()Get the number of optional parameters declared by this function- Returns:
- the arity of the function
-
setParameterDefinitions
Set the definitions of the parameters in the compiled function, as an array.- Parameters:
fn- the compiled object representing the user-written function
-
getArgumentTypes
Get the argument types- Returns:
- the declared types of the arguments
-
getCompiledFunction
Get the compiled function- Returns:
- the object representing the compiled user-written function
-