Package net.sf.saxon.functions
Class AbstractFunction
- java.lang.Object
-
- net.sf.saxon.functions.AbstractFunction
-
- All Implemented Interfaces:
Callable,FunctionItem,GroundedValue,Item,Sequence
- Direct Known Subclasses:
AtomicConstructorFunction,CallableFunction,CoercedFunction,CurriedFunction,ListConstructorFunction,OriginalFunction,SystemFunction,SystemFunctionWithBoundContextItem,UnionConstructorFunction,UnresolvedXQueryFunctionItem,UserFunctionReference.BoundUserFunction
public abstract class AbstractFunction extends java.lang.Object implements FunctionItem
Abstract superclass (and factory class) for implementations of Function
-
-
Constructor Summary
Constructors Constructor Description AbstractFunction()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description AtomicSequenceatomize()Atomize the item.booleandeepEqual40(FunctionItem other, XPathContext context, DeepEqual.DeepEqualOptions options)booleandeepEquals(FunctionItem other, XPathContext context, AtomicComparer comparer, int flags)Test whether this FunctionItem is deep-equal to another function item, under the rules of the deep-equal functionbooleaneffectiveBooleanValue()Get the effective boolean value of the function itemvoidexport(ExpressionPresenter out)Output information about this function item to the diagnostic explain() outputAnnotationListgetAnnotations()Get the function annotations (as defined in XQuery).OperandRole[]getOperandRoles()Get the roles of the arguments, for the purposes of streamingUnicodeStringgetUnicodeStringValue()Get the string value of the functionbooleanisArray()Ask whether this function is an arraybooleanisMap()Ask whether this function is a mapbooleanisTrustedResultType()Check that result type is SystemFunction or AtomicConstructorFunctionXPathContextmakeNewContext(XPathContext callingContext, ContextOriginator originator)Prepare an XPathContext object for evaluating the functionvoidsimplify()java.lang.StringtoShortString()Provide a short string showing the contents of the item, suitable for use in error messagesvoidtypeCheck(ExpressionVisitor visitor, ContextItemStaticInfo contextItemType)Type check the function (may modify it by adding code for converting the arguments)-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface net.sf.saxon.om.FunctionItem
getArity, getDescription, getFunctionItemType, getFunctionName, getGenre, isSequenceVariadic
-
Methods inherited from interface net.sf.saxon.om.GroundedValue
asIterable, concatenate, containsNode, materialize
-
Methods inherited from interface net.sf.saxon.om.Item
getLength, getStringValue, head, isStreamed, itemAt, iterate, reduce, subsequence
-
Methods inherited from interface net.sf.saxon.om.Sequence
makeRepeatable
-
-
-
-
Method Detail
-
getOperandRoles
public OperandRole[] getOperandRoles()
Get the roles of the arguments, for the purposes of streaming- Specified by:
getOperandRolesin interfaceFunctionItem- Returns:
- an array of OperandRole objects, one for each argument
-
atomize
public AtomicSequence atomize() throws XPathException
Atomize the item.- Specified by:
atomizein interfaceItem- Returns:
- the result of atomization
- Throws:
XPathException- if atomization is not allowed for this kind of item
-
isArray
public boolean isArray()
Ask whether this function is an array- Specified by:
isArrayin interfaceFunctionItem- Returns:
- true if this function item is an array, otherwise false
-
isMap
public boolean isMap()
Ask whether this function is a map- Specified by:
isMapin interfaceFunctionItem- Returns:
- true if this function item is a map, otherwise false
-
getUnicodeStringValue
public UnicodeString getUnicodeStringValue()
Get the string value of the function- Specified by:
getUnicodeStringValuein interfaceGroundedValue- Specified by:
getUnicodeStringValuein interfaceItem- Returns:
- nothing; this method always throws an exception
- Throws:
UncheckedXPathException- (the string value of a function is not defined)
-
getAnnotations
public AnnotationList getAnnotations()
Description copied from interface:FunctionItemGet the function annotations (as defined in XQuery). Returns an empty list if there are no function annotations.- Specified by:
getAnnotationsin interfaceFunctionItem- Returns:
- the function annotations
-
effectiveBooleanValue
public boolean effectiveBooleanValue() throws XPathExceptionGet the effective boolean value of the function item- Specified by:
effectiveBooleanValuein interfaceGroundedValue- Returns:
- the effective boolean value
- Throws:
XPathException- (the EBVof a function item is not defined)
-
simplify
public void simplify() throws XPathException- Throws:
XPathException
-
typeCheck
public void typeCheck(ExpressionVisitor visitor, ContextItemStaticInfo contextItemType) throws XPathException
Type check the function (may modify it by adding code for converting the arguments)- Parameters:
visitor- the expression visitor, supplies context informationcontextItemType- the context item type at the point where the function definition appears- Throws:
XPathException- if any failure (e.g. a type checking failure) occurs
-
makeNewContext
public XPathContext makeNewContext(XPathContext callingContext, ContextOriginator originator)
Prepare an XPathContext object for evaluating the function- Specified by:
makeNewContextin interfaceFunctionItem- Parameters:
callingContext- the XPathContext of the function calling expressionoriginator- the originator of the new context- Returns:
- a suitable context for evaluating the function (which may or may not be the same as the caller's context)
-
deepEquals
public boolean deepEquals(FunctionItem other, XPathContext context, AtomicComparer comparer, int flags) throws XPathException
Test whether this FunctionItem is deep-equal to another function item, under the rules of the deep-equal function- Specified by:
deepEqualsin interfaceFunctionItem- Parameters:
other- the other function itemcontext- the dynamic evaluation contextcomparer- the object to perform the comparisonflags- options for how the comparison is performed- Returns:
- true if the two function items are deep-equal
- Throws:
XPathException- if the comparison cannot be performed
-
deepEqual40
public boolean deepEqual40(FunctionItem other, XPathContext context, DeepEqual.DeepEqualOptions options) throws XPathException
- Specified by:
deepEqual40in interfaceFunctionItem- Throws:
XPathException
-
export
public void export(ExpressionPresenter out) throws XPathException
Output information about this function item to the diagnostic explain() output- Specified by:
exportin interfaceFunctionItem- Parameters:
out- the destination for the information- Throws:
XPathException- if things go wrong
-
isTrustedResultType
public boolean isTrustedResultType()
Check that result type is SystemFunction or AtomicConstructorFunction- Specified by:
isTrustedResultTypein interfaceFunctionItem- Returns:
- true if the implementation can be trusted
-
toShortString
public java.lang.String toShortString()
Description copied from interface:FunctionItemProvide a short string showing the contents of the item, suitable for use in error messages- Specified by:
toShortStringin interfaceFunctionItem- Specified by:
toShortStringin interfaceGroundedValue- Specified by:
toShortStringin interfaceItem- Returns:
- a depiction of the item suitable for use in error messages
-
-