Class Indexer
Indexer can index into some proceeding structure to access a
particular element of the structure.
Numerical index values are zero-based, such as when accessing the nth element of an array in Java.
Supported Structures
- Arrays: the nth element
- Collections (lists, sets, etc.): the nth element
- Strings: the nth character as a String
- Maps: the value for the specified key
- Objects: the property with the specified name
- Custom Structures: via registered IndexAccessorimplementations
Null-safe Indexing
As of Spring Framework 6.2, null-safe indexing is supported via the '?.'
operator. For example, 'colors?.[0]' will evaluate to null if
colors is null and will otherwise evaluate to the 0th
color. As of Spring Framework 7.0, null-safe indexing also applies when
indexing into a structure contained in an Optional. For example, if
colors is of type Optional<Colors>, the expression
'colors?.[0]' will evaluate to null if colors is
null or empty and will otherwise evaluate
to the 0th color, effectively colors.get()[0].
- Since:
- 3.0
- Author:
- Andy Clement, Phillip Webb, Stephane Nicoll, Sam Brannen
- See Also:
- 
Field SummaryFields inherited from class SpelNodeImplchildren, exitTypeDescriptorFields inherited from interface OpcodesAALOAD, 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 SummaryConstructorsConstructorDescriptionIndexer(boolean nullSafe, int startPos, int endPos, SpelNodeImpl indexExpression) Create anIndexerwith the given null-safe flag, start position, end position, and index expression.
- 
Method SummaryModifier and TypeMethodDescriptionvoidgenerateCode(MethodVisitor mv, CodeFlow cf) Generate the bytecode for this node into the suppliedMethodVisitor.getValueInternal(ExpressionState state) protected ValueRefgetValueRef(ExpressionState state) booleanDetermine if this node can be compiled to bytecode.final booleanDoes this node represent a null-safe index operation?booleanisWritable(ExpressionState expressionState) 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 SpelNodeImplgenerateCodeForArgument, generateCodeForArguments, generateCodeForArguments, getChild, getChildCount, getEndPosition, getExitDescriptor, getObjectClass, getStartPosition, getTypedValue, getValue, getValue, nextChildIs, setValue
- 
Constructor Details- 
IndexerCreate anIndexerwith the given null-safe flag, start position, end position, and index expression.- Since:
- 6.2
 
 
- 
- 
Method Details- 
isNullSafepublic final boolean isNullSafe()Does this node represent a null-safe index operation?- Overrides:
- isNullSafein class- SpelNodeImpl
- Returns:
- trueif this node is the target of a null-safe operation
- Since:
- 6.2
 
- 
getValueInternal- Specified by:
- getValueInternalin class- SpelNodeImpl
- Throws:
- EvaluationException
 
- 
setValueInternalpublic 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 class- SpelNodeImpl
- 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
 
- 
isWritableDescription copied from interface:SpelNodeDetermine if this expression node will support a setValue() call.- Specified by:
- isWritablein interface- SpelNode
- Overrides:
- isWritablein class- SpelNodeImpl
- Parameters:
- expressionState- the current expression state (includes the context)
- Returns:
- true if the expression node will allow setValue()
- Throws:
- SpelEvaluationException
 
- 
getValueRef- Overrides:
- getValueRefin class- SpelNodeImpl
- Throws:
- EvaluationException
 
- 
isCompilablepublic 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:
 
- 
generateCodeDescription 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 ASM- MethodVisitorinto which code should be generated
- cf- a context object with information about what is on the stack
- See Also:
 
- 
toStringAST
 
-