Package org.drools.core.base.evaluators
Class SetEvaluatorsDefinition
- java.lang.Object
-
- org.drools.core.base.evaluators.SetEvaluatorsDefinition
-
- All Implemented Interfaces:
Externalizable
,Serializable
,EvaluatorDefinition
,org.kie.api.runtime.rule.EvaluatorDefinition
public class SetEvaluatorsDefinition extends Object implements EvaluatorDefinition
This class defines all the set built in evaluators like contains, memberOf, etc.- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.drools.core.base.evaluators.EvaluatorDefinition
EvaluatorDefinition.Target
-
-
Field Summary
Fields Modifier and Type Field Description static Operator
CONTAINS
protected static String
containsOp
static Operator
EXCLUDES
protected static String
excludesOp
static Operator
MEMBEROF
protected static String
memberOfOp
static Operator
NOT_CONTAINS
static Operator
NOT_EXCLUDES
static Operator
NOT_MEMBEROF
-
Constructor Summary
Constructors Constructor Description SetEvaluatorsDefinition()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static SetEvaluatorsDefinition.ArrayContains
getArrayContains(Class cls)
Evaluator
getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText)
Returns the evaluator instance for the given type and the defined parameterTextEvaluator
getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText, EvaluatorDefinition.Target left, EvaluatorDefinition.Target right)
Returns the evaluator instance for the given type and the defined parameterTextEvaluator
getEvaluator(ValueType type, Operator operator)
Returns the evaluator instance for the given type and the defined parameterTextEvaluator
getEvaluator(ValueType type, Operator operator, String parameterText)
Returns the evaluator instance for the given type and the defined parameterTextString[]
getEvaluatorIds()
Returns the list of identifies this evaluator implementation supportsEvaluatorDefinition.Target
getTarget()
There are evaluators that operate on *fact* attributes, evaluators that operate on *fact handle* attributes, and evaluators that operate on both.boolean
isNegatable()
My apologies to English speakers if the word "negatable" does not exist. :) This method returns true if this evaluator supports negation.void
readExternal(ObjectInput in)
boolean
supportsType(ValueType type)
Returns true in case this evaluator supports operations over values of that specific type.void
writeExternal(ObjectOutput out)
-
-
-
Field Detail
-
containsOp
protected static final String containsOp
- See Also:
- Constant Field Values
-
excludesOp
protected static final String excludesOp
- See Also:
- Constant Field Values
-
memberOfOp
protected static final String memberOfOp
- See Also:
- Constant Field Values
-
CONTAINS
public static Operator CONTAINS
-
NOT_CONTAINS
public static Operator NOT_CONTAINS
-
EXCLUDES
public static Operator EXCLUDES
-
NOT_EXCLUDES
public static Operator NOT_EXCLUDES
-
MEMBEROF
public static Operator MEMBEROF
-
NOT_MEMBEROF
public static Operator NOT_MEMBEROF
-
-
Method Detail
-
readExternal
public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException
- Specified by:
readExternal
in interfaceExternalizable
- Throws:
IOException
ClassNotFoundException
-
writeExternal
public void writeExternal(ObjectOutput out) throws IOException
- Specified by:
writeExternal
in interfaceExternalizable
- Throws:
IOException
-
getEvaluator
public Evaluator getEvaluator(ValueType type, Operator operator)
Description copied from interface:EvaluatorDefinition
Returns the evaluator instance for the given type and the defined parameterText- Specified by:
getEvaluator
in interfaceEvaluatorDefinition
- Parameters:
type
- the type of the attributes this evaluator will operate on. This is important because the evaluator may do optimisations and type coercion based on the types it is evaluating. It is also possible that this evaluator does not support a given type.operator
- the operator implemented by the evaluator- Returns:
- an Evaluator instance capable of evaluating expressions between values of the given type, or null in case the type is not supported.
-
getEvaluator
public Evaluator getEvaluator(ValueType type, Operator operator, String parameterText)
Description copied from interface:EvaluatorDefinition
Returns the evaluator instance for the given type and the defined parameterText- Specified by:
getEvaluator
in interfaceEvaluatorDefinition
- Parameters:
type
- the type of the attributes this evaluator will operate on. This is important because the evaluator may do optimisations and type coercion based on the types it is evaluating. It is also possible that this evaluator does not support a given type.operator
- the operator implemented by the evaluatorparameterText
- some evaluators support parameters and these parameters are defined as a String that is parsed by the evaluator itself.- Returns:
- an Evaluator instance capable of evaluating expressions between values of the given type, or null in case the type is not supported.
-
getEvaluator
public Evaluator getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText)
Description copied from interface:EvaluatorDefinition
Returns the evaluator instance for the given type and the defined parameterText- Specified by:
getEvaluator
in interfaceEvaluatorDefinition
- Parameters:
type
- the type of the attributes this evaluator will operate on. This is important because the evaluator may do optimisations and type coercion based on the types it is evaluating. It is also possible that this evaluator does not support a given type.operatorId
- the string identifier of the evaluatorisNegated
- true if the evaluator instance to be returned is the negated version of the evaluator.parameterText
- some evaluators support parameters and these parameters are defined as a String that is parsed by the evaluator itself.- Returns:
- an Evaluator instance capable of evaluating expressions between values of the given type, or null in case the type is not supported.
-
getEvaluator
public Evaluator getEvaluator(ValueType type, String operatorId, boolean isNegated, String parameterText, EvaluatorDefinition.Target left, EvaluatorDefinition.Target right)
Description copied from interface:EvaluatorDefinition
Returns the evaluator instance for the given type and the defined parameterText- Specified by:
getEvaluator
in interfaceEvaluatorDefinition
- Parameters:
type
- the type of the attributes this evaluator will operate on. This is important because the evaluator may do optimisations and type coercion based on the types it is evaluating. It is also possible that this evaluator does not support a given type.operatorId
- the string identifier of the evaluatorisNegated
- true if the evaluator instance to be returned is the negated version of the evaluator.parameterText
- some evaluators support parameters and these parameters are defined as a String that is parsed by the evaluator itself.left
- the target of the evaluator on the Left side, i.e., on Rete terms, the previous binding or the actual value on the right side of the operator.right
- the target of the evaluator on the Right side, i.e., on Rete terms, the current pattern field.- Returns:
- an Evaluator instance capable of evaluating expressions between values of the given type, or null in case the type is not supported.
-
getEvaluatorIds
public String[] getEvaluatorIds()
Description copied from interface:EvaluatorDefinition
Returns the list of identifies this evaluator implementation supports- Specified by:
getEvaluatorIds
in interfaceEvaluatorDefinition
- Returns:
-
isNegatable
public boolean isNegatable()
Description copied from interface:EvaluatorDefinition
My apologies to English speakers if the word "negatable" does not exist. :) This method returns true if this evaluator supports negation. Example: the "matches" operator supports "not matches" and so is "negatable" (!?)- Specified by:
isNegatable
in interfaceEvaluatorDefinition
- Returns:
-
getTarget
public EvaluatorDefinition.Target getTarget()
Description copied from interface:EvaluatorDefinition
There are evaluators that operate on *fact* attributes, evaluators that operate on *fact handle* attributes, and evaluators that operate on both. This method returns the target of the current evaluator.- Specified by:
getTarget
in interfaceEvaluatorDefinition
- Returns:
- true if this evaluator operates on fact handle attributes and false if it operates on fact attributes
-
supportsType
public boolean supportsType(ValueType type)
Description copied from interface:EvaluatorDefinition
Returns true in case this evaluator supports operations over values of that specific type.- Specified by:
supportsType
in interfaceEvaluatorDefinition
- Returns:
-
getArrayContains
public static SetEvaluatorsDefinition.ArrayContains getArrayContains(Class cls)
-
-