Class ExpressionState
java.lang.Object
org.springframework.expression.spel.ExpressionState
ExpressionState is for maintaining per-expression-evaluation state: any changes to
it are not seen by other expressions, but it gives a place to hold local variables and
for component expressions in a compound expression to communicate state. This is in
contrast to the EvaluationContext, which is shared amongst expression evaluations, and
any changes to it will be seen by other expressions or any code that chooses to ask
questions of the context.
It also acts as a place to define common utility routines that the various AST nodes might need.
- Since:
- 3.0
- Author:
- Andy Clement, Juergen Hoeller, Sam Brannen
-
Constructor Summary
ConstructorDescriptionExpressionState
(EvaluationContext context) ExpressionState
(EvaluationContext context, SpelParserConfiguration configuration) ExpressionState
(EvaluationContext context, TypedValue rootObject) ExpressionState
(EvaluationContext context, TypedValue rootObject, SpelParserConfiguration configuration) -
Method Summary
Modifier and TypeMethodDescriptionassignVariable
(String name, Supplier<TypedValue> valueSupplier) Assign the value created by the specifiedSupplier
to a named variable within the evaluation context.convertValue
(Object value, TypeDescriptor targetTypeDescriptor) convertValue
(TypedValue value, TypeDescriptor targetTypeDescriptor) void
Enter a new scope with a new root context object and a new local variable scope.void
Class<?>
The active context object is what unqualified references to properties/etc are resolved against.lookupVariable
(String name) Look up a named global variable in the evaluation context.void
void
void
setVariable
(String name, @Nullable Object value) Set a named variable in the evaluation context to a specified value.
-
Constructor Details
-
ExpressionState
-
ExpressionState
-
ExpressionState
-
ExpressionState
public ExpressionState(EvaluationContext context, TypedValue rootObject, SpelParserConfiguration configuration)
-
-
Method Details
-
getActiveContextObject
The active context object is what unqualified references to properties/etc are resolved against. -
pushActiveContextObject
-
popActiveContextObject
public void popActiveContextObject() -
getRootContextObject
-
getScopeRootContextObject
-
assignVariable
Assign the value created by the specifiedSupplier
to a named variable within the evaluation context.In contrast to
setVariable(String, Object)
, this method should only be invoked to support assignment within an expression.- Parameters:
name
- the name of the variable to assignvalueSupplier
- the supplier of the value to be assigned to the variable- Returns:
- a
TypedValue
wrapping the assigned value - Since:
- 5.2.24
- See Also:
-
setVariable
Set a named variable in the evaluation context to a specified value.In contrast to
assignVariable(String, Supplier)
, this method should only be invoked programmatically.- Parameters:
name
- the name of the variable to setvalue
- the value to be placed in the variable- See Also:
-
lookupVariable
Look up a named global variable in the evaluation context.- Parameters:
name
- the name of the variable to look up- Returns:
- a
TypedValue
containing the value of the variable, orTypedValue.NULL
if the variable does not exist - See Also:
-
getTypeComparator
-
findType
- Throws:
EvaluationException
-
getTypeConverter
-
convertValue
public Object convertValue(Object value, TypeDescriptor targetTypeDescriptor) throws EvaluationException - Throws:
EvaluationException
-
convertValue
public @Nullable Object convertValue(TypedValue value, TypeDescriptor targetTypeDescriptor) throws EvaluationException - Throws:
EvaluationException
-
enterScope
public void enterScope()Enter a new scope with a new root context object and a new local variable scope. -
exitScope
public void exitScope() -
operate
public TypedValue operate(Operation op, @Nullable Object left, @Nullable Object right) throws EvaluationException - Throws:
EvaluationException
-
getPropertyAccessors
-
getEvaluationContext
-
getConfiguration
-