Class TypeConverter
For example, to convert a String to an instance of MyDate, one can write
 
     ELProcessor elp = new ELProcessor();
     elp.getELManager().addELResolver(new TypeConverter() {
         Object convertToType(ELContext context, Object obj, Class<?> type) {
             if ((obj instanceof String) && type == MyDate.class) {
                 context.setPropertyResolved(obj, type);
                 return (obj == null)? null: new MyDate(obj.toString());
             }
             return null;
         }
      };
 
 - Since:
- Jakarta Expression Language 3.0
- 
Field SummaryFields inherited from class jakarta.el.ELResolverRESOLVABLE_AT_DESIGN_TIME, TYPE
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionabstract ObjectconvertToType(ELContext context, Object obj, Class<?> targetType) Converts an object to a specific type.Class<?>getCommonPropertyType(ELContext context, Object base) Returns the most general type that this resolver accepts for thepropertyargument, given abaseobject.getFeatureDescriptors(ELContext context, Object base) Returns information about the set of variables or properties that can be resolved for the givenbaseobject.Class<?>For a givenbaseandproperty, attempts to identify the most general type that is acceptable for an object to be passed as thevalueparameter in a future call to theELResolver.setValue(jakarta.el.ELContext, java.lang.Object, java.lang.Object, java.lang.Object)method.Attempts to resolve the givenpropertyobject on the givenbaseobject.booleanisReadOnly(ELContext context, Object base, Object property) For a givenbaseandproperty, attempts to determine whether a call toELResolver.setValue(jakarta.el.ELContext, java.lang.Object, java.lang.Object, java.lang.Object)will always fail.voidAttempts to set the value of the givenpropertyobject on the givenbaseobject.Methods inherited from class jakarta.el.ELResolverinvoke
- 
Constructor Details- 
TypeConverterpublic TypeConverter()
 
- 
- 
Method Details- 
getValueDescription copied from class:ELResolverAttempts to resolve the givenpropertyobject on the givenbaseobject.If this resolver handles the given (base, property) pair, the propertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller should ignore the return value.- Specified by:
- getValuein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object whose property value is to be returned, or- nullto resolve a top-level variable.
- property- The property or variable to be resolved.
- Returns:
- If the propertyResolvedproperty ofELContextwas set totrue, then the result of the variable or property resolution; otherwise undefined.
 
- 
getTypeDescription copied from class:ELResolverFor a givenbaseandproperty, attempts to identify the most general type that is acceptable for an object to be passed as thevalueparameter in a future call to theELResolver.setValue(jakarta.el.ELContext, java.lang.Object, java.lang.Object, java.lang.Object)method.If this resolver handles the given (base, property) pair, the propertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller should ignore the return value.This is not always the same as getValue().getClass(). For example, in the case of anArrayELResolver, thegetTypemethod will return the element type of the array, which might be a superclass of the type of the actual element that is currently in the specified array element.- Specified by:
- getTypein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object whose property value is to be analyzed, or- nullto analyze a top-level variable.
- property- The property or variable to return the acceptable type for.
- Returns:
- If the propertyResolvedproperty ofELContextwas set totrue, then the most general acceptable type; otherwise undefined.
 
- 
setValueDescription copied from class:ELResolverAttempts to set the value of the givenpropertyobject on the givenbaseobject.If this resolver handles the given (base, property) pair, the propertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller can safely assume no value has been set.- Specified by:
- setValuein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object whose property value is to be set, or- nullto set a top-level variable.
- property- The property or variable to be set.
- value- The value to set the property or variable to.
 
- 
isReadOnlyDescription copied from class:ELResolverFor a givenbaseandproperty, attempts to determine whether a call toELResolver.setValue(jakarta.el.ELContext, java.lang.Object, java.lang.Object, java.lang.Object)will always fail.If this resolver handles the given (base, property) pair, the propertyResolvedproperty of theELContextobject must be set totrueby the resolver, before returning. If this property is nottrueafter this method is called, the caller should ignore the return value.- Specified by:
- isReadOnlyin class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object whose property value is to be analyzed, or- nullto analyze a top-level variable.
- property- The property or variable to return the read-only status for.
- Returns:
- If the propertyResolvedproperty ofELContextwas set totrue, thentrueif the property is read-only orfalseif not; otherwise undefined.
 
- 
getFeatureDescriptorsDescription copied from class:ELResolverReturns information about the set of variables or properties that can be resolved for the givenbaseobject. One use for this method is to assist tools in auto-completion.If the baseparameter isnull, the resolver must enumerate the list of top-level variables it can resolve.The Iteratorreturned must contain zero or more instances ofFeatureDescriptor, in no guaranteed order. In the case of primitive types such asint, the valuenullmust be returned. This is to prevent the useless iteration through all possible primitive values. A return value ofnullindicates that this resolver does not handle the givenbaseobject or that the results are too complex to represent with this method and theELResolver.getCommonPropertyType(jakarta.el.ELContext, java.lang.Object)method should be used instead.Each FeatureDescriptorwill contain information about a single variable or property. In addition to the standard properties, theFeatureDescriptormust have two named attributes (as set by thesetValuemethod):- ELResolver.TYPE- The value of this named attribute must be an instance of- java.lang.Classand specify the runtime type of the variable or property.
- ELResolver.RESOLVABLE_AT_DESIGN_TIME- The value of this named attribute must be an instance of- java.lang.Booleanand indicates whether it is safe to attempt to resolve this property at design-time. For instance, it may be unsafe to attempt a resolution at design time if the- ELResolverneeds access to a resource that is only available at runtime and no acceptable simulated value can be provided.
 The caller should be aware that the Iteratorreturned might iterate through a very large or even infinitely large set of properties. Care should be taken by the caller to not get stuck in an infinite loop.This is a "best-effort" list. Not all ELResolvers will return completely accurate results, but all must be callable at both design-time and runtime (i.e. whether or notBeans.isDesignTime()returnstrue), without causing errors.The propertyResolvedproperty of theELContextis not relevant to this method. The results of allELResolvers are concatenated in the case of composite resolvers.- Specified by:
- getFeatureDescriptorsin class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object whose set of valid properties is to be enumerated, or- nullto enumerate the set of top-level variables that this resolver can evaluate.
- Returns:
- An Iteratorcontaining zero or more (possibly infinitely more)FeatureDescriptorobjects, ornullif this resolver does not handle the givenbaseobject or that the results are too complex to represent with this method
- See Also:
 
- 
getCommonPropertyTypeDescription copied from class:ELResolverReturns the most general type that this resolver accepts for thepropertyargument, given abaseobject. One use for this method is to assist tools in auto-completion.This assists tools in auto-completion and also provides a way to express that the resolver accepts a primitive value, such as an integer index into an array. For example, the ArrayELResolverwill accept anyintas aproperty, so the return value would beInteger.class.- Specified by:
- getCommonPropertyTypein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- base- The base object to return the most general property type for, or- nullto enumerate the set of top-level variables that this resolver can evaluate.
- Returns:
- nullif this- ELResolverdoes not know how to handle the given- baseobject; otherwise- Object.classif any type of- propertyis accepted; otherwise the most general- propertytype accepted for the given- base.
 
- 
convertToTypeConverts an object to a specific type.An ELExceptionis thrown if an error occurs during the conversion.- Overrides:
- convertToTypein class- ELResolver
- Parameters:
- context- The context of this evaluation.
- obj- The object to convert.
- targetType- The target type for the conversion.
- Returns:
- object converted to targetType
- Throws:
- ELException- thrown if errors occur.
 
 
-