Package org.geotools.filter
Class FunctionImpl
- Object
- 
- ExpressionAbstract
- 
- FunctionImpl
 
 
- 
- All Implemented Interfaces:
- Expression,- Function
 - Direct Known Subclasses:
- AbstractHSLFunction,- BoundedByFunction,- Collection_NearestFunction,- ConcatenateFunction,- ConstrastFunction,- CSSFunction,- DefaultIfNullFunction,- ExponentialFunction,- FontAlternativesFunction,- FootprintsTransformation,- GrayscaleFunction,- HSLFunction,- InternalVolatileFunction,- MapBoxFontBaseNameFunction,- MapBoxFontStyleFunction,- MapBoxFontWeightFunction,- MBExpression,- MixFunction,- ShadeFunction,- SpinFunction,- StringInFunction,- StringTransformFunction,- TintFunction
 
 public class FunctionImpl extends ExpressionAbstract implements Function Default implementation of a Function; you may extend this class to implement specific functionality.- Author:
- Cory Horner, Refractions Research
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected FunctionNamefunctionNameFunctionName description for FilterCapabilities, may be provided by subclass in constructor, or will be lazily created based on name and number of arguments.- 
Fields inherited from interface ExpressionNIL
 
- 
 - 
Constructor SummaryConstructors Constructor Description FunctionImpl()
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description Objectaccept(ExpressionVisitor visitor, Object extraData)Accepts a visitor.protected LinkedHashMap<String,Object>dispatchArguments(Object obj)Gathers up and groups the parameters to the function based on the declared parameters.booleanequals(Object obj)Objectevaluate(Object object)Default implementation simply returns the fallbackValue.protected static FunctionNamefunctionName(String name, String ret, String... args)Convenience method for creating a function name from a set of strings describing the return and argument parameters of the function.LiteralgetFallbackValue()The value of the fallbackValue attribute is used as a default value, if the SE implementation does not support the function.FunctionNamegetFunctionName()Access to the FunctionName description as used in a FilterCapabilities document.StringgetName()Gets the name of this function.List<Expression>getParameters()Returns the function parameters.protected ObjectgetParameterValue(Object object, int argumentIndex)Evaluates a specific argument against the context, checking for required values and proper conversion.protected ObjectgetParameterValue(Object object, int argumentIndex, Object defaultValue)Evaluates a specific argument against the context, checking for required values and proper conversion.inthashCode()voidsetFallbackValue(Literal fallbackValue)voidsetName(String name)Sets the name of the function.voidsetParameters(List<Expression> params)Sets the function parameters.StringtoString()Creates a String representation of this Function with the function name and the arguments.- 
Methods inherited from class ExpressionAbstractevaluate
 - 
Methods inherited from interface Expressionevaluate
 
- 
 
- 
- 
- 
Field Detail- 
functionNameprotected FunctionName functionName FunctionName description for FilterCapabilities, may be provided by subclass in constructor, or will be lazily created based on name and number of arguments.
 
- 
 - 
Method Detail- 
getNamepublic String getName() Gets the name of this function.
 - 
getFunctionNamepublic FunctionName getFunctionName() Description copied from interface:FunctionAccess to the FunctionName description as used in a FilterCapabilities document.- Specified by:
- getFunctionNamein interface- Function
- Returns:
- FunctionName description, if available.
 
 - 
setNamepublic void setName(String name) Sets the name of the function.
 - 
getParameterspublic List<Expression> getParameters() Returns the function parameters.- Specified by:
- getParametersin interface- Function
 
 - 
evaluatepublic Object evaluate(Object object) Default implementation simply returns the fallbackValue.Please override this method to produce a value based on the provided arguments. - Specified by:
- evaluatein interface- Expression
- Overrides:
- evaluatein class- ExpressionAbstract
- Parameters:
- object- Object being evaluated; often a Feature
- Returns:
- value for the provided object
 
 - 
setParameterspublic void setParameters(List<Expression> params) Sets the function parameters.
 - 
setFallbackValuepublic void setFallbackValue(Literal fallbackValue) 
 - 
getFallbackValuepublic Literal getFallbackValue() Description copied from interface:FunctionThe value of the fallbackValue attribute is used as a default value, if the SE implementation does not support the function. If the implementation supports the function, then the result value is determined by executing the function.- Specified by:
- getFallbackValuein interface- Function
- Returns:
- Optional literal to use if an implementation for this function is not available.
 
 - 
acceptpublic Object accept(ExpressionVisitor visitor, Object extraData) Description copied from interface:ExpressionAccepts a visitor. Subclasses must implement with a method whose content is the following:return visitor.visit(this, extraData); - Specified by:
- acceptin interface- Expression
 
 - 
toStringpublic String toString() Creates a String representation of this Function with the function name and the arguments. The String created should be good for most subclasses
 - 
getParameterValueprotected Object getParameterValue(Object object, int argumentIndex) Evaluates a specific argument against the context, checking for required values and proper conversion.
 - 
getParameterValueprotected Object getParameterValue(Object object, int argumentIndex, Object defaultValue) Evaluates a specific argument against the context, checking for required values and proper conversion. This version accepts a default value
 - 
dispatchArgumentsprotected LinkedHashMap<String,Object> dispatchArguments(Object obj) Gathers up and groups the parameters to the function based on the declared parameters.This method calls #validateArguments()which enforces java style argument conventions for multi valued parameters. Basically enforcing that only the last argument in a function can be variable.
 - 
functionNameprotected static FunctionName functionName(String name, String ret, String... args) Convenience method for creating a function name from a set of strings describing the return and argument parameters of the function.The value of ret and each value of args is a string of the following structure: name[:type[:min,max]] Where:- name is the name of the parameter
- type is type (class name) of the parameter
- min is the minimum number of occurrences
- max is the maximum number of occurrences
 - foo
- foo:String
- foo:java.lang.Integer
- foo:Polygon:1,1
- foo:Polygon:1,
- foo:Polygon:,
 - java.lang
- org.locationtech.jts.geom
 - Parameters:
- name- The name of the function
- ret- The parameter specification of the return of the function
- args- The argument specifications of the function arguments
 
 
- 
 
-