Class AbstractConverter<D>
- Type Parameters:
- D- The default value type.
- All Implemented Interfaces:
- Converter<D>
- Direct Known Subclasses:
- ArrayConverter,- BooleanConverter,- CharacterConverter,- ClassConverter,- ColorConverter,- DateTimeConverter,- DimensionConverter,- DurationConverter,- EnumConverter,- FileConverter,- InetAddressConverter,- LocaleConverter,- LocalTimeConverter,- MonthDayConverter,- NumberConverter,- OffsetTimeConverter,- PathConverter,- PatternConverter,- PeriodConverter,- PointConverter,- StringConverter,- URIConverter,- URLConverter,- UUIDConverter,- YearConverter,- YearMonthConverter,- ZoneIdConverter,- ZoneOffsetConverter
Converter implementation that provides the structure for handling conversion to and from a specified type.
 
 This implementation provides the basic structure for converting to/from a specified type optionally using a default value or throwing a
 ConversionException if a conversion error occurs.
 
 Implementations should provide conversion to the specified type and from the specified type to a String value by implementing the following methods:
 
- convertToString(value)- convert to a String (default implementation uses the objects- toString()method).
- convertToType(Class, value)- convert to the specified type
 The default value has to be compliant to the default type of this converter - which is enforced by the generic type parameter. If a conversion is not
 possible and a default value is set, the converter tries to transform the default value to the requested target type. If this fails, a
 ConversionException if thrown.
 
- Since:
- 1.8.0
- 
Constructor SummaryConstructorsConstructorDescriptionConstructs a Converter that throws aConversionExceptionif an error occurs.AbstractConverter(D defaultValue) Constructs a Converter that returns a default value if an error occurs.
- 
Method SummaryModifier and TypeMethodDescriptionprotected ConversionExceptionconversionException(Class<?> type, Object value) Creates a standard conversion exception with a message indicating that the passed in value cannot be converted to the desired target type.<R> RConverts the input object into an output object of the specified type.protected ObjectconvertArray(Object value) Returns the first element from an Array (or Collection) or the value unchanged if not an Array (or Collection).protected StringconvertToString(Object value) Converts the input object into a String.protected abstract <R> RconvertToType(Class<R> type, Object value) Converts the input object into an output object of the specified type.protected ObjectgetDefault(Class<?> type) Gets the default value for conversions to the specified type.Gets the default type thisConverterhandles.protected <T> ThandleError(Class<T> type, Object value, Throwable cause) Handles Conversion Errors.protected <T> ThandleMissing(Class<T> type) Handles missing values.booleanTests whether a default value will be returned or exception thrown in the event of a conversion error.protected voidsetDefaultValue(D defaultValue) Sets the default value, converting as required.protected static StringtoLowerCase(Object value) Converts the given object to a lower-case string.toString()Converts this instance to a String.protected static StringConverts the given object to a lower-case string.protected static StringConverts the given object to a lower-case string.
- 
Constructor Details- 
AbstractConverterpublic AbstractConverter()Constructs a Converter that throws aConversionExceptionif an error occurs.
- 
AbstractConverterConstructs a Converter that returns a default value if an error occurs.- Parameters:
- defaultValue- The default value to be returned if the value to be converted is missing or an error occurs converting the value.
 
 
- 
- 
Method Details- 
toLowerCaseConverts the given object to a lower-case string.- Parameters:
- value- the input string.
- Returns:
- the given string trimmed and converter to lower-case.
 
- 
toStringConverts the given object to a lower-case string.- Parameters:
- value- the input string.
- Returns:
- the given string trimmed and converter to lower-case.
 
- 
toTrimConverts the given object to a lower-case string.- Parameters:
- value- the input string.
- Returns:
- the given string trimmed and converter to lower-case.
 
- 
conversionExceptionCreates a standard conversion exception with a message indicating that the passed in value cannot be converted to the desired target type.- Parameters:
- type- the target type
- value- the value to be converted
- Returns:
- a ConversionExceptionwith a standard message
- Since:
- 1.9
 
- 
convertConverts the input object into an output object of the specified type.- Specified by:
- convertin interface- Converter<D>
- Type Parameters:
- R- the result type.
- Parameters:
- type- Data type to which this value should be converted
- value- The input value to be converted
- Returns:
- The converted value.
- Throws:
- ConversionException- if conversion cannot be performed successfully and no default is specified.
 
- 
convertArrayReturns the first element from an Array (or Collection) or the value unchanged if not an Array (or Collection). This needs to be overridden for array/Collection converters.- Parameters:
- value- The value to convert
- Returns:
- The first element in an Array (or Collection) or the value unchanged if not an Array (or Collection)
 
- 
convertToStringConverts the input object into a String.N.B.This implementation simply uses the value's toString()method and should be overridden if a more sophisticated mechanism for conversion to a String is required.- Parameters:
- value- The input value to be converted.
- Returns:
- the converted String value.
- Throws:
- IllegalArgumentException- if an error occurs converting to a String
 
- 
convertToTypeConverts the input object into an output object of the specified type.Typical implementations will provide a minimum of String --> typeconversion.- Type Parameters:
- R- Target type of the conversion.
- Parameters:
- type- Data type to which this value should be converted.
- value- The input value to be converted.
- Returns:
- The converted value.
- Throws:
- Throwable- if an error occurs converting to the specified type
 
- 
getDefaultGets the default value for conversions to the specified type.- Parameters:
- type- Data type to which this value should be converted.
- Returns:
- The default value for the specified type.
 
- 
getDefaultTypeGets the default type thisConverterhandles.- Returns:
- The default type this Converterhandles.
 
- 
handleErrorHandles Conversion Errors.If a default value has been specified then it is returned otherwise a ConversionException is thrown. - Type Parameters:
- T- Target type of the conversion.
- Parameters:
- type- Data type to which this value should be converted.
- value- The input value to be converted
- cause- The exception thrown by the- convertmethod
- Returns:
- The default value.
- Throws:
- ConversionException- if no default value has been specified for this- Converter.
 
- 
handleMissingHandles missing values.If a default value has been specified, then it is returned (after a cast to the desired target class); otherwise a ConversionException is thrown. - Type Parameters:
- T- the desired target type
- Parameters:
- type- Data type to which this value should be converted.
- Returns:
- The default value.
- Throws:
- ConversionException- if no default value has been specified for this- Converter.
 
- 
isUseDefaultTests whether a default value will be returned or exception thrown in the event of a conversion error.- Returns:
- trueif a default value will be returned for conversion errors or- falseif a- ConversionExceptionwill be thrown.
 
- 
setDefaultValueSets the default value, converting as required.If the default value is different from the type the Converterhandles, it will be converted to the handled type.- Parameters:
- defaultValue- The default value to be returned if the value to be converted is missing or an error occurs converting the value.
- Throws:
- ConversionException- if an error occurs converting the default value
 
- 
toStringConverts this instance to a String.
 
-