org.hibernate.search.engine.cfg.spi.ConvertUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hibernate-search-engine Show documentation
Show all versions of hibernate-search-engine Show documentation
Hibernate Search engine, always required
/*
* Hibernate Search, full-text search for your domain model
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later
* See the lgpl.txt file in the root directory or .
*/
package org.hibernate.search.engine.cfg.spi;
import java.lang.invoke.MethodHandles;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.function.Function;
import java.util.regex.Pattern;
import java.util.stream.Collectors;
import org.hibernate.search.engine.environment.bean.BeanReference;
import org.hibernate.search.engine.logging.impl.Log;
import org.hibernate.search.util.common.SearchException;
import org.hibernate.search.util.common.logging.impl.LoggerFactory;
public final class ConvertUtils {
private static final Log log = LoggerFactory.make( Log.class, MethodHandles.lookup() );
private ConvertUtils() {
// Private constructor, do not use
}
/**
* Convert a property value to a given class, either by casting it if possible
* or by treating it as a string to be parsed.
*
* @param expectedType the expected type
* @param parser a parser from String to the expected type
* @param value the value to convert (a String)
* @param The type of the returned value.
* @return the converted value
* @throws SearchException for invalid values.
*/
public static T convert(Class expectedType, Function parser, Object value) {
if ( expectedType.isInstance( value ) ) {
return expectedType.cast( value );
}
try {
return parser.apply( (String) value );
}
catch (RuntimeException e) {
throw log.invalidPropertyValue( expectedType, e.getMessage(), e );
}
}
/**
* Convert a property value from String to boolean if necessary, allowing only either "true" or "false".
*
* @param value the value to convert (a Boolean, or a String to be parsed)
* @return true if value is "true", false if value is "false"
* @throws SearchException for invalid format or values.
*/
public static Boolean convertBoolean(Object value) {
try {
if ( value instanceof Boolean ) {
return (Boolean) value;
}
if ( value instanceof String ) {
return ParseUtils.parseBoolean( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidBooleanPropertyValue( e.getMessage(), e );
}
throw log.invalidBooleanPropertyValue( "", null );
}
/**
* Convert a property value from String to int if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted integer
* @throws SearchException for invalid format or values.
*/
public static Integer convertInteger(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).intValue();
}
if ( value instanceof String ) {
return ParseUtils.parseInteger( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidIntegerPropertyValue( e.getMessage(), e );
}
throw log.invalidIntegerPropertyValue( "", null );
}
/**
* Convert a property value from String to long if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted long
* @throws SearchException for invalid format or values.
*/
public static Long convertLong(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).longValue();
}
if ( value instanceof String ) {
return ParseUtils.parseLong( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidLongPropertyValue( e.getMessage(), e );
}
throw log.invalidLongPropertyValue( "", null );
}
/**
* Convert a property value from String to byte if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted byte
* @throws SearchException for invalid format or values.
*/
public static Byte convertByte(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).byteValue();
}
if ( value instanceof String ) {
return ParseUtils.parseByte( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( Byte.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( Byte.class, "", null );
}
/**
* Convert a property value from String to short if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted short
* @throws SearchException for invalid format or values.
*/
public static Short convertShort(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).shortValue();
}
if ( value instanceof String ) {
return ParseUtils.parseShort( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( Short.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( Short.class, "", null );
}
/**
* Convert a property value from String to float if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted float
* @throws SearchException for invalid format or values.
*/
public static Float convertFloat(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).floatValue();
}
if ( value instanceof String ) {
return ParseUtils.parseFloat( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( Float.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( Float.class, "", null );
}
/**
* Convert a property value from String to double if necessary.
*
* @param value the value to convert (a Number, or a String to be parsed)
* @return the converted double
* @throws SearchException for invalid format or values.
*/
public static Double convertDouble(Object value) {
try {
if ( value instanceof Number ) {
return ( (Number) value ).doubleValue();
}
if ( value instanceof String ) {
return ParseUtils.parseDouble( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( Double.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( Double.class, "", null );
}
/**
* Convert a property value from String to BigDecimal if necessary.
*
* @param value the value to convert (a BigDecimal, a Number, or a String to be parsed)
* @return the converted BigDecimal
* @throws SearchException for invalid format or values.
*/
public static BigDecimal convertBigDecimal(Object value) {
try {
if ( value instanceof BigDecimal ) {
return (BigDecimal) value;
}
if ( value instanceof Number ) {
return BigDecimal.valueOf( ( (Number) value ).doubleValue() );
}
if ( value instanceof String ) {
return ParseUtils.parseBigDecimal( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( BigDecimal.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( BigDecimal.class, "", null );
}
/**
* Convert a property value from String to BigInteger if necessary.
*
* @param value the value to convert (a BigInteger, a Number, or a String to be parsed)
* @return the converted BigInteger
* @throws SearchException for invalid format or values.
*/
public static BigInteger convertBigInteger(Object value) {
try {
if ( value instanceof BigInteger ) {
return (BigInteger) value;
}
if ( value instanceof Number ) {
return BigInteger.valueOf( ( (Number) value ).longValue() );
}
if ( value instanceof String ) {
return ParseUtils.parseBigInteger( (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidNumberPropertyValue( BigInteger.class, e.getMessage(), e );
}
throw log.invalidNumberPropertyValue( BigInteger.class, "", null );
}
public static BeanReference extends T> convertBeanReference(Class expectedType, Object value) {
try {
if ( expectedType.isInstance( value ) ) {
return BeanReference.ofInstance( expectedType.cast( value ) );
}
if ( value instanceof BeanReference ) {
return ( (BeanReference>) value ).asSubTypeOf( expectedType );
}
if ( value instanceof Class ) {
// Don't check the given class is assignable to the expected type now:
// the bean provider may return an instance of a subtype of the given class.
return BeanReference.of( (Class>) value ).asSubTypeOf( expectedType );
}
if ( value instanceof String ) {
return BeanReference.parse( expectedType, (String) value );
}
}
catch (RuntimeException e) {
throw log.invalidBeanReferencePropertyValue( expectedType, e.getMessage(), e );
}
throw log.invalidBeanReferencePropertyValue( expectedType, "", null );
}
public static List convertMultiValue(Pattern separatorPattern,
Function
© 2015 - 2025 Weber Informatics LLC | Privacy Policy