clean up a bunch of generics-related warnings
This commit is contained in:
parent
86cdf67016
commit
bedd31b36e
|
@ -101,9 +101,8 @@ public abstract class AbstractConverterDescriptor implements ConverterDescriptor
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SuppressWarnings({ "unchecked", "rawtypes" })
|
public JpaAttributeConverter<?,?> createJpaAttributeConverter(JpaAttributeConverterCreationContext context) {
|
||||||
public JpaAttributeConverter createJpaAttributeConverter(JpaAttributeConverterCreationContext context) {
|
final JavaType<?> converterJtd = context
|
||||||
final JavaType<Object> converterJtd = context
|
|
||||||
.getJavaTypeRegistry()
|
.getJavaTypeRegistry()
|
||||||
.getDescriptor( getAttributeConverterClass() );
|
.getDescriptor( getAttributeConverterClass() );
|
||||||
|
|
||||||
|
|
|
@ -45,5 +45,5 @@ public interface ConverterDescriptor {
|
||||||
/**
|
/**
|
||||||
* Factory for the runtime representation of the converter
|
* Factory for the runtime representation of the converter
|
||||||
*/
|
*/
|
||||||
JpaAttributeConverter createJpaAttributeConverter(JpaAttributeConverterCreationContext context);
|
JpaAttributeConverter<?,?> createJpaAttributeConverter(JpaAttributeConverterCreationContext context);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,26 +17,26 @@ import org.hibernate.type.descriptor.jdbc.JdbcType;
|
||||||
/**
|
/**
|
||||||
* @author Steve Ebersole
|
* @author Steve Ebersole
|
||||||
*/
|
*/
|
||||||
public class InferredBasicValueResolution<J> implements BasicValue.Resolution<J> {
|
public class InferredBasicValueResolution<J,T> implements BasicValue.Resolution<J> {
|
||||||
private JavaType<J> domainJtd;
|
private final JavaType<J> domainJtd;
|
||||||
private JavaType<J> relationalJtd;
|
private final JavaType<T> relationalJtd;
|
||||||
private JdbcType jdbcType;
|
private final JdbcType jdbcType;
|
||||||
|
|
||||||
private MutabilityPlan mutabilityPlan;
|
private final MutabilityPlan<J> mutabilityPlan;
|
||||||
|
|
||||||
private JdbcMapping jdbcMapping;
|
private final JdbcMapping jdbcMapping;
|
||||||
private BasicValueConverter valueConverter;
|
private final BasicValueConverter<J,T> valueConverter;
|
||||||
|
|
||||||
private final BasicType<J> legacyType;
|
private final BasicType<J> legacyType;
|
||||||
|
|
||||||
public InferredBasicValueResolution(
|
public InferredBasicValueResolution(
|
||||||
JdbcMapping jdbcMapping,
|
JdbcMapping jdbcMapping,
|
||||||
JavaType<J> domainJtd,
|
JavaType<J> domainJtd,
|
||||||
JavaType<J> relationalJtd,
|
JavaType<T> relationalJtd,
|
||||||
JdbcType jdbcType,
|
JdbcType jdbcType,
|
||||||
BasicValueConverter valueConverter,
|
BasicValueConverter<J,T> valueConverter,
|
||||||
BasicType<J> legacyType,
|
BasicType<J> legacyType,
|
||||||
MutabilityPlan mutabilityPlan) {
|
MutabilityPlan<J> mutabilityPlan) {
|
||||||
this.jdbcMapping = jdbcMapping;
|
this.jdbcMapping = jdbcMapping;
|
||||||
this.legacyType = legacyType;
|
this.legacyType = legacyType;
|
||||||
this.domainJtd = domainJtd;
|
this.domainJtd = domainJtd;
|
||||||
|
@ -52,7 +52,7 @@ public class InferredBasicValueResolution<J> implements BasicValue.Resolution<J>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BasicType getLegacyResolvedBasicType() {
|
public BasicType<J> getLegacyResolvedBasicType() {
|
||||||
return legacyType;
|
return legacyType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ public class InferredBasicValueResolution<J> implements BasicValue.Resolution<J>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BasicValueConverter getValueConverter() {
|
public BasicValueConverter<J,T> getValueConverter() {
|
||||||
return valueConverter;
|
return valueConverter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,6 @@ import org.hibernate.mapping.BasicValue;
|
||||||
import org.hibernate.mapping.Column;
|
import org.hibernate.mapping.Column;
|
||||||
import org.hibernate.mapping.Selectable;
|
import org.hibernate.mapping.Selectable;
|
||||||
import org.hibernate.mapping.Table;
|
import org.hibernate.mapping.Table;
|
||||||
import org.hibernate.metamodel.mapping.JdbcMapping;
|
|
||||||
import org.hibernate.metamodel.model.convert.internal.NamedEnumValueConverter;
|
import org.hibernate.metamodel.model.convert.internal.NamedEnumValueConverter;
|
||||||
import org.hibernate.metamodel.model.convert.internal.OrdinalEnumValueConverter;
|
import org.hibernate.metamodel.model.convert.internal.OrdinalEnumValueConverter;
|
||||||
import org.hibernate.type.AdjustableBasicType;
|
import org.hibernate.type.AdjustableBasicType;
|
||||||
|
@ -45,12 +44,11 @@ public class InferredBasicValueResolver {
|
||||||
/**
|
/**
|
||||||
* Create an inference-based resolution
|
* Create an inference-based resolution
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings({"unchecked", "rawtypes"})
|
public static <T> BasicValue.Resolution<T> from(
|
||||||
public static BasicValue.Resolution from(
|
|
||||||
Function<TypeConfiguration, BasicJavaType> explicitJavaTypeAccess,
|
Function<TypeConfiguration, BasicJavaType> explicitJavaTypeAccess,
|
||||||
Function<TypeConfiguration, JdbcType> explicitSqlTypeAccess,
|
Function<TypeConfiguration, JdbcType> explicitSqlTypeAccess,
|
||||||
Type resolvedJavaType,
|
Type resolvedJavaType,
|
||||||
Supplier<JavaType> reflectedJtdResolver,
|
Supplier<JavaType<T>> reflectedJtdResolver,
|
||||||
JdbcTypeIndicators stdIndicators,
|
JdbcTypeIndicators stdIndicators,
|
||||||
Table table,
|
Table table,
|
||||||
Selectable selectable,
|
Selectable selectable,
|
||||||
|
@ -58,17 +56,21 @@ public class InferredBasicValueResolver {
|
||||||
String propertyName,
|
String propertyName,
|
||||||
TypeConfiguration typeConfiguration) {
|
TypeConfiguration typeConfiguration) {
|
||||||
|
|
||||||
final BasicJavaType explicitJavaType = explicitJavaTypeAccess != null ? explicitJavaTypeAccess.apply( typeConfiguration ) : null;
|
final BasicJavaType<T> explicitJavaType = explicitJavaTypeAccess != null
|
||||||
final JdbcType explicitJdbcType = explicitSqlTypeAccess != null ? explicitSqlTypeAccess.apply( typeConfiguration ) : null;
|
? explicitJavaTypeAccess.apply( typeConfiguration )
|
||||||
|
: null;
|
||||||
|
final JdbcType explicitJdbcType = explicitSqlTypeAccess
|
||||||
|
!= null ? explicitSqlTypeAccess.apply( typeConfiguration )
|
||||||
|
: null;
|
||||||
|
|
||||||
final BasicJavaType reflectedJtd = (BasicJavaType) reflectedJtdResolver.get();
|
final JavaType<T> reflectedJtd = reflectedJtdResolver.get();
|
||||||
|
|
||||||
// NOTE : the distinction that is made below wrt `explicitJavaType` and `reflectedJtd` is
|
// NOTE : the distinction that is made below wrt `explicitJavaType` and `reflectedJtd` is
|
||||||
// needed temporarily to trigger "legacy resolution" versus "ORM6 resolution. Yes, it
|
// needed temporarily to trigger "legacy resolution" versus "ORM6 resolution. Yes, it
|
||||||
// makes the code a little more complicated but the benefit is well worth it - saving memory
|
// makes the code a little more complicated but the benefit is well worth it - saving memory
|
||||||
|
|
||||||
final BasicType<?> jdbcMapping;
|
final BasicType<T> jdbcMapping;
|
||||||
final BasicType<?> legacyType;
|
final BasicType<T> legacyType;
|
||||||
|
|
||||||
if ( explicitJavaType != null ) {
|
if ( explicitJavaType != null ) {
|
||||||
// we have an explicit JavaType
|
// we have an explicit JavaType
|
||||||
|
@ -99,7 +101,7 @@ public class InferredBasicValueResolver {
|
||||||
}
|
}
|
||||||
else if ( explicitJavaType instanceof TemporalJavaType ) {
|
else if ( explicitJavaType instanceof TemporalJavaType ) {
|
||||||
return fromTemporal(
|
return fromTemporal(
|
||||||
(TemporalJavaType) reflectedJtd,
|
(TemporalJavaType<T>) reflectedJtd,
|
||||||
explicitJavaType,
|
explicitJavaType,
|
||||||
null,
|
null,
|
||||||
resolvedJavaType,
|
resolvedJavaType,
|
||||||
|
@ -107,8 +109,9 @@ public class InferredBasicValueResolver {
|
||||||
typeConfiguration
|
typeConfiguration
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
else if ( explicitJavaType instanceof SerializableJavaType || explicitJavaType.getJavaType() instanceof Serializable ) {
|
else if ( explicitJavaType instanceof SerializableJavaType
|
||||||
legacyType = new SerializableType<>( explicitJavaType );
|
|| explicitJavaType.getJavaType() instanceof Serializable ) {
|
||||||
|
legacyType = new SerializableType( explicitJavaType );
|
||||||
jdbcMapping = legacyType;
|
jdbcMapping = legacyType;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -154,7 +157,7 @@ public class InferredBasicValueResolver {
|
||||||
}
|
}
|
||||||
else if ( reflectedJtd instanceof TemporalJavaType ) {
|
else if ( reflectedJtd instanceof TemporalJavaType ) {
|
||||||
return fromTemporal(
|
return fromTemporal(
|
||||||
(TemporalJavaType) reflectedJtd,
|
(TemporalJavaType<T>) reflectedJtd,
|
||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
resolvedJavaType,
|
resolvedJavaType,
|
||||||
|
@ -165,7 +168,8 @@ public class InferredBasicValueResolver {
|
||||||
else {
|
else {
|
||||||
// see if there is a registered BasicType for this JavaType and, if so, use it.
|
// see if there is a registered BasicType for this JavaType and, if so, use it.
|
||||||
// this mimics the legacy handling
|
// this mimics the legacy handling
|
||||||
final BasicType registeredType = typeConfiguration.getBasicTypeRegistry().getRegisteredType( reflectedJtd.getJavaType() );
|
final BasicType<T> registeredType = typeConfiguration.getBasicTypeRegistry()
|
||||||
|
.getRegisteredType( reflectedJtd.getJavaType() );
|
||||||
|
|
||||||
if ( registeredType != null ) {
|
if ( registeredType != null ) {
|
||||||
// so here is the legacy resolution
|
// so here is the legacy resolution
|
||||||
|
@ -183,8 +187,9 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
legacyType = jdbcMapping;
|
legacyType = jdbcMapping;
|
||||||
}
|
}
|
||||||
else if ( reflectedJtd instanceof SerializableJavaType || Serializable.class.isAssignableFrom( reflectedJtd.getJavaTypeClass() ) ) {
|
else if ( reflectedJtd instanceof SerializableJavaType
|
||||||
legacyType = new SerializableType<>( reflectedJtd );
|
|| Serializable.class.isAssignableFrom( reflectedJtd.getJavaTypeClass() ) ) {
|
||||||
|
legacyType = new SerializableType( reflectedJtd );
|
||||||
jdbcMapping = legacyType;
|
jdbcMapping = legacyType;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -217,17 +222,20 @@ public class InferredBasicValueResolver {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final BasicJavaType recommendedJtd = explicitJdbcType.getJdbcRecommendedJavaTypeMapping(
|
|
||||||
|
final BasicJavaType<T> recommendedJtd = explicitJdbcType.getJdbcRecommendedJavaTypeMapping(
|
||||||
length,
|
length,
|
||||||
scale,
|
scale,
|
||||||
typeConfiguration
|
typeConfiguration
|
||||||
);
|
);
|
||||||
final BasicType<?> resolved = typeConfiguration.getBasicTypeRegistry().resolve(
|
|
||||||
|
jdbcMapping = resolveSqlTypeIndicators(
|
||||||
|
stdIndicators,
|
||||||
|
typeConfiguration.getBasicTypeRegistry().resolve(
|
||||||
recommendedJtd,
|
recommendedJtd,
|
||||||
explicitJdbcType
|
explicitJdbcType
|
||||||
);
|
),
|
||||||
|
recommendedJtd );
|
||||||
jdbcMapping = resolveSqlTypeIndicators( stdIndicators, resolved, recommendedJtd );
|
|
||||||
legacyType = jdbcMapping;
|
legacyType = jdbcMapping;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -252,7 +260,7 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new InferredBasicValueResolution(
|
return new InferredBasicValueResolution<>(
|
||||||
jdbcMapping,
|
jdbcMapping,
|
||||||
jdbcMapping.getJavaTypeDescriptor(),
|
jdbcMapping.getJavaTypeDescriptor(),
|
||||||
jdbcMapping.getJavaTypeDescriptor(),
|
jdbcMapping.getJavaTypeDescriptor(),
|
||||||
|
@ -263,14 +271,13 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("rawtypes")
|
public static <T> BasicType<T> resolveSqlTypeIndicators(
|
||||||
public static BasicType<?> resolveSqlTypeIndicators(
|
|
||||||
JdbcTypeIndicators stdIndicators,
|
JdbcTypeIndicators stdIndicators,
|
||||||
BasicType<?> resolved,
|
BasicType<T> resolved,
|
||||||
JavaType<?> domainJtd) {
|
JavaType<T> domainJtd) {
|
||||||
if ( resolved instanceof AdjustableBasicType ) {
|
if ( resolved instanceof AdjustableBasicType ) {
|
||||||
final AdjustableBasicType indicatorCapable = (AdjustableBasicType) resolved;
|
final AdjustableBasicType<T> indicatorCapable = (AdjustableBasicType<T>) resolved;
|
||||||
final BasicType indicatedType = indicatorCapable.resolveIndicatedType( stdIndicators, domainJtd );
|
final BasicType<T> indicatedType = indicatorCapable.resolveIndicatedType( stdIndicators, domainJtd );
|
||||||
return indicatedType != null ? indicatedType : resolved;
|
return indicatedType != null ? indicatedType : resolved;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -278,10 +285,9 @@ public class InferredBasicValueResolver {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("rawtypes")
|
public static <E extends Enum<E>> InferredBasicValueResolution<E,?> fromEnum(
|
||||||
public static <E extends Enum<E>> InferredBasicValueResolution fromEnum(
|
|
||||||
EnumJavaType<E> enumJavaType,
|
EnumJavaType<E> enumJavaType,
|
||||||
BasicJavaType explicitJavaType,
|
BasicJavaType<?> explicitJavaType,
|
||||||
JdbcType explicitJdbcType,
|
JdbcType explicitJdbcType,
|
||||||
JdbcTypeIndicators stdIndicators,
|
JdbcTypeIndicators stdIndicators,
|
||||||
TypeConfiguration typeConfiguration) {
|
TypeConfiguration typeConfiguration) {
|
||||||
|
@ -291,54 +297,33 @@ public class InferredBasicValueResolver {
|
||||||
|
|
||||||
switch ( enumStyle ) {
|
switch ( enumStyle ) {
|
||||||
case STRING: {
|
case STRING: {
|
||||||
final JavaType<?> relationalJtd;
|
return stringEnumValueResolution(
|
||||||
if ( explicitJavaType != null ) {
|
|
||||||
if ( ! String.class.isAssignableFrom( explicitJavaType.getJavaTypeClass() ) ) {
|
|
||||||
throw new MappingException(
|
|
||||||
"Explicit JavaType [" + explicitJavaType +
|
|
||||||
"] applied to enumerated value with EnumType#STRING" +
|
|
||||||
" should handle `java.lang.String` as its relational type descriptor"
|
|
||||||
);
|
|
||||||
}
|
|
||||||
relationalJtd = explicitJavaType;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
final boolean useCharacter = stdIndicators.getColumnLength() == 1;
|
|
||||||
final Class<?> relationalJavaType = useCharacter ? Character.class : String.class;
|
|
||||||
relationalJtd = typeConfiguration.getJavaTypeRegistry().getDescriptor( relationalJavaType );
|
|
||||||
}
|
|
||||||
|
|
||||||
final JdbcType jdbcType = explicitJdbcType != null ? explicitJdbcType : relationalJtd.getRecommendedJdbcType( stdIndicators );
|
|
||||||
|
|
||||||
//noinspection unchecked
|
|
||||||
final NamedEnumValueConverter valueConverter = new NamedEnumValueConverter(
|
|
||||||
enumJavaType,
|
enumJavaType,
|
||||||
jdbcType,
|
explicitJavaType,
|
||||||
relationalJtd
|
explicitJdbcType,
|
||||||
);
|
stdIndicators,
|
||||||
|
|
||||||
final org.hibernate.type.EnumType<E> legacyEnumType = new org.hibernate.type.EnumType<>(
|
|
||||||
enumJavaType.getJavaTypeClass(),
|
|
||||||
valueConverter,
|
|
||||||
typeConfiguration
|
typeConfiguration
|
||||||
);
|
);
|
||||||
|
|
||||||
final CustomType<E> legacyEnumTypeWrapper = new CustomType<>( legacyEnumType, typeConfiguration );
|
|
||||||
|
|
||||||
final JdbcMapping jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( relationalJtd, jdbcType );
|
|
||||||
|
|
||||||
//noinspection unchecked
|
|
||||||
return new InferredBasicValueResolution(
|
|
||||||
jdbcMapping,
|
|
||||||
enumJavaType,
|
|
||||||
relationalJtd,
|
|
||||||
jdbcType,
|
|
||||||
valueConverter,
|
|
||||||
legacyEnumTypeWrapper,
|
|
||||||
ImmutableMutabilityPlan.INSTANCE
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
case ORDINAL: {
|
case ORDINAL: {
|
||||||
|
return ordinalEnumValueResolution(
|
||||||
|
enumJavaType,
|
||||||
|
explicitJavaType,
|
||||||
|
explicitJdbcType,
|
||||||
|
typeConfiguration
|
||||||
|
);
|
||||||
|
}
|
||||||
|
default: {
|
||||||
|
throw new MappingException( "Unknown enumeration-style (JPA EnumType) : " + enumStyle );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static <E extends Enum<E>> InferredBasicValueResolution<E, Integer> ordinalEnumValueResolution(
|
||||||
|
EnumJavaType<E> enumJavaType,
|
||||||
|
BasicJavaType<?> explicitJavaType,
|
||||||
|
JdbcType explicitJdbcType,
|
||||||
|
TypeConfiguration typeConfiguration) {
|
||||||
final JavaType<Integer> relationalJtd;
|
final JavaType<Integer> relationalJtd;
|
||||||
if ( explicitJavaType != null ) {
|
if ( explicitJavaType != null ) {
|
||||||
if ( ! Integer.class.isAssignableFrom( explicitJavaType.getJavaTypeClass() ) ) {
|
if ( ! Integer.class.isAssignableFrom( explicitJavaType.getJavaTypeClass() ) ) {
|
||||||
|
@ -349,7 +334,7 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
//noinspection unchecked
|
//noinspection unchecked
|
||||||
relationalJtd = explicitJavaType;
|
relationalJtd = (BasicJavaType<Integer>) explicitJavaType;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
relationalJtd = typeConfiguration.getJavaTypeRegistry().getDescriptor( Integer.class );
|
relationalJtd = typeConfiguration.getJavaTypeRegistry().getDescriptor( Integer.class );
|
||||||
|
@ -359,44 +344,85 @@ public class InferredBasicValueResolver {
|
||||||
? explicitJdbcType
|
? explicitJdbcType
|
||||||
: typeConfiguration.getJdbcTypeRegistry().getDescriptor( SqlTypes.TINYINT );
|
: typeConfiguration.getJdbcTypeRegistry().getDescriptor( SqlTypes.TINYINT );
|
||||||
|
|
||||||
//noinspection unchecked
|
final OrdinalEnumValueConverter<E> valueConverter = new OrdinalEnumValueConverter<>(
|
||||||
final OrdinalEnumValueConverter valueConverter = new OrdinalEnumValueConverter(
|
|
||||||
enumJavaType,
|
enumJavaType,
|
||||||
jdbcType,
|
jdbcType,
|
||||||
relationalJtd
|
relationalJtd
|
||||||
);
|
);
|
||||||
|
|
||||||
final org.hibernate.type.EnumType<E> legacyEnumType = new org.hibernate.type.EnumType<>(
|
return new InferredBasicValueResolution<>(
|
||||||
enumJavaType.getJavaTypeClass(),
|
typeConfiguration.getBasicTypeRegistry().resolve(relationalJtd, jdbcType),
|
||||||
valueConverter,
|
|
||||||
typeConfiguration
|
|
||||||
);
|
|
||||||
|
|
||||||
final CustomType<E> legacyEnumTypeWrapper = new CustomType<>( legacyEnumType, typeConfiguration );
|
|
||||||
|
|
||||||
final JdbcMapping jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( relationalJtd, jdbcType );
|
|
||||||
|
|
||||||
//noinspection unchecked
|
|
||||||
return new InferredBasicValueResolution(
|
|
||||||
jdbcMapping,
|
|
||||||
enumJavaType,
|
enumJavaType,
|
||||||
relationalJtd,
|
relationalJtd,
|
||||||
jdbcType,
|
jdbcType,
|
||||||
valueConverter,
|
valueConverter,
|
||||||
legacyEnumTypeWrapper,
|
new CustomType<>(
|
||||||
ImmutableMutabilityPlan.INSTANCE
|
new org.hibernate.type.EnumType<>(
|
||||||
|
enumJavaType.getJavaTypeClass(),
|
||||||
|
valueConverter,
|
||||||
|
typeConfiguration
|
||||||
|
),
|
||||||
|
typeConfiguration
|
||||||
|
),
|
||||||
|
ImmutableMutabilityPlan.instance()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
default: {
|
|
||||||
throw new MappingException( "Unknown enumeration-style (JPA EnumType) : " + enumStyle );
|
private static <E extends Enum<E>> InferredBasicValueResolution<E, String> stringEnumValueResolution(
|
||||||
|
EnumJavaType<E> enumJavaType,
|
||||||
|
BasicJavaType<?> explicitJavaType,
|
||||||
|
JdbcType explicitJdbcType,
|
||||||
|
JdbcTypeIndicators stdIndicators,
|
||||||
|
TypeConfiguration typeConfiguration) {
|
||||||
|
final JavaType<String> relationalJtd;
|
||||||
|
if ( explicitJavaType != null ) {
|
||||||
|
if ( ! String.class.isAssignableFrom( explicitJavaType.getJavaTypeClass() ) ) {
|
||||||
|
throw new MappingException(
|
||||||
|
"Explicit JavaType [" + explicitJavaType +
|
||||||
|
"] applied to enumerated value with EnumType#STRING" +
|
||||||
|
" should handle `java.lang.String` as its relational type descriptor"
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
//noinspection unchecked
|
||||||
|
relationalJtd = (BasicJavaType<String>) explicitJavaType;
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
final boolean useCharacter = stdIndicators.getColumnLength() == 1;
|
||||||
|
relationalJtd = typeConfiguration.getJavaTypeRegistry()
|
||||||
|
.getDescriptor( useCharacter ? Character.class : String.class );
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings({"rawtypes", "unchecked"})
|
final JdbcType jdbcType = explicitJdbcType != null
|
||||||
public static InferredBasicValueResolution fromTemporal(
|
? explicitJdbcType
|
||||||
TemporalJavaType reflectedJtd,
|
: relationalJtd.getRecommendedJdbcType(stdIndicators);
|
||||||
BasicJavaType explicitJavaType,
|
|
||||||
|
final NamedEnumValueConverter<E> valueConverter = new NamedEnumValueConverter<>(
|
||||||
|
enumJavaType,
|
||||||
|
jdbcType,
|
||||||
|
relationalJtd
|
||||||
|
);
|
||||||
|
|
||||||
|
return new InferredBasicValueResolution<>(
|
||||||
|
typeConfiguration.getBasicTypeRegistry().resolve(relationalJtd, jdbcType),
|
||||||
|
enumJavaType,
|
||||||
|
relationalJtd,
|
||||||
|
jdbcType,
|
||||||
|
valueConverter,
|
||||||
|
new CustomType<>(
|
||||||
|
new org.hibernate.type.EnumType<>(
|
||||||
|
enumJavaType.getJavaTypeClass(),
|
||||||
|
valueConverter,
|
||||||
|
typeConfiguration
|
||||||
|
),
|
||||||
|
typeConfiguration
|
||||||
|
),
|
||||||
|
ImmutableMutabilityPlan.instance()
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static <T> InferredBasicValueResolution<T,T> fromTemporal(
|
||||||
|
TemporalJavaType<T> reflectedJtd,
|
||||||
|
BasicJavaType<?> explicitJavaType,
|
||||||
JdbcType explicitJdbcType,
|
JdbcType explicitJdbcType,
|
||||||
Type resolvedJavaType,
|
Type resolvedJavaType,
|
||||||
JdbcTypeIndicators stdIndicators,
|
JdbcTypeIndicators stdIndicators,
|
||||||
|
@ -407,14 +433,15 @@ public class InferredBasicValueResolver {
|
||||||
// Case #1 - explicit JavaType
|
// Case #1 - explicit JavaType
|
||||||
|
|
||||||
if ( explicitJavaType != null ) {
|
if ( explicitJavaType != null ) {
|
||||||
if ( !TemporalJavaType.class.isInstance( explicitJavaType ) ) {
|
if ( !(explicitJavaType instanceof TemporalJavaType) ) {
|
||||||
throw new MappingException(
|
throw new MappingException(
|
||||||
"Explicit JavaType [" + explicitJavaType +
|
"Explicit JavaType [" + explicitJavaType +
|
||||||
"] defined for temporal value must implement TemporalJavaType"
|
"] defined for temporal value must implement TemporalJavaType"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
final TemporalJavaType explicitTemporalJtd = (TemporalJavaType) explicitJavaType;
|
@SuppressWarnings("unchecked")
|
||||||
|
final TemporalJavaType<T> explicitTemporalJtd = (TemporalJavaType<T>) explicitJavaType;
|
||||||
|
|
||||||
if ( requestedTemporalPrecision != null && explicitTemporalJtd.getPrecision() != requestedTemporalPrecision ) {
|
if ( requestedTemporalPrecision != null && explicitTemporalJtd.getPrecision() != requestedTemporalPrecision ) {
|
||||||
throw new MappingException(
|
throw new MappingException(
|
||||||
|
@ -424,18 +451,20 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
final JdbcType jdbcType = explicitJdbcType != null ? explicitJdbcType : explicitTemporalJtd.getRecommendedJdbcType( stdIndicators );
|
final JdbcType jdbcType = explicitJdbcType != null
|
||||||
|
? explicitJdbcType
|
||||||
|
: explicitTemporalJtd.getRecommendedJdbcType( stdIndicators );
|
||||||
|
|
||||||
final BasicType jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( explicitTemporalJtd, jdbcType );
|
final BasicType<T> jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( explicitTemporalJtd, jdbcType );
|
||||||
|
|
||||||
return new InferredBasicValueResolution(
|
return new InferredBasicValueResolution<>(
|
||||||
jdbcMapping,
|
jdbcMapping,
|
||||||
explicitTemporalJtd,
|
explicitTemporalJtd,
|
||||||
explicitTemporalJtd,
|
explicitTemporalJtd,
|
||||||
jdbcType,
|
jdbcType,
|
||||||
null,
|
null,
|
||||||
jdbcMapping,
|
jdbcMapping,
|
||||||
explicitJavaType.getMutabilityPlan()
|
explicitTemporalJtd.getMutabilityPlan()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -446,7 +475,7 @@ public class InferredBasicValueResolver {
|
||||||
// due to the new annotations being used
|
// due to the new annotations being used
|
||||||
|
|
||||||
if ( explicitJdbcType != null ) {
|
if ( explicitJdbcType != null ) {
|
||||||
final TemporalJavaType jtd;
|
final TemporalJavaType<T> jtd;
|
||||||
|
|
||||||
if ( requestedTemporalPrecision != null ) {
|
if ( requestedTemporalPrecision != null ) {
|
||||||
jtd = reflectedJtd.resolveTypeForPrecision(
|
jtd = reflectedJtd.resolveTypeForPrecision(
|
||||||
|
@ -458,9 +487,9 @@ public class InferredBasicValueResolver {
|
||||||
jtd = reflectedJtd;
|
jtd = reflectedJtd;
|
||||||
}
|
}
|
||||||
|
|
||||||
final BasicType jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( jtd, explicitJdbcType );
|
final BasicType<T> jdbcMapping = typeConfiguration.getBasicTypeRegistry().resolve( jtd, explicitJdbcType );
|
||||||
|
|
||||||
return new InferredBasicValueResolution(
|
return new InferredBasicValueResolution<>(
|
||||||
jdbcMapping,
|
jdbcMapping,
|
||||||
jtd,
|
jtd,
|
||||||
jtd,
|
jtd,
|
||||||
|
@ -476,7 +505,7 @@ public class InferredBasicValueResolver {
|
||||||
//
|
//
|
||||||
// - for the moment continue to use the legacy resolution to registered
|
// - for the moment continue to use the legacy resolution to registered
|
||||||
// BasicType
|
// BasicType
|
||||||
final BasicType basicType;
|
final BasicType<T> basicType;
|
||||||
if ( requestedTemporalPrecision != null && requestedTemporalPrecision != reflectedJtd.getPrecision() ) {
|
if ( requestedTemporalPrecision != null && requestedTemporalPrecision != reflectedJtd.getPrecision() ) {
|
||||||
basicType = typeConfiguration.getBasicTypeRegistry().resolve(
|
basicType = typeConfiguration.getBasicTypeRegistry().resolve(
|
||||||
reflectedJtd.resolveTypeForPrecision( requestedTemporalPrecision, typeConfiguration ),
|
reflectedJtd.resolveTypeForPrecision( requestedTemporalPrecision, typeConfiguration ),
|
||||||
|
@ -490,7 +519,7 @@ public class InferredBasicValueResolver {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new InferredBasicValueResolution(
|
return new InferredBasicValueResolution<>(
|
||||||
basicType,
|
basicType,
|
||||||
basicType.getJavaTypeDescriptor(),
|
basicType.getJavaTypeDescriptor(),
|
||||||
basicType.getJavaTypeDescriptor(),
|
basicType.getJavaTypeDescriptor(),
|
||||||
|
|
|
@ -32,10 +32,9 @@ import org.hibernate.type.spi.TypeConfiguration;
|
||||||
/**
|
/**
|
||||||
* @author Steve Ebersole
|
* @author Steve Ebersole
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("rawtypes")
|
|
||||||
public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
|
|
||||||
public static NamedConverterResolution from(
|
public static <T> NamedConverterResolution<T> from(
|
||||||
ConverterDescriptor converterDescriptor,
|
ConverterDescriptor converterDescriptor,
|
||||||
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
||||||
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
||||||
|
@ -47,13 +46,13 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
explicitJtdAccess,
|
explicitJtdAccess,
|
||||||
explicitStdAccess,
|
explicitStdAccess,
|
||||||
explicitMutabilityPlanAccess,
|
explicitMutabilityPlanAccess,
|
||||||
converterDescriptor.createJpaAttributeConverter( converterCreationContext ),
|
converter( converterCreationContext, converterDescriptor ),
|
||||||
sqlTypeIndicators,
|
sqlTypeIndicators,
|
||||||
context
|
context
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static NamedConverterResolution from(
|
public static <T> NamedConverterResolution<T> from(
|
||||||
String name,
|
String name,
|
||||||
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
||||||
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
||||||
|
@ -64,12 +63,10 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
assert name.startsWith( ConverterDescriptor.TYPE_NAME_PREFIX );
|
assert name.startsWith( ConverterDescriptor.TYPE_NAME_PREFIX );
|
||||||
final String converterClassName = name.substring( ConverterDescriptor.TYPE_NAME_PREFIX.length() );
|
final String converterClassName = name.substring( ConverterDescriptor.TYPE_NAME_PREFIX.length() );
|
||||||
|
|
||||||
final StandardServiceRegistry serviceRegistry = context.getBootstrapContext().getServiceRegistry();
|
|
||||||
final ClassLoaderService classLoaderService = serviceRegistry.getService( ClassLoaderService.class );
|
|
||||||
|
|
||||||
final Class<? extends AttributeConverter> converterClass = classLoaderService.classForName( converterClassName );
|
|
||||||
final ClassBasedConverterDescriptor converterDescriptor = new ClassBasedConverterDescriptor(
|
final ClassBasedConverterDescriptor converterDescriptor = new ClassBasedConverterDescriptor(
|
||||||
converterClass,
|
context.getBootstrapContext().getServiceRegistry()
|
||||||
|
.getService( ClassLoaderService.class )
|
||||||
|
.classForName( converterClassName ),
|
||||||
context.getBootstrapContext().getClassmateContext()
|
context.getBootstrapContext().getClassmateContext()
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -77,25 +74,33 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
explicitJtdAccess,
|
explicitJtdAccess,
|
||||||
explicitStdAccess,
|
explicitStdAccess,
|
||||||
explicitMutabilityPlanAccess,
|
explicitMutabilityPlanAccess,
|
||||||
converterDescriptor.createJpaAttributeConverter( converterCreationContext ),
|
converter( converterCreationContext, converterDescriptor ),
|
||||||
sqlTypeIndicators,
|
sqlTypeIndicators,
|
||||||
context
|
context
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static NamedConverterResolution fromInternal(
|
private static <T> JpaAttributeConverter<T, ?> converter(
|
||||||
|
JpaAttributeConverterCreationContext converterCreationContext,
|
||||||
|
ConverterDescriptor converterDescriptor) {
|
||||||
|
//noinspection unchecked
|
||||||
|
return (JpaAttributeConverter<T,?>) converterDescriptor.createJpaAttributeConverter(converterCreationContext);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static <T> NamedConverterResolution<T> fromInternal(
|
||||||
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
Function<TypeConfiguration, BasicJavaType> explicitJtdAccess,
|
||||||
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
Function<TypeConfiguration, JdbcType> explicitStdAccess,
|
||||||
Function<TypeConfiguration, MutabilityPlan> explicitMutabilityPlanAccess,
|
Function<TypeConfiguration, MutabilityPlan> explicitMutabilityPlanAccess,
|
||||||
JpaAttributeConverter converter, JdbcTypeIndicators sqlTypeIndicators,
|
JpaAttributeConverter<T,?> converter,
|
||||||
|
JdbcTypeIndicators sqlTypeIndicators,
|
||||||
MetadataBuildingContext context) {
|
MetadataBuildingContext context) {
|
||||||
final TypeConfiguration typeConfiguration = context.getBootstrapContext().getTypeConfiguration();
|
final TypeConfiguration typeConfiguration = context.getBootstrapContext().getTypeConfiguration();
|
||||||
|
|
||||||
final JavaType explicitJtd = explicitJtdAccess != null
|
final JavaType<T> explicitJtd = explicitJtdAccess != null
|
||||||
? explicitJtdAccess.apply( typeConfiguration )
|
? explicitJtdAccess.apply( typeConfiguration )
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
final JavaType domainJtd = explicitJtd != null
|
final JavaType<T> domainJtd = explicitJtd != null
|
||||||
? explicitJtd
|
? explicitJtd
|
||||||
: converter.getDomainJavaType();
|
: converter.getDomainJavaType();
|
||||||
|
|
||||||
|
@ -103,29 +108,29 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
? explicitStdAccess.apply( typeConfiguration )
|
? explicitStdAccess.apply( typeConfiguration )
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
final JavaType relationalJtd = converter.getRelationalJavaType();
|
final JavaType<?> relationalJtd = converter.getRelationalJavaType();
|
||||||
|
|
||||||
final JdbcType jdbcType = explicitJdbcType != null
|
final JdbcType jdbcType = explicitJdbcType != null
|
||||||
? explicitJdbcType
|
? explicitJdbcType
|
||||||
: relationalJtd.getRecommendedJdbcType( sqlTypeIndicators );
|
: relationalJtd.getRecommendedJdbcType( sqlTypeIndicators );
|
||||||
|
|
||||||
final MutabilityPlan explicitMutabilityPlan = explicitMutabilityPlanAccess != null
|
final MutabilityPlan<T> explicitMutabilityPlan = explicitMutabilityPlanAccess != null
|
||||||
? explicitMutabilityPlanAccess.apply( typeConfiguration )
|
? explicitMutabilityPlanAccess.apply( typeConfiguration )
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
|
|
||||||
final MutabilityPlan mutabilityPlan;
|
final MutabilityPlan<T> mutabilityPlan;
|
||||||
if ( explicitMutabilityPlan != null ) {
|
if ( explicitMutabilityPlan != null ) {
|
||||||
mutabilityPlan = explicitMutabilityPlan;
|
mutabilityPlan = explicitMutabilityPlan;
|
||||||
}
|
}
|
||||||
else if ( ! domainJtd.getMutabilityPlan().isMutable() ) {
|
else if ( ! domainJtd.getMutabilityPlan().isMutable() ) {
|
||||||
mutabilityPlan = ImmutableMutabilityPlan.INSTANCE;
|
mutabilityPlan = ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
mutabilityPlan = new AttributeConverterMutabilityPlanImpl( converter, true );
|
mutabilityPlan = new AttributeConverterMutabilityPlanImpl<>( converter, true );
|
||||||
}
|
}
|
||||||
|
|
||||||
return new NamedConverterResolution(
|
return new NamedConverterResolution<T>(
|
||||||
domainJtd,
|
domainJtd,
|
||||||
relationalJtd,
|
relationalJtd,
|
||||||
jdbcType,
|
jdbcType,
|
||||||
|
@ -136,24 +141,23 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private final JavaType domainJtd;
|
private final JavaType<J> domainJtd;
|
||||||
private final JavaType relationalJtd;
|
private final JavaType<?> relationalJtd;
|
||||||
private final JdbcType jdbcType;
|
private final JdbcType jdbcType;
|
||||||
|
|
||||||
private final JpaAttributeConverter valueConverter;
|
private final JpaAttributeConverter<J,?> valueConverter;
|
||||||
private final MutabilityPlan mutabilityPlan;
|
private final MutabilityPlan<J> mutabilityPlan;
|
||||||
|
|
||||||
private final JdbcMapping jdbcMapping;
|
private final JdbcMapping jdbcMapping;
|
||||||
|
|
||||||
private final BasicType legacyResolvedType;
|
private final BasicType<J> legacyResolvedType;
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public NamedConverterResolution(
|
public NamedConverterResolution(
|
||||||
JavaType domainJtd,
|
JavaType<J> domainJtd,
|
||||||
JavaType relationalJtd,
|
JavaType<?> relationalJtd,
|
||||||
JdbcType jdbcType,
|
JdbcType jdbcType,
|
||||||
JpaAttributeConverter valueConverter,
|
JpaAttributeConverter<J,?> valueConverter,
|
||||||
MutabilityPlan mutabilityPlan,
|
MutabilityPlan<J> mutabilityPlan,
|
||||||
TypeConfiguration typeConfiguration) {
|
TypeConfiguration typeConfiguration) {
|
||||||
assert domainJtd != null;
|
assert domainJtd != null;
|
||||||
this.domainJtd = domainJtd;
|
this.domainJtd = domainJtd;
|
||||||
|
@ -208,8 +212,9 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
// typeConfiguration
|
// typeConfiguration
|
||||||
// );
|
// );
|
||||||
|
|
||||||
this.legacyResolvedType = new AttributeConverterTypeAdapter(
|
this.legacyResolvedType = new AttributeConverterTypeAdapter<>(
|
||||||
ConverterDescriptor.TYPE_NAME_PREFIX + valueConverter.getConverterJavaType().getJavaType().getTypeName(),
|
ConverterDescriptor.TYPE_NAME_PREFIX
|
||||||
|
+ valueConverter.getConverterJavaType().getJavaType().getTypeName(),
|
||||||
String.format(
|
String.format(
|
||||||
"BasicType adapter for AttributeConverter<%s,%s>",
|
"BasicType adapter for AttributeConverter<%s,%s>",
|
||||||
domainJtd.getJavaType().getTypeName(),
|
domainJtd.getJavaType().getTypeName(),
|
||||||
|
@ -225,13 +230,11 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BasicType<J> getLegacyResolvedBasicType() {
|
public BasicType<J> getLegacyResolvedBasicType() {
|
||||||
//noinspection unchecked
|
|
||||||
return legacyResolvedType;
|
return legacyResolvedType;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JavaType<J> getDomainJavaType() {
|
public JavaType<J> getDomainJavaType() {
|
||||||
//noinspection unchecked
|
|
||||||
return domainJtd;
|
return domainJtd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -251,13 +254,12 @@ public class NamedConverterResolution<J> implements BasicValue.Resolution<J> {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JpaAttributeConverter getValueConverter() {
|
public JpaAttributeConverter<J,?> getValueConverter() {
|
||||||
return valueConverter;
|
return valueConverter;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MutabilityPlan<J> getMutabilityPlan() {
|
public MutabilityPlan<J> getMutabilityPlan() {
|
||||||
//noinspection unchecked
|
|
||||||
return mutabilityPlan;
|
return mutabilityPlan;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -756,8 +756,11 @@ public class BasicValue extends SimpleValue implements JdbcTypeIndicators, Resol
|
||||||
// envers - grr
|
// envers - grr
|
||||||
setTypeParameters( properties );
|
setTypeParameters( properties );
|
||||||
|
|
||||||
final CustomType<Object> customType = new CustomType<>( (UserType<Object>) typeInstance, typeConfiguration );
|
this.resolution = new UserTypeResolution(
|
||||||
this.resolution = new UserTypeResolution( customType, null, properties );
|
new CustomType<>( (UserType<Object>) typeInstance, typeConfiguration ),
|
||||||
|
null,
|
||||||
|
properties
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -817,7 +820,7 @@ public class BasicValue extends SimpleValue implements JdbcTypeIndicators, Resol
|
||||||
* Converter, if any, to convert values between the
|
* Converter, if any, to convert values between the
|
||||||
* domain and relational JavaType representations
|
* domain and relational JavaType representations
|
||||||
*/
|
*/
|
||||||
BasicValueConverter getValueConverter();
|
BasicValueConverter<J,?> getValueConverter();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The resolved MutabilityPlan
|
* The resolved MutabilityPlan
|
||||||
|
|
|
@ -52,7 +52,7 @@ import org.hibernate.type.Type;
|
||||||
import org.hibernate.type.descriptor.JdbcTypeNameMapper;
|
import org.hibernate.type.descriptor.JdbcTypeNameMapper;
|
||||||
import org.hibernate.type.descriptor.converter.AttributeConverterJdbcTypeAdapter;
|
import org.hibernate.type.descriptor.converter.AttributeConverterJdbcTypeAdapter;
|
||||||
import org.hibernate.type.descriptor.converter.AttributeConverterTypeAdapter;
|
import org.hibernate.type.descriptor.converter.AttributeConverterTypeAdapter;
|
||||||
import org.hibernate.type.descriptor.java.BasicJavaType;
|
import org.hibernate.type.descriptor.java.JavaType;
|
||||||
import org.hibernate.type.descriptor.jdbc.JdbcType;
|
import org.hibernate.type.descriptor.jdbc.JdbcType;
|
||||||
import org.hibernate.type.descriptor.jdbc.JdbcTypeIndicators;
|
import org.hibernate.type.descriptor.jdbc.JdbcTypeIndicators;
|
||||||
import org.hibernate.type.descriptor.jdbc.LobTypeMappings;
|
import org.hibernate.type.descriptor.jdbc.LobTypeMappings;
|
||||||
|
@ -728,8 +728,7 @@ public abstract class SimpleValue implements KeyValue {
|
||||||
*/
|
*/
|
||||||
private Type buildAttributeConverterTypeAdapter() {
|
private Type buildAttributeConverterTypeAdapter() {
|
||||||
// todo : validate the number of columns present here?
|
// todo : validate the number of columns present here?
|
||||||
|
return buildAttributeConverterTypeAdapter( attributeConverterDescriptor.createJpaAttributeConverter(
|
||||||
final JpaAttributeConverter jpaAttributeConverter = attributeConverterDescriptor.createJpaAttributeConverter(
|
|
||||||
new JpaAttributeConverterCreationContext() {
|
new JpaAttributeConverterCreationContext() {
|
||||||
@Override
|
@Override
|
||||||
public ManagedBeanRegistry getManagedBeanRegistry() {
|
public ManagedBeanRegistry getManagedBeanRegistry() {
|
||||||
|
@ -744,9 +743,13 @@ public abstract class SimpleValue implements KeyValue {
|
||||||
return getMetadata().getTypeConfiguration();
|
return getMetadata().getTypeConfiguration();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
) );
|
||||||
|
}
|
||||||
|
|
||||||
final BasicJavaType<?> domainJtd = (BasicJavaType<?>) jpaAttributeConverter.getDomainJavaType();
|
private <T> AttributeConverterTypeAdapter<T> buildAttributeConverterTypeAdapter(
|
||||||
|
JpaAttributeConverter<T, ?> jpaAttributeConverter) {
|
||||||
|
JavaType<T> domainJavaType = jpaAttributeConverter.getDomainJavaType();
|
||||||
|
JavaType<?> relationalJavaType = jpaAttributeConverter.getRelationalJavaType();
|
||||||
|
|
||||||
// build the SqlTypeDescriptor adapter ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
// build the SqlTypeDescriptor adapter ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
// Going back to the illustration, this should be a SqlTypeDescriptor that handles the Integer <-> String
|
// Going back to the illustration, this should be a SqlTypeDescriptor that handles the Integer <-> String
|
||||||
|
@ -754,7 +757,7 @@ public abstract class SimpleValue implements KeyValue {
|
||||||
// corresponding to the AttributeConverter's declared "databaseColumnJavaType" (how we read that value out
|
// corresponding to the AttributeConverter's declared "databaseColumnJavaType" (how we read that value out
|
||||||
// of ResultSets). See JdbcTypeJavaClassMappings for details. Again, given example, this should return
|
// of ResultSets). See JdbcTypeJavaClassMappings for details. Again, given example, this should return
|
||||||
// VARCHAR/CHAR
|
// VARCHAR/CHAR
|
||||||
final JdbcType recommendedJdbcType = jpaAttributeConverter.getRelationalJavaType().getRecommendedJdbcType(
|
final JdbcType recommendedJdbcType = relationalJavaType.getRecommendedJdbcType(
|
||||||
// todo (6.0) : handle the other JdbcRecommendedSqlTypeMappingContext methods
|
// todo (6.0) : handle the other JdbcRecommendedSqlTypeMappingContext methods
|
||||||
new JdbcTypeIndicators() {
|
new JdbcTypeIndicators() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -774,7 +777,7 @@ public abstract class SimpleValue implements KeyValue {
|
||||||
jdbcTypeCode = LobTypeMappings.getLobCodeTypeMapping( jdbcTypeCode );
|
jdbcTypeCode = LobTypeMappings.getLobCodeTypeMapping( jdbcTypeCode );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if ( Serializable.class.isAssignableFrom( domainJtd.getJavaTypeClass() ) ) {
|
if ( Serializable.class.isAssignableFrom( domainJavaType.getJavaTypeClass() ) ) {
|
||||||
jdbcTypeCode = Types.BLOB;
|
jdbcTypeCode = Types.BLOB;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -793,33 +796,26 @@ public abstract class SimpleValue implements KeyValue {
|
||||||
jdbcTypeCode = NationalizedTypeMappings.toNationalizedTypeCode( jdbcTypeCode );
|
jdbcTypeCode = NationalizedTypeMappings.toNationalizedTypeCode( jdbcTypeCode );
|
||||||
}
|
}
|
||||||
|
|
||||||
final JdbcType jdbcType = metadata.getTypeConfiguration()
|
|
||||||
.getJdbcTypeRegistry()
|
|
||||||
.getDescriptor( jdbcTypeCode );
|
|
||||||
|
|
||||||
// and finally construct the adapter, which injects the AttributeConverter calls into the binding/extraction
|
|
||||||
// process...
|
|
||||||
final JdbcType jdbcTypeAdapter = new AttributeConverterJdbcTypeAdapter(
|
|
||||||
jpaAttributeConverter,
|
|
||||||
jdbcType,
|
|
||||||
jpaAttributeConverter.getRelationalJavaType()
|
|
||||||
);
|
|
||||||
|
|
||||||
// todo : cache the AttributeConverterTypeAdapter in case that AttributeConverter is applied multiple times.
|
// todo : cache the AttributeConverterTypeAdapter in case that AttributeConverter is applied multiple times.
|
||||||
|
|
||||||
final String name = ConverterDescriptor.TYPE_NAME_PREFIX + jpaAttributeConverter.getConverterJavaType().getJavaType().getTypeName();
|
|
||||||
final String description = String.format(
|
|
||||||
"BasicType adapter for AttributeConverter<%s,%s>",
|
|
||||||
jpaAttributeConverter.getDomainJavaType().getJavaType().getTypeName(),
|
|
||||||
jpaAttributeConverter.getRelationalJavaType().getJavaType().getTypeName()
|
|
||||||
);
|
|
||||||
return new AttributeConverterTypeAdapter<>(
|
return new AttributeConverterTypeAdapter<>(
|
||||||
name,
|
ConverterDescriptor.TYPE_NAME_PREFIX
|
||||||
description,
|
+ jpaAttributeConverter.getConverterJavaType().getJavaType().getTypeName(),
|
||||||
|
String.format(
|
||||||
|
"BasicType adapter for AttributeConverter<%s,%s>",
|
||||||
|
domainJavaType.getJavaType().getTypeName(),
|
||||||
|
relationalJavaType.getJavaType().getTypeName()
|
||||||
|
),
|
||||||
jpaAttributeConverter,
|
jpaAttributeConverter,
|
||||||
jdbcTypeAdapter,
|
// and finally construct the adapter, which injects the AttributeConverter
|
||||||
jpaAttributeConverter.getRelationalJavaType(),
|
// calls into the binding/extraction process...
|
||||||
jpaAttributeConverter.getDomainJavaType(),
|
new AttributeConverterJdbcTypeAdapter(
|
||||||
|
jpaAttributeConverter,
|
||||||
|
metadata.getTypeConfiguration().getJdbcTypeRegistry().getDescriptor( jdbcTypeCode ),
|
||||||
|
relationalJavaType
|
||||||
|
),
|
||||||
|
relationalJavaType,
|
||||||
|
domainJavaType,
|
||||||
null
|
null
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -215,7 +215,7 @@ public abstract class AbstractEmbeddableMapping implements EmbeddableMappingType
|
||||||
final MutabilityPlan<?> mutabilityPlan;
|
final MutabilityPlan<?> mutabilityPlan;
|
||||||
|
|
||||||
if ( updateable ) {
|
if ( updateable ) {
|
||||||
mutabilityPlan = new MutabilityPlan<Object>() {
|
mutabilityPlan = new MutabilityPlan<>() {
|
||||||
@Override
|
@Override
|
||||||
public boolean isMutable() {
|
public boolean isMutable() {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -184,7 +184,7 @@ public class MappingModelCreationHelper {
|
||||||
final Value value = bootProperty.getValue();
|
final Value value = bootProperty.getValue();
|
||||||
final BasicValue.Resolution<?> resolution = ( (Resolvable) value ).resolve();
|
final BasicValue.Resolution<?> resolution = ( (Resolvable) value ).resolve();
|
||||||
|
|
||||||
final BasicValueConverter valueConverter = resolution.getValueConverter();
|
final BasicValueConverter<?,?> valueConverter = resolution.getValueConverter();
|
||||||
|
|
||||||
final StateArrayContributorMetadataAccess attributeMetadataAccess = entityMappingType -> new StateArrayContributorMetadata() {
|
final StateArrayContributorMetadataAccess attributeMetadataAccess = entityMappingType -> new StateArrayContributorMetadata() {
|
||||||
private final MutabilityPlan mutabilityPlan = resolution.getMutabilityPlan();
|
private final MutabilityPlan mutabilityPlan = resolution.getMutabilityPlan();
|
||||||
|
@ -258,7 +258,6 @@ public class MappingModelCreationHelper {
|
||||||
// we want to "decompose" the "type" into its various pieces as expected by the mapping
|
// we want to "decompose" the "type" into its various pieces as expected by the mapping
|
||||||
assert valueConverter.getRelationalJavaType() == resolution.getRelationalJavaType();
|
assert valueConverter.getRelationalJavaType() == resolution.getRelationalJavaType();
|
||||||
|
|
||||||
//noinspection unchecked
|
|
||||||
final BasicType<?> mappingBasicType = creationProcess.getCreationContext()
|
final BasicType<?> mappingBasicType = creationProcess.getCreationContext()
|
||||||
.getDomainModel()
|
.getDomainModel()
|
||||||
.getTypeConfiguration()
|
.getTypeConfiguration()
|
||||||
|
|
|
@ -4000,10 +4000,10 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
final MappingModelExpressible<?> elementExpressible = getElementExpressible( localExpressible );
|
final MappingModelExpressible<?> elementExpressible = getElementExpressible( localExpressible );
|
||||||
if ( elementExpressible instanceof BasicType<?> ) {
|
if ( elementExpressible instanceof BasicType ) {
|
||||||
expressible = InferredBasicValueResolver.resolveSqlTypeIndicators(
|
expressible = InferredBasicValueResolver.resolveSqlTypeIndicators(
|
||||||
this,
|
this,
|
||||||
(BasicType<?>) elementExpressible,
|
(BasicType) elementExpressible,
|
||||||
literal.getJavaTypeDescriptor()
|
literal.getJavaTypeDescriptor()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -4080,23 +4080,18 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if ( literal instanceof SqmLiteral ) {
|
|
||||||
return new QueryLiteral<>(
|
return new QueryLiteral<>(
|
||||||
literal.getLiteralValue(),
|
literal.getLiteralValue(),
|
||||||
creationContext.getSessionFactory()
|
creationContext.getSessionFactory()
|
||||||
.getTypeConfiguration()
|
.getTypeConfiguration()
|
||||||
.getBasicTypeRegistry()
|
.getBasicTypeRegistry()
|
||||||
.getRegisteredType(
|
.getRegisteredType(
|
||||||
( (BasicSqmPathSource) literal.getNodeType() ).getSqmPathType()
|
( (BasicSqmPathSource<?>) literal.getNodeType() ).getSqmPathType()
|
||||||
.getJavaType()
|
.getJavaType()
|
||||||
.getName()
|
.getName()
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
throw new NotYetImplementedFor6Exception(
|
|
||||||
expressible == null ? literal.getLiteralValue().getClass() : expressible.getClass()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private MappingModelExpressible<?> getKeyExpressible(JdbcMappingContainer mappingModelExpressible) {
|
private MappingModelExpressible<?> getKeyExpressible(JdbcMappingContainer mappingModelExpressible) {
|
||||||
|
@ -4613,10 +4608,10 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
@Override
|
@Override
|
||||||
public Object visitCastTarget(SqmCastTarget<?> target) {
|
public Object visitCastTarget(SqmCastTarget<?> target) {
|
||||||
BasicValuedMapping targetType = (BasicValuedMapping) target.getType();
|
BasicValuedMapping targetType = (BasicValuedMapping) target.getType();
|
||||||
if ( targetType instanceof BasicType<?> ) {
|
if ( targetType instanceof BasicType ) {
|
||||||
targetType = InferredBasicValueResolver.resolveSqlTypeIndicators(
|
targetType = InferredBasicValueResolver.resolveSqlTypeIndicators(
|
||||||
this,
|
this,
|
||||||
(BasicType<?>) targetType,
|
(BasicType) targetType,
|
||||||
target.getNodeJavaType()
|
target.getNodeJavaType()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -5320,7 +5315,6 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
final BasicValuedMapping inferrableType = (BasicValuedMapping) resolveInferredType();
|
final BasicValuedMapping inferrableType = (BasicValuedMapping) resolveInferredType();
|
||||||
if ( inferrableType instanceof ConvertibleModelPart ) {
|
if ( inferrableType instanceof ConvertibleModelPart ) {
|
||||||
final ConvertibleModelPart inferredPart = (ConvertibleModelPart) inferrableType;
|
final ConvertibleModelPart inferredPart = (ConvertibleModelPart) inferrableType;
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
final BasicValueConverter<Enum<?>,?> valueConverter = inferredPart.getValueConverter();
|
final BasicValueConverter<Enum<?>,?> valueConverter = inferredPart.getValueConverter();
|
||||||
final Object jdbcValue = valueConverter.toRelationalValue( sqmEnumLiteral.getEnumValue() );
|
final Object jdbcValue = valueConverter.toRelationalValue( sqmEnumLiteral.getEnumValue() );
|
||||||
return new QueryLiteral<>( jdbcValue, inferredPart );
|
return new QueryLiteral<>( jdbcValue, inferredPart );
|
||||||
|
@ -5335,7 +5329,7 @@ public abstract class BaseSqmToSqlAstConverter<T extends Statement> extends Base
|
||||||
|
|
||||||
return new ConvertedQueryLiteral(
|
return new ConvertedQueryLiteral(
|
||||||
sqmEnumLiteral.getEnumValue(),
|
sqmEnumLiteral.getEnumValue(),
|
||||||
new OrdinalEnumValueConverter( enumJtd, jdbcType, relationalJtd ),
|
new OrdinalEnumValueConverter<>( enumJtd, jdbcType, relationalJtd ),
|
||||||
jdbcMappingType
|
jdbcMappingType
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,9 +35,8 @@ public abstract class AbstractClassJavaType<T> implements BasicJavaType<T>, Seri
|
||||||
*
|
*
|
||||||
* @see #AbstractClassJavaType(Class, MutabilityPlan)
|
* @see #AbstractClassJavaType(Class, MutabilityPlan)
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings({ "unchecked" })
|
|
||||||
protected AbstractClassJavaType(Class<? extends T> type) {
|
protected AbstractClassJavaType(Class<? extends T> type) {
|
||||||
this( type, (MutabilityPlan<T>) ImmutableMutabilityPlan.INSTANCE );
|
this( type, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -36,9 +36,8 @@ public abstract class AbstractJavaType<T> implements BasicJavaType<T>, Serializa
|
||||||
*
|
*
|
||||||
* @see #AbstractJavaType(Type, MutabilityPlan)
|
* @see #AbstractJavaType(Type, MutabilityPlan)
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings({ "unchecked" })
|
|
||||||
protected AbstractJavaType(Type type) {
|
protected AbstractJavaType(Type type) {
|
||||||
this( type, (MutabilityPlan<T>) ImmutableMutabilityPlan.INSTANCE );
|
this( type, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -47,7 +46,7 @@ public abstract class AbstractJavaType<T> implements BasicJavaType<T>, Serializa
|
||||||
* @param type The Java type.
|
* @param type The Java type.
|
||||||
* @param mutabilityPlan The plan for handling mutability aspects of the java type.
|
* @param mutabilityPlan The plan for handling mutability aspects of the java type.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings({ "unchecked" })
|
@SuppressWarnings("unchecked")
|
||||||
protected AbstractJavaType(Type type, MutabilityPlan<T> mutabilityPlan) {
|
protected AbstractJavaType(Type type, MutabilityPlan<T> mutabilityPlan) {
|
||||||
this.type = type;
|
this.type = type;
|
||||||
this.mutabilityPlan = mutabilityPlan;
|
this.mutabilityPlan = mutabilityPlan;
|
||||||
|
@ -86,13 +85,13 @@ public abstract class AbstractJavaType<T> implements BasicJavaType<T>, Serializa
|
||||||
return (value == null) ? "null" : value.toString();
|
return (value == null) ? "null" : value.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected HibernateException unknownUnwrap(Class conversionType) {
|
protected HibernateException unknownUnwrap(Class<?> conversionType) {
|
||||||
throw new HibernateException(
|
throw new HibernateException(
|
||||||
"Unknown unwrap conversion requested: " + type.getTypeName() + " to " + conversionType.getName()
|
"Unknown unwrap conversion requested: " + type.getTypeName() + " to " + conversionType.getName()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected HibernateException unknownWrap(Class conversionType) {
|
protected HibernateException unknownWrap(Class<?> conversionType) {
|
||||||
throw new HibernateException(
|
throw new HibernateException(
|
||||||
"Unknown wrap conversion requested: " + conversionType.getName() + " to " + type.getTypeName()
|
"Unknown wrap conversion requested: " + conversionType.getName() + " to " + type.getTypeName()
|
||||||
);
|
);
|
||||||
|
|
|
@ -38,9 +38,8 @@ public class DurationJavaType extends AbstractClassJavaType<Duration> {
|
||||||
*/
|
*/
|
||||||
public static final DurationJavaType INSTANCE = new DurationJavaType();
|
public static final DurationJavaType INSTANCE = new DurationJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public DurationJavaType() {
|
public DurationJavaType() {
|
||||||
super( Duration.class, ImmutableMutabilityPlan.INSTANCE );
|
super( Duration.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -21,9 +21,8 @@ import org.hibernate.type.descriptor.jdbc.spi.JdbcTypeRegistry;
|
||||||
* @author Steve Ebersole
|
* @author Steve Ebersole
|
||||||
*/
|
*/
|
||||||
public class EnumJavaType<T extends Enum<T>> extends AbstractClassJavaType<T> {
|
public class EnumJavaType<T extends Enum<T>> extends AbstractClassJavaType<T> {
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public EnumJavaType(Class<T> type) {
|
public EnumJavaType(Class<T> type) {
|
||||||
super( type, ImmutableMutabilityPlan.INSTANCE );
|
super( type, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -38,9 +38,8 @@ public class InstantJavaType extends AbstractTemporalJavaType<Instant>
|
||||||
*/
|
*/
|
||||||
public static final InstantJavaType INSTANCE = new InstantJavaType();
|
public static final InstantJavaType INSTANCE = new InstantJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public InstantJavaType() {
|
public InstantJavaType() {
|
||||||
super( Instant.class, ImmutableMutabilityPlan.INSTANCE );
|
super( Instant.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -59,9 +59,8 @@ public interface JavaType<T> extends Serializable {
|
||||||
/**
|
/**
|
||||||
* Retrieve the mutability plan for this Java type.
|
* Retrieve the mutability plan for this Java type.
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
default MutabilityPlan<T> getMutabilityPlan() {
|
default MutabilityPlan<T> getMutabilityPlan() {
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
return ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
default T getReplacement(T original, T target, SharedSessionContractImplementor session) {
|
default T getReplacement(T original, T target, SharedSessionContractImplementor session) {
|
||||||
|
|
|
@ -36,9 +36,8 @@ public class LocalDateJavaType extends AbstractTemporalJavaType<LocalDate> {
|
||||||
*/
|
*/
|
||||||
public static final LocalDateJavaType INSTANCE = new LocalDateJavaType();
|
public static final LocalDateJavaType INSTANCE = new LocalDateJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public LocalDateJavaType() {
|
public LocalDateJavaType() {
|
||||||
super( LocalDate.class, ImmutableMutabilityPlan.INSTANCE );
|
super( LocalDate.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -37,9 +37,8 @@ public class LocalDateTimeJavaType extends AbstractTemporalJavaType<LocalDateTim
|
||||||
*/
|
*/
|
||||||
public static final LocalDateTimeJavaType INSTANCE = new LocalDateTimeJavaType();
|
public static final LocalDateTimeJavaType INSTANCE = new LocalDateTimeJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public LocalDateTimeJavaType() {
|
public LocalDateTimeJavaType() {
|
||||||
super( LocalDateTime.class, ImmutableMutabilityPlan.INSTANCE );
|
super( LocalDateTime.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -39,9 +39,8 @@ public class LocalTimeJavaType extends AbstractTemporalJavaType<LocalTime> {
|
||||||
*/
|
*/
|
||||||
public static final LocalTimeJavaType INSTANCE = new LocalTimeJavaType();
|
public static final LocalTimeJavaType INSTANCE = new LocalTimeJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public LocalTimeJavaType() {
|
public LocalTimeJavaType() {
|
||||||
super( LocalTime.class, ImmutableMutabilityPlan.INSTANCE );
|
super( LocalTime.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -28,7 +28,7 @@ public class LocaleJavaType extends AbstractClassJavaType<Locale> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public LocaleJavaType() {
|
public LocaleJavaType() {
|
||||||
super( Locale.class, ImmutableMutabilityPlan.INSTANCE, LocaleComparator.INSTANCE );
|
super( Locale.class, ImmutableMutabilityPlan.instance(), LocaleComparator.INSTANCE );
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString(Locale value) {
|
public String toString(Locale value) {
|
||||||
|
|
|
@ -15,15 +15,15 @@ import org.hibernate.type.descriptor.WrapperOptions;
|
||||||
*/
|
*/
|
||||||
public class ObjectArrayJavaType extends AbstractClassJavaType<Object[]> {
|
public class ObjectArrayJavaType extends AbstractClassJavaType<Object[]> {
|
||||||
|
|
||||||
private final JavaType<Object>[] components;
|
private final JavaType[] components;
|
||||||
|
|
||||||
public ObjectArrayJavaType(JavaType<?>[] components) {
|
public ObjectArrayJavaType(JavaType[] components) {
|
||||||
super(
|
super(
|
||||||
Object[].class,
|
Object[].class,
|
||||||
ImmutableMutabilityPlan.INSTANCE,
|
ImmutableMutabilityPlan.instance(),
|
||||||
new ComponentArrayComparator( (JavaType<Object>[]) components )
|
new ComponentArrayComparator( components )
|
||||||
);
|
);
|
||||||
this.components = (JavaType<Object>[]) components;
|
this.components = components;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -40,9 +40,8 @@ public class OffsetDateTimeJavaType extends AbstractTemporalJavaType<OffsetDateT
|
||||||
*/
|
*/
|
||||||
public static final OffsetDateTimeJavaType INSTANCE = new OffsetDateTimeJavaType();
|
public static final OffsetDateTimeJavaType INSTANCE = new OffsetDateTimeJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public OffsetDateTimeJavaType() {
|
public OffsetDateTimeJavaType() {
|
||||||
super( OffsetDateTime.class, ImmutableMutabilityPlan.INSTANCE, OffsetDateTime.timeLineOrder() );
|
super( OffsetDateTime.class, ImmutableMutabilityPlan.instance(), OffsetDateTime.timeLineOrder() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -39,9 +39,8 @@ public class OffsetTimeJavaType extends AbstractTemporalJavaType<OffsetTime> {
|
||||||
*/
|
*/
|
||||||
public static final OffsetTimeJavaType INSTANCE = new OffsetTimeJavaType();
|
public static final OffsetTimeJavaType INSTANCE = new OffsetTimeJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public OffsetTimeJavaType() {
|
public OffsetTimeJavaType() {
|
||||||
super( OffsetTime.class, ImmutableMutabilityPlan.INSTANCE );
|
super( OffsetTime.class, ImmutableMutabilityPlan.instance() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -54,10 +54,9 @@ public class SerializableJavaType<T extends Serializable> extends AbstractClassJ
|
||||||
super( type, mutabilityPlan == null ? createMutabilityPlan( type ) : mutabilityPlan );
|
super( type, mutabilityPlan == null ? createMutabilityPlan( type ) : mutabilityPlan );
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings({ "unchecked" })
|
|
||||||
private static <T> MutabilityPlan<T> createMutabilityPlan(Class<T> type) {
|
private static <T> MutabilityPlan<T> createMutabilityPlan(Class<T> type) {
|
||||||
if ( type.isAnnotationPresent( Immutable.class ) ) {
|
if ( type.isAnnotationPresent( Immutable.class ) ) {
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
return ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
return (MutabilityPlan<T>) SerializableMutabilityPlan.INSTANCE;
|
return (MutabilityPlan<T>) SerializableMutabilityPlan.INSTANCE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,7 @@ public class TimeZoneJavaType extends AbstractClassJavaType<TimeZone> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public TimeZoneJavaType() {
|
public TimeZoneJavaType() {
|
||||||
super( TimeZone.class, ImmutableMutabilityPlan.INSTANCE, TimeZoneComparator.INSTANCE );
|
super( TimeZone.class, ImmutableMutabilityPlan.instance(), TimeZoneComparator.INSTANCE );
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString(TimeZone value) {
|
public String toString(TimeZone value) {
|
||||||
|
|
|
@ -31,7 +31,7 @@ public class ZoneOffsetJavaType extends AbstractClassJavaType<ZoneOffset> {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ZoneOffsetJavaType() {
|
public ZoneOffsetJavaType() {
|
||||||
super( ZoneOffset.class, ImmutableMutabilityPlan.INSTANCE, ZoneOffsetComparator.INSTANCE );
|
super( ZoneOffset.class, ImmutableMutabilityPlan.instance(), ZoneOffsetComparator.INSTANCE );
|
||||||
}
|
}
|
||||||
|
|
||||||
public String toString(ZoneOffset value) {
|
public String toString(ZoneOffset value) {
|
||||||
|
|
|
@ -40,9 +40,8 @@ public class ZonedDateTimeJavaType extends AbstractTemporalJavaType<ZonedDateTim
|
||||||
*/
|
*/
|
||||||
public static final ZonedDateTimeJavaType INSTANCE = new ZonedDateTimeJavaType();
|
public static final ZonedDateTimeJavaType INSTANCE = new ZonedDateTimeJavaType();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public ZonedDateTimeJavaType() {
|
public ZonedDateTimeJavaType() {
|
||||||
super( ZonedDateTime.class, ImmutableMutabilityPlan.INSTANCE, ZonedDateTimeComparator.INSTANCE );
|
super( ZonedDateTime.class, ImmutableMutabilityPlan.instance(), ZonedDateTimeComparator.INSTANCE );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -52,12 +52,11 @@ public class RegistryHelper {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public <J> MutabilityPlan<J> determineMutabilityPlan(Type javaType, TypeConfiguration typeConfiguration) {
|
public <J> MutabilityPlan<J> determineMutabilityPlan(Type javaType, TypeConfiguration typeConfiguration) {
|
||||||
final Class<J> javaTypeClass = determineJavaTypeClass( javaType );
|
final Class<J> javaTypeClass = determineJavaTypeClass( javaType );
|
||||||
|
|
||||||
if ( javaTypeClass.isAnnotationPresent( Immutable.class ) ) {
|
if ( javaTypeClass.isAnnotationPresent( Immutable.class ) ) {
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
return ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( javaTypeClass.isAnnotationPresent( Mutability.class ) ) {
|
if ( javaTypeClass.isAnnotationPresent( Mutability.class ) ) {
|
||||||
|
@ -71,11 +70,11 @@ public class RegistryHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( javaTypeClass.isEnum() ) {
|
if ( javaTypeClass.isEnum() ) {
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
return ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( javaTypeClass.isPrimitive() ) {
|
if ( javaTypeClass.isPrimitive() ) {
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
return ImmutableMutabilityPlan.instance();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( Serializable.class.isAssignableFrom( javaTypeClass ) ) {
|
if ( Serializable.class.isAssignableFrom( javaTypeClass ) ) {
|
||||||
|
@ -85,7 +84,6 @@ public class RegistryHelper {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
private <J> JavaType<J> createTypeDescriptor(
|
private <J> JavaType<J> createTypeDescriptor(
|
||||||
Type javaType,
|
Type javaType,
|
||||||
Function<Class<J>,MutabilityPlan<J>> mutabilityPlanResolver) {
|
Function<Class<J>,MutabilityPlan<J>> mutabilityPlanResolver) {
|
||||||
|
@ -93,14 +91,14 @@ public class RegistryHelper {
|
||||||
|
|
||||||
if ( javaTypeClass.isEnum() ) {
|
if ( javaTypeClass.isEnum() ) {
|
||||||
// enums are unequivocally immutable
|
// enums are unequivocally immutable
|
||||||
//noinspection rawtypes
|
//noinspection rawtypes, unchecked
|
||||||
return new EnumJavaType( javaTypeClass );
|
return new EnumJavaType( javaTypeClass );
|
||||||
}
|
}
|
||||||
|
|
||||||
final MutabilityPlan<J> plan = mutabilityPlanResolver.apply( javaTypeClass );
|
final MutabilityPlan<J> plan = mutabilityPlanResolver.apply( javaTypeClass );
|
||||||
|
|
||||||
if ( Serializable.class.isAssignableFrom( javaTypeClass ) ) {
|
if ( Serializable.class.isAssignableFrom( javaTypeClass ) ) {
|
||||||
//noinspection rawtypes
|
//noinspection rawtypes, unchecked
|
||||||
return new SerializableJavaType( javaTypeClass, plan );
|
return new SerializableJavaType( javaTypeClass, plan );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,6 @@ public class ImmutableConvertedBasicTypeImpl<J> extends ConvertedBasicTypeImpl<J
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected MutabilityPlan<J> getMutabilityPlan() {
|
protected MutabilityPlan<J> getMutabilityPlan() {
|
||||||
//noinspection unchecked
|
return ImmutableMutabilityPlan.instance();
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,6 @@ public class ImmutableNamedBasicTypeImpl<J> extends NamedBasicTypeImpl<J> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected MutabilityPlan<J> getMutabilityPlan() {
|
protected MutabilityPlan<J> getMutabilityPlan() {
|
||||||
//noinspection unchecked
|
return ImmutableMutabilityPlan.instance();
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,7 @@ public class ExplicitJavaTypeDescriptorTest extends BaseNonConfigCoreFunctionalT
|
||||||
@After
|
@After
|
||||||
public void dropTestData() {
|
public void dropTestData() {
|
||||||
inTransaction(
|
inTransaction(
|
||||||
(session) -> session.createQuery( "delete TheEntity" ).executeUpdate()
|
session -> session.createQuery( "delete TheEntity" ).executeUpdate()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -320,8 +320,7 @@ public class ExplicitJavaTypeDescriptorTest extends BaseNonConfigCoreFunctionalT
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MutabilityPlan<PseudoMutableState> getMutabilityPlan() {
|
public MutabilityPlan<PseudoMutableState> getMutabilityPlan() {
|
||||||
//noinspection unchecked
|
return ImmutableMutabilityPlan.instance();
|
||||||
return ImmutableMutabilityPlan.INSTANCE;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
Loading…
Reference in New Issue