|
|||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||
java.lang.Objectnet.sf.saxon.tree.NodeImpl
net.sf.saxon.tree.ElementImpl
net.sf.saxon.style.StyleElement
net.sf.saxon.style.XSLFunction
public class XSLFunction
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.
| Field Summary | |
|---|---|
protected Object |
children
|
protected int |
sequence
|
| Fields inherited from class net.sf.saxon.style.StyleElement |
|---|
defaultCollationName, defaultXPathNamespace, extensionNamespaces, REPORT_ALWAYS, REPORT_IF_INSTANTIATED, REPORT_UNLESS_FALLBACK_AVAILABLE, REPORT_UNLESS_FORWARDS_COMPATIBLE, reportingCircumstances, staticContext, validationError, version |
| Fields inherited from class net.sf.saxon.tree.ElementImpl |
|---|
attributeList, nameCode, namespaceList, typeCode |
| Fields inherited from class net.sf.saxon.tree.NodeImpl |
|---|
index, NODE_LETTER, parent |
| Fields inherited from interface net.sf.saxon.om.NodeInfo |
|---|
ALL_NAMESPACES, EMPTY_NAMESPACE_LIST, IS_DTD_TYPE, IS_NILLED, LOCAL_NAMESPACES, NO_NAMESPACES |
| Constructor Summary | |
|---|---|
XSLFunction()
|
|
| Method Summary | |
|---|---|
void |
addChild(NodeImpl node,
int index)
Add a child node to this node. |
void |
compact(int size)
Compact the space used by this node |
Expression |
compile(Executable exec)
Compile the function definition to create an executable representation |
protected AxisIterator |
enumerateChildren(NodeTest test)
Get an enumeration of the children of this node |
void |
fixupReferences()
Notify all references to this function of the data type. |
UserFunction |
getCompiledFunction()
Get the compiled function |
int |
getConstructType()
Get the type of construct. |
NodeInfo |
getFirstChild()
Get the first child node of the element |
NodeInfo |
getLastChild()
Get the last child node of the element |
protected NodeImpl |
getNthChild(int n)
Get the nth child node of the element (numbering from 0) |
int |
getNumberOfArguments()
Get the number of arguments declared by this function (that is, its arity). |
int |
getNumberOfChildren()
Determine how many children the node has |
StructuredQName |
getObjectName()
Get a name identifying the object of the expression, for example a function name, template name, variable name, key name, element name, etc. |
SequenceType |
getResultType()
Get the type of value returned by this function |
protected long |
getSequenceNumber()
Get the node sequence number (in document order). |
SlotManager |
getSlotManager()
Get associated Procedure (for details of stack frame). |
String |
getStringValue()
Return the string-value of the node, that is, the concatenation of the character content of all descendent elements and text nodes. |
CharSequence |
getStringValueCS()
Get the value of the item as a CharSequence. |
boolean |
hasChildNodes()
Determine if the node has any children. |
void |
insertChildren(NodeInfo[] source,
boolean atStart,
boolean inherit)
Insert copies of a sequence of nodes as children of this node. |
protected void |
insertChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
Insert children before or after a given existing child |
boolean |
isOverriding()
Is override="yes"?. |
protected boolean |
isPermittedChild(StyleElement child)
Specify that xsl:param is a permitted child |
protected boolean |
mayContainParam(String attName)
Determine whether this type of element is allowed to contain an xsl:param element |
boolean |
mayContainSequenceConstructor()
Determine whether this type of element is allowed to contain a template-body. |
void |
optimize()
Optimize the stylesheet construct |
void |
prepareAttributes()
Set the attribute list for the element. |
void |
registerReference(UserFunctionCall ref)
Method called by UserFunctionCall to register the function call for subsequent fixup. |
protected void |
removeChild(NodeImpl child)
Remove a given child |
protected void |
replaceChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
Replace child at a given index by new children |
void |
setParameterDefinitions(UserFunction fn)
Set the definitions of the parameters in the compiled function, as an array. |
protected void |
useChildrenArray(NodeImpl[] array)
Supply an array to be used for the array of children. |
void |
validate()
Check that the stylesheet element is valid. |
| Methods inherited from class net.sf.saxon.tree.NodeImpl |
|---|
atomize, compareOrder, equals, getConfiguration, getDisplayName, getDocumentNumber, getFingerprint, getLocalPart, getNamePool, getNextInDocument, getNextSibling, getParent, getPhysicalRoot, getPrefix, getPreviousInDocument, getPreviousSibling, getPublicId, getSiblingPosition, getTypedValue, getURI, insertSiblings, isDeleted, isIdref, isSameNodeInfo, iterateAxis, iterateAxis, newBuilder, replace |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
| Methods inherited from interface net.sf.saxon.trace.InstructionInfo |
|---|
getLineNumber, getSystemId |
| Methods inherited from interface org.xml.sax.Locator |
|---|
getColumnNumber, getPublicId |
| Methods inherited from interface javax.xml.transform.SourceLocator |
|---|
getColumnNumber, getPublicId |
| Methods inherited from interface net.sf.saxon.om.NodeInfo |
|---|
hashCode |
| Field Detail |
|---|
protected Object children
protected int sequence
| Constructor Detail |
|---|
public XSLFunction()
| Method Detail |
|---|
public void registerReference(UserFunctionCall ref)
ref - the UserFunctionCall to be registered
public void prepareAttributes()
throws XPathException
StyleElement
prepareAttributes in class StyleElementXPathExceptionpublic StructuredQName getObjectName()
getObjectName in interface InstructionInfogetObjectName in class StyleElementpublic boolean mayContainSequenceConstructor()
mayContainSequenceConstructor in class StyleElementprotected boolean mayContainParam(String attName)
StyleElement
mayContainParam in class StyleElementattName - if null, the method tests whether an xsl:param child is allowed.
If non-null, it tests whether an xsl:param child with the given attribute name is allowed
protected boolean isPermittedChild(StyleElement child)
isPermittedChild in class StyleElementchild - the child that may or may not be permitted
public boolean isOverriding()
public void fixupReferences()
throws XPathException
fixupReferences in class StyleElementXPathException
public void validate()
throws XPathException
StyleElement
validate in class StyleElementXPathException
public Expression compile(Executable exec)
throws XPathException
compile in class StyleElementexec - the Executable
XPathException
public void optimize()
throws XPathException
StylesheetProcedure
optimize in interface StylesheetProcedureXPathExceptionpublic SlotManager getSlotManager()
getSlotManager in interface StylesheetProcedurepublic SequenceType getResultType()
public int getNumberOfArguments()
public void setParameterDefinitions(UserFunction fn)
fn - the compiled object representing the user-written functionpublic UserFunction getCompiledFunction()
public int getConstructType()
Location. This method is part of the
InstructionInfo interface
getConstructType in interface InstructionInfogetConstructType in class StyleElementprotected final long getSequenceNumber()
getSequenceNumber in class NodeImplpublic final boolean hasChildNodes()
hasChildNodes in interface NodeInfohasChildNodes in class NodeImpltrue if the node has any children,
false if the node has no children.public int getNumberOfChildren()
protected final AxisIterator enumerateChildren(NodeTest test)
test - A NodeTest to be satisfied by the child nodes, or null
if all child node are to be returned
public final NodeInfo getFirstChild()
getFirstChild in class NodeImplpublic final NodeInfo getLastChild()
getLastChild in class NodeImplprotected final NodeImpl getNthChild(int n)
n - identifies the required child
protected void removeChild(NodeImpl child)
child - the child to be removedpublic String getStringValue()
Item.getStringValueCS()public CharSequence getStringValueCS()
NodeImpl
getStringValueCS in interface ItemgetStringValueCS in interface ValueRepresentationgetStringValueCS in class NodeImplItem.getStringValue()protected void useChildrenArray(NodeImpl[] array)
array - the array to be used
public void addChild(NodeImpl node,
int index)
node - the node to be added as a child of this nodeindex - the position where the child is to be added
public void insertChildren(NodeInfo[] source,
boolean atStart,
boolean inherit)
This method takes no action unless the target node is a document node or element node. It also takes no action in respect of any supplied nodes that are not elements, text nodes, comments, or processing instructions.
The supplied nodes will be copied to form the new children. Adjacent text nodes will be merged, and zero-length text nodes removed.
insertChildren in interface MutableNodeInfoinsertChildren in class NodeImplsource - the nodes to be insertedatStart - true if the new nodes are to be inserted before existing children; false if they areinherit - true if the inserted nodes are to inherit the namespaces that are in-scope for their
new parent; false if such namespaces should be undeclared on the children
protected void insertChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
source - the children to be insertedindex - the position before which they are to be inserted: 0 indicates insertion before the
first child, 1 insertion before the second child, and so on.inherit - true if the inserted nodes are to inherit the namespaces that are in-scope for their
new parent; false if such namespaces should be undeclared on the children
protected void replaceChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
source - the children to be insertedindex - the position at which they are to be inserted: 0 indicates replacement of the
first child, replacement of the second child, and so on. The effect is undefined if index
is out of rangeinherit - set to true if the new child elements are to inherit the in-scope namespaces
of their new parent
IllegalArgumentException - if any of the replacement nodes is not an element, text,
comment, or processing instruction nodepublic void compact(int size)
size - the number of actual children
|
|||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||