Class CompoundExpression
property1.property2.methodOne() or
property1?.property2?.methodOne() when the null-safe navigation
operator is used.
May also contain array/collection/map indexers, such as
property1[0].property2['key'].
- Since:
- 3.0
- Author:
- Andy Clement, Sam Brannen
-
Field Summary
Fields inherited from class SpelNodeImpl
children, exitTypeDescriptorFields inherited from interface Opcodes
AALOAD, AASTORE, ACC_ABSTRACT, ACC_ANNOTATION, ACC_BRIDGE, ACC_DEPRECATED, ACC_ENUM, ACC_FINAL, ACC_INTERFACE, ACC_MANDATED, ACC_MODULE, ACC_NATIVE, ACC_OPEN, ACC_PRIVATE, ACC_PROTECTED, ACC_PUBLIC, ACC_RECORD, ACC_STATIC, ACC_STATIC_PHASE, ACC_STRICT, ACC_SUPER, ACC_SYNCHRONIZED, ACC_SYNTHETIC, ACC_TRANSIENT, ACC_TRANSITIVE, ACC_VARARGS, ACC_VOLATILE, ACONST_NULL, ALOAD, ANEWARRAY, ARETURN, ARRAYLENGTH, ASM10_EXPERIMENTAL, ASM4, ASM5, ASM6, ASM7, ASM8, ASM9, ASTORE, ATHROW, BALOAD, BASTORE, BIPUSH, CALOAD, CASTORE, CHECKCAST, D2F, D2I, D2L, DADD, DALOAD, DASTORE, DCMPG, DCMPL, DCONST_0, DCONST_1, DDIV, DLOAD, DMUL, DNEG, DOUBLE, DREM, DRETURN, DSTORE, DSUB, DUP, DUP_X1, DUP_X2, DUP2, DUP2_X1, DUP2_X2, F_APPEND, F_CHOP, F_FULL, F_NEW, F_SAME, F_SAME1, F2D, F2I, F2L, FADD, FALOAD, FASTORE, FCMPG, FCMPL, FCONST_0, FCONST_1, FCONST_2, FDIV, FLOAD, FLOAT, FMUL, FNEG, FREM, FRETURN, FSTORE, FSUB, GETFIELD, GETSTATIC, GOTO, H_GETFIELD, H_GETSTATIC, H_INVOKEINTERFACE, H_INVOKESPECIAL, H_INVOKESTATIC, H_INVOKEVIRTUAL, H_NEWINVOKESPECIAL, H_PUTFIELD, H_PUTSTATIC, I2B, I2C, I2D, I2F, I2L, I2S, IADD, IALOAD, IAND, IASTORE, ICONST_0, ICONST_1, ICONST_2, ICONST_3, ICONST_4, ICONST_5, ICONST_M1, IDIV, IF_ACMPEQ, IF_ACMPNE, IF_ICMPEQ, IF_ICMPGE, IF_ICMPGT, IF_ICMPLE, IF_ICMPLT, IF_ICMPNE, IFEQ, IFGE, IFGT, IFLE, IFLT, IFNE, IFNONNULL, IFNULL, IINC, ILOAD, IMUL, INEG, INSTANCEOF, INTEGER, INVOKEDYNAMIC, INVOKEINTERFACE, INVOKESPECIAL, INVOKESTATIC, INVOKEVIRTUAL, IOR, IREM, IRETURN, ISHL, ISHR, ISTORE, ISUB, IUSHR, IXOR, JSR, L2D, L2F, L2I, LADD, LALOAD, LAND, LASTORE, LCMP, LCONST_0, LCONST_1, LDC, LDIV, LLOAD, LMUL, LNEG, LONG, LOOKUPSWITCH, LOR, LREM, LRETURN, LSHL, LSHR, LSTORE, LSUB, LUSHR, LXOR, MONITORENTER, MONITOREXIT, MULTIANEWARRAY, NEW, NEWARRAY, NOP, NULL, POP, POP2, PUTFIELD, PUTSTATIC, RET, RETURN, SALOAD, SASTORE, SIPUSH, SOURCE_DEPRECATED, SOURCE_MASK, SWAP, T_BOOLEAN, T_BYTE, T_CHAR, T_DOUBLE, T_FLOAT, T_INT, T_LONG, T_SHORT, TABLESWITCH, TOP, UNINITIALIZED_THIS, V_PREVIEW, V1_1, V1_2, V1_3, V1_4, V1_5, V1_6, V1_7, V1_8, V10, V11, V12, V13, V14, V15, V16, V17, V18, V19, V20, V21, V22, V23, V24, V25, V9 -
Constructor Summary
ConstructorsConstructorDescriptionCompoundExpression(int startPos, int endPos, SpelNodeImpl... expressionComponents) -
Method Summary
Modifier and TypeMethodDescriptionvoidgenerateCode(MethodVisitor mv, CodeFlow cf) Generate the bytecode for this node into the suppliedMethodVisitor.getValueInternal(ExpressionState state) Evaluates a compound expression.protected ValueRefgetValueRef(ExpressionState state) booleanDetermine if this node can be compiled to bytecode.booleanisWritable(ExpressionState state) Determine if this expression node will support a setValue() call.setValueInternal(ExpressionState state, Supplier<TypedValue> valueSupplier) Evaluate the expression to a node and then set the new value created by the specifiedSupplieron that node.Return the string form of this AST node.Methods inherited from class SpelNodeImpl
generateCodeForArgument, generateCodeForArguments, generateCodeForArguments, getChild, getChildCount, getEndPosition, getExitDescriptor, getObjectClass, getStartPosition, getTypedValue, getValue, getValue, isNullSafe, nextChildIs, setValue
-
Constructor Details
-
CompoundExpression
-
-
Method Details
-
getValueRef
- Overrides:
getValueRefin classSpelNodeImpl- Throws:
EvaluationException
-
getValueInternal
Evaluates a compound expression. This involves evaluating each piece in turn and the return value from each piece is the active context object for the subsequent piece.- Specified by:
getValueInternalin classSpelNodeImpl- Parameters:
state- the state in which the expression is being evaluated- Returns:
- the final value from the last piece of the compound expression
- Throws:
EvaluationException
-
setValueInternal
public TypedValue setValueInternal(ExpressionState state, Supplier<TypedValue> valueSupplier) throws EvaluationException Description copied from class:SpelNodeImplEvaluate the expression to a node and then set the new value created by the specifiedSupplieron that node.For example, if the expression evaluates to a property reference, then the property will be set to the new value.
Favor this method over
SpelNodeImpl.setValue(ExpressionState, Object)when the value should be lazily computed.By default, this method throws a
SpelEvaluationException, effectively disabling this feature. Subclasses may override this method to provide an actual implementation.- Overrides:
setValueInternalin classSpelNodeImpl- Parameters:
state- the current expression state (includes the context)valueSupplier- a supplier of the new value- Throws:
EvaluationException- if any problem occurs evaluating the expression or setting the new value
-
isWritable
Description copied from interface:SpelNodeDetermine if this expression node will support a setValue() call.- Specified by:
isWritablein interfaceSpelNode- Overrides:
isWritablein classSpelNodeImpl- Parameters:
state- the current expression state (includes the context)- Returns:
- true if the expression node will allow setValue()
- Throws:
EvaluationException- if something went wrong trying to determine if the node supports writing
-
toStringAST
-
isCompilable
public boolean isCompilable()Description copied from interface:SpelNodeDetermine if this node can be compiled to bytecode.The reasoning in each node may be different but will typically involve checking whether the exit type descriptor of the node is known and any relevant child nodes are compilable.
The default implementation returns
false.If you override this method, you must also override
SpelNode.generateCode(MethodVisitor, CodeFlow).- Returns:
trueif this node can be compiled to bytecode- See Also:
-
generateCode
Description copied from interface:SpelNodeGenerate the bytecode for this node into the suppliedMethodVisitor.Context information about the current expression being compiled is available in the supplied
CodeFlowobject — for example, information about the type of the object currently on the stack.This method will not be invoked unless
SpelNode.isCompilable()returnstrue.The default implementation throws an
IllegalStateExceptionsinceSpelNode.isCompilable()returnsfalseby default.If you override this method, you must also override
SpelNode.isCompilable().- Parameters:
mv- the ASMMethodVisitorinto which code should be generatedcf- a context object with information about what is on the stack- See Also:
-