Package mondrian.olap.fun
Class UdfResolver
java.lang.Object
mondrian.olap.fun.UdfResolver
- All Implemented Interfaces:
Resolver
Resolver for user-defined functions.
- Since:
- 2.0
- Author:
- jhyde
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
Implementation ofUdfResolver.UdfFactory
that instantiates a given class using a public default constructor.static interface
Factory forUserDefinedFunction
.Nested classes/interfaces inherited from interface mondrian.olap.fun.Resolver
Resolver.Conversion
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionReturns the description of the function or operator.Returns a representative example of the function which this Resolver can produce, for purposes of describing the function set.getName()
Returns the name of the function or operator.String[]
Returns an array of symbolic constants which can appear as arguments to this function.Returns a string describing the syntax of this function, for exampleReturns the syntax with which the function or operator was invoked.boolean
requiresExpression
(int k) Returns whether a particular argument must be a scalar expression.resolve
(Exp[] args, Validator validator, List<Resolver.Conversion> conversions) Given a particular set of arguments the function is applied to, returns the correct overloaded form of the function.
-
Constructor Details
-
UdfResolver
-
-
Method Details
-
getName
Description copied from interface:Resolver
Returns the name of the function or operator. -
getDescription
Description copied from interface:Resolver
Returns the description of the function or operator.- Specified by:
getDescription
in interfaceResolver
-
getSignature
Description copied from interface:Resolver
Returns a string describing the syntax of this function, for exampleStrToSet(
) - Specified by:
getSignature
in interfaceResolver
-
getSyntax
Description copied from interface:Resolver
Returns the syntax with which the function or operator was invoked. -
getFunDef
Description copied from interface:Resolver
Returns a representative example of the function which this Resolver can produce, for purposes of describing the function set. May return null if there is no representative function, or if the Resolver has a way to describe itself in more detail. -
resolve
Description copied from interface:Resolver
Given a particular set of arguments the function is applied to, returns the correct overloaded form of the function.The method adds an item to
conversions
every time it performs an implicit type-conversion. If there are several candidate functions with the same signature, the validator will choose the one which used the fewest implicit conversions.- Specified by:
resolve
in interfaceResolver
- Parameters:
args
- Expressions which this function call is applied to.validator
- Validatorconversions
- List of implicit conversions performed (out)- Returns:
- The function definition which matches these arguments, or null if no function definition that this resolver knows about matches.
-
requiresExpression
public boolean requiresExpression(int k) Description copied from interface:Resolver
Returns whether a particular argument must be a scalar expression. Returnsfalse
if any of the variants of this resolver allows a set as itsk
th argument; true otherwise.- Specified by:
requiresExpression
in interfaceResolver
-
getReservedWords
Description copied from interface:Resolver
Returns an array of symbolic constants which can appear as arguments to this function.For example, the
DrilldownMember
may take the symbolRECURSIVE
as an argument. Most functions do not define any symbolic constants.- Specified by:
getReservedWords
in interfaceResolver
- Returns:
- An array of the names of the symbolic constants
-