added "converters" property to FormattingConversionServiceFactoryBean as well
This commit is contained in:
parent
bc6b707a22
commit
8334a03e03
|
|
@ -13,6 +13,7 @@
|
||||||
* See the License for the specific language governing permissions and
|
* See the License for the specific language governing permissions and
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.springframework.context.support;
|
package org.springframework.context.support;
|
||||||
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
@ -20,16 +21,15 @@ import java.util.Set;
|
||||||
import org.springframework.beans.factory.FactoryBean;
|
import org.springframework.beans.factory.FactoryBean;
|
||||||
import org.springframework.beans.factory.InitializingBean;
|
import org.springframework.beans.factory.InitializingBean;
|
||||||
import org.springframework.core.convert.ConversionService;
|
import org.springframework.core.convert.ConversionService;
|
||||||
import org.springframework.core.convert.converter.Converter;
|
|
||||||
import org.springframework.core.convert.converter.ConverterFactory;
|
|
||||||
import org.springframework.core.convert.converter.ConverterRegistry;
|
|
||||||
import org.springframework.core.convert.converter.GenericConverter;
|
|
||||||
import org.springframework.core.convert.support.ConversionServiceFactory;
|
import org.springframework.core.convert.support.ConversionServiceFactory;
|
||||||
|
import org.springframework.core.convert.support.GenericConversionService;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A factory for a ConversionService that installs default converters appropriate for most environments.
|
* A factory for a ConversionService that installs default converters appropriate for most environments.
|
||||||
* Set the <code>converters</code> property to supplement or override the default converters.
|
* Set the {@link #setConverters "converters"} property to supplement or override the default converters.
|
||||||
|
*
|
||||||
* @author Keith Donald
|
* @author Keith Donald
|
||||||
|
* @author Juergen Hoeller
|
||||||
* @since 3.0
|
* @since 3.0
|
||||||
* @see ConversionServiceFactory#createDefaultConversionService()
|
* @see ConversionServiceFactory#createDefaultConversionService()
|
||||||
*/
|
*/
|
||||||
|
|
@ -37,22 +37,35 @@ public class ConversionServiceFactoryBean implements FactoryBean<ConversionServi
|
||||||
|
|
||||||
private Set<Object> converters;
|
private Set<Object> converters;
|
||||||
|
|
||||||
private ConversionService conversionService;
|
private GenericConversionService conversionService;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Configure the set of custom Converters that should be added.
|
* Configure the set of custom converter objects that should be added:
|
||||||
|
* implementing {@link org.springframework.core.convert.converter.Converter},
|
||||||
|
* {@link org.springframework.core.convert.converter.ConverterFactory},
|
||||||
|
* or {@link org.springframework.core.convert.converter.GenericConverter}.
|
||||||
*/
|
*/
|
||||||
public void setConverters(Set<Object> converters) {
|
public void setConverters(Set<Object> converters) {
|
||||||
this.converters = converters;
|
this.converters = converters;
|
||||||
}
|
}
|
||||||
|
|
||||||
// implementing InitializingBean
|
|
||||||
|
|
||||||
public void afterPropertiesSet() {
|
public void afterPropertiesSet() {
|
||||||
this.conversionService = createConversionService();
|
this.conversionService = createConversionService();
|
||||||
registerConverters(this.converters, (ConverterRegistry) this.conversionService);
|
ConversionServiceFactory.addDefaultConverters(this.conversionService);
|
||||||
|
ConversionServiceFactory.registerConverters(this.converters, this.conversionService);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create the ConversionService instance returned by this factory bean.
|
||||||
|
* <p>Creates a simple {@link GenericConversionService} instance by default.
|
||||||
|
* Subclasses may override to customize the ConversionService instance that gets created.
|
||||||
|
*/
|
||||||
|
protected GenericConversionService createConversionService() {
|
||||||
|
return new GenericConversionService();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// implementing FactoryBean
|
// implementing FactoryBean
|
||||||
|
|
||||||
public ConversionService getObject() {
|
public ConversionService getObject() {
|
||||||
|
|
@ -60,41 +73,11 @@ public class ConversionServiceFactoryBean implements FactoryBean<ConversionServi
|
||||||
}
|
}
|
||||||
|
|
||||||
public Class<? extends ConversionService> getObjectType() {
|
public Class<? extends ConversionService> getObjectType() {
|
||||||
return ConversionService.class;
|
return GenericConversionService.class;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isSingleton() {
|
public boolean isSingleton() {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// subclassing hooks
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates the ConversionService instance returned by this factory bean.
|
|
||||||
* Creates a default conversion service instance by default.
|
|
||||||
* Subclasses may override to customize the ConversionService instance that gets created.
|
|
||||||
* @see ConversionServiceFactory#createDefaultConversionService()
|
|
||||||
*/
|
|
||||||
protected ConversionService createConversionService() {
|
|
||||||
return ConversionServiceFactory.createDefaultConversionService();
|
|
||||||
}
|
|
||||||
|
|
||||||
// internal helpers
|
|
||||||
|
|
||||||
private void registerConverters(Set<Object> converters, ConverterRegistry registry) {
|
|
||||||
if (converters != null) {
|
|
||||||
for (Object converter : converters) {
|
|
||||||
if (converter instanceof Converter<?, ?>) {
|
|
||||||
registry.addConverter((Converter<?, ?>) converter);
|
|
||||||
} else if (converter instanceof ConverterFactory<?, ?>) {
|
|
||||||
registry.addConverterFactory((ConverterFactory<?, ?>) converter);
|
|
||||||
} else if (converter instanceof GenericConverter) {
|
|
||||||
registry.addGenericConverter((GenericConverter) converter);
|
|
||||||
} else {
|
|
||||||
throw new IllegalArgumentException("Each converter must implement one of the Converter, ConverterFactory, or GenericConverter interfaces");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -51,12 +51,25 @@ public class FormattingConversionServiceFactoryBean
|
||||||
private static final boolean jodaTimePresent = ClassUtils.isPresent(
|
private static final boolean jodaTimePresent = ClassUtils.isPresent(
|
||||||
"org.joda.time.DateTime", FormattingConversionService.class.getClassLoader());
|
"org.joda.time.DateTime", FormattingConversionService.class.getClassLoader());
|
||||||
|
|
||||||
|
private Set<Object> converters;
|
||||||
|
|
||||||
private FormattingConversionService conversionService;
|
private FormattingConversionService conversionService;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure the set of custom converter objects that should be added:
|
||||||
|
* implementing {@link org.springframework.core.convert.converter.Converter},
|
||||||
|
* {@link org.springframework.core.convert.converter.ConverterFactory},
|
||||||
|
* or {@link org.springframework.core.convert.converter.GenericConverter}.
|
||||||
|
*/
|
||||||
|
public void setConverters(Set<Object> converters) {
|
||||||
|
this.converters = converters;
|
||||||
|
}
|
||||||
|
|
||||||
public void afterPropertiesSet() {
|
public void afterPropertiesSet() {
|
||||||
this.conversionService = new FormattingConversionService();
|
this.conversionService = new FormattingConversionService();
|
||||||
ConversionServiceFactory.addDefaultConverters(this.conversionService);
|
ConversionServiceFactory.addDefaultConverters(this.conversionService);
|
||||||
|
ConversionServiceFactory.registerConverters(this.converters, this.conversionService);
|
||||||
installFormatters(this.conversionService);
|
installFormatters(this.conversionService);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue