net.sf.saxon.instruct

Class UserFunction

public final class UserFunction extends Procedure implements InstructionInfoProvider

This object represents the compiled form of a user-written function (the source can be either an XSLT stylesheet function or an XQuery function).

It is assumed that type-checking, of both the arguments and the results, has been handled at compile time. That is, the expression supplied as the body of the function must be wrapped in code to check or convert the result to the required type, and calls on the function must be wrapped at compile time to check or convert the supplied arguments.

Constructor Summary
UserFunction()
UserFunction(Expression body)
Method Summary
ValueRepresentationcall(ValueRepresentation[] actualArgs, XPathContextMajor context, boolean evaluateTailCalls)
Call this function.
ValueRepresentationcall(ValueRepresentation[] actualArgs, Controller controller)
Call this function.
SequenceTypegetArgumentType(int n)
Get the required types of an argument to this function
intgetFunctionNameCode()
Get the namepool name code of the function
InstructionInfogetInstructionInfo()
Get the InstructionInfo details about the construct.
intgetNumberOfArguments()
Get the arity of this function
UserFunctionParameter[]getParameterDefinitions()
SequenceTypegetResultType()
Get the type of value returned by this function
booleanisTailRecursive()
voidsetFunctionNameCode(int nameCode)
Set the namepool name code of the function
voidsetMemoFunction(boolean isMemo)
Mark this function as a memo function (or not)
voidsetParameterDefinitions(UserFunctionParameter[] params)
voidsetResultType(SequenceType resultType)
voidsetTailRecursive(boolean tailCalls)

Constructor Detail

UserFunction

public UserFunction()

UserFunction

public UserFunction(Expression body)

Method Detail

call

public ValueRepresentation call(ValueRepresentation[] actualArgs, XPathContextMajor context, boolean evaluateTailCalls)
Call this function.

Parameters: actualArgs the arguments supplied to the function. These must have the correct types required by the function signature (it is the caller's responsibility to check this). It is acceptable to supply a Closure to represent a value whose evaluation will be delayed until it is needed. The array must be the correct size to match the number of arguments: again, it is the caller's responsibility to check this. context This provides the run-time context for evaluating the function. It is the caller's responsibility to allocate a "clean" context for the function to use; the context that is provided will be overwritten by the function. evaluateTailCalls if true, then any function calls contained in the body of the function are evaluated in the normal way, whether or not they are marked as tail calls. If the argument is false, then tail calls are not evaluated, and instead a FunctionCallPackage is returned containing the information needed to evaluate the function. The caller must then be prepared to deal with this returned value by evaluating the packaged function call (which may return further packaged function calls, and so on).

Returns: a Value representing the result of the function.

call

public ValueRepresentation call(ValueRepresentation[] actualArgs, Controller controller)
Call this function. This method allows an XQuery function to be called directly from a Java application. It creates the environment needed to achieve this

Parameters: actualArgs the arguments supplied to the function. These must have the correct types required by the function signature (it is the caller's responsibility to check this). It is acceptable to supply a Closure to represent a value whose evaluation will be delayed until it is needed. The array must be the correct size to match the number of arguments: again, it is the caller's responsibility to check this. controller This provides the run-time context for evaluating the function. A Controller may be obtained by calling XQueryExpression. This may be used for a series of calls on functions defined in the same module as the XQueryExpression.

Returns: a Value representing the result of the function.

getArgumentType

public SequenceType getArgumentType(int n)
Get the required types of an argument to this function

Parameters: n identifies the argument in question, starting at 0

Returns: a SequenceType object, indicating the required type of the argument

getFunctionNameCode

public int getFunctionNameCode()
Get the namepool name code of the function

Returns: a name code representing the function name

getInstructionInfo

public InstructionInfo getInstructionInfo()
Get the InstructionInfo details about the construct. This information isn't used for tracing, but it is available when inspecting the context stack.

getNumberOfArguments

public int getNumberOfArguments()
Get the arity of this function

Returns: the number of arguments

getParameterDefinitions

public UserFunctionParameter[] getParameterDefinitions()

getResultType

public SequenceType 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

isTailRecursive

public boolean isTailRecursive()

setFunctionNameCode

public void setFunctionNameCode(int nameCode)
Set the namepool name code of the function

Parameters: nameCode represents the function name

setMemoFunction

public void setMemoFunction(boolean isMemo)
Mark this function as a memo function (or not)

Parameters: isMemo true if this is a memo function

setParameterDefinitions

public void setParameterDefinitions(UserFunctionParameter[] params)

setResultType

public void setResultType(SequenceType resultType)

setTailRecursive

public void setTailRecursive(boolean tailCalls)