fix some warnings
This commit is contained in:
parent
ec0f78d8c7
commit
c863838e72
|
@ -112,12 +112,9 @@ public abstract class AbstractGraph<J> extends AbstractGraphNode<J> implements G
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void visitAttributeNodes(Consumer<AttributeNodeImplementor<?>> consumer) {
|
public void visitAttributeNodes(Consumer<AttributeNodeImplementor<?>> consumer) {
|
||||||
if ( attrNodeMap == null ) {
|
if ( attrNodeMap != null ) {
|
||||||
return;
|
attrNodeMap.forEach( (attribute, nodeImplementor) -> consumer.accept( nodeImplementor ) );
|
||||||
}
|
}
|
||||||
attrNodeMap.forEach( (persistentAttribute, attributeNodeImplementor) -> {
|
|
||||||
consumer.accept( attributeNodeImplementor );
|
|
||||||
} );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -125,10 +122,12 @@ public abstract class AbstractGraph<J> extends AbstractGraphNode<J> implements G
|
||||||
if ( attrNodeMap == null ) {
|
if ( attrNodeMap == null ) {
|
||||||
return emptyList();
|
return emptyList();
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
final List<AttributeNode<?>> result = new ArrayList<>();
|
final List<AttributeNode<?>> result = new ArrayList<>();
|
||||||
visitAttributeNodes( result::add );
|
visitAttributeNodes( result::add );
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public AttributeNodeImplementor<?> addAttributeNode(AttributeNodeImplementor<?> incomingAttributeNode) {
|
public AttributeNodeImplementor<?> addAttributeNode(AttributeNodeImplementor<?> incomingAttributeNode) {
|
||||||
|
@ -209,8 +208,8 @@ public abstract class AbstractGraph<J> extends AbstractGraphNode<J> implements G
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override @SafeVarargs
|
||||||
public void addAttributeNodes(Attribute<? super J, ?>... attributes) {
|
public final void addAttributeNodes(Attribute<? super J, ?>... attributes) {
|
||||||
for ( int i = 0; i < attributes.length; i++ ) {
|
for ( int i = 0; i < attributes.length; i++ ) {
|
||||||
addAttributeNode( attributes[i] );
|
addAttributeNode( attributes[i] );
|
||||||
}
|
}
|
||||||
|
|
|
@ -231,16 +231,12 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static <Y> DomainType<Y> determineSimpleType(ValueContext typeContext, MetadataContext context) {
|
public static <Y> DomainType<Y> determineSimpleType(ValueContext typeContext, MetadataContext context) {
|
||||||
switch ( typeContext.getValueClassification() ) {
|
return switch ( typeContext.getValueClassification() ) {
|
||||||
case BASIC:
|
case BASIC -> basicDomainType( typeContext, context );
|
||||||
return basicDomainType( typeContext, context );
|
case ENTITY -> entityDomainType (typeContext, context );
|
||||||
case ENTITY:
|
case EMBEDDABLE -> embeddableDomainType( typeContext, context );
|
||||||
return entityDomainType( typeContext, context );
|
default -> throw new AssertionFailure( "Unknown type : " + typeContext.getValueClassification() );
|
||||||
case EMBEDDABLE:
|
};
|
||||||
return embeddableDomainType( typeContext, context );
|
|
||||||
default:
|
|
||||||
throw new AssertionFailure( "Unknown type : " + typeContext.getValueClassification() );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static <Y> EmbeddableDomainType<Y> embeddableDomainType(ValueContext typeContext, MetadataContext context) {
|
private static <Y> EmbeddableDomainType<Y> embeddableDomainType(ValueContext typeContext, MetadataContext context) {
|
||||||
|
@ -339,8 +335,7 @@ public class AttributeFactory {
|
||||||
|
|
||||||
private static <Y> DomainType<Y> entityDomainType(ValueContext typeContext, MetadataContext context) {
|
private static <Y> DomainType<Y> entityDomainType(ValueContext typeContext, MetadataContext context) {
|
||||||
final org.hibernate.type.Type type = typeContext.getHibernateValue().getType();
|
final org.hibernate.type.Type type = typeContext.getHibernateValue().getType();
|
||||||
if ( type instanceof EntityType ) {
|
if ( type instanceof EntityType entityType ) {
|
||||||
final EntityType entityType = (EntityType) type;
|
|
||||||
final IdentifiableDomainType<Y> domainType =
|
final IdentifiableDomainType<Y> domainType =
|
||||||
context.locateIdentifiableType( entityType.getAssociatedEntityName() );
|
context.locateIdentifiableType( entityType.getAssociatedEntityName() );
|
||||||
if ( domainType == null ) {
|
if ( domainType == null ) {
|
||||||
|
@ -378,11 +373,11 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
final org.hibernate.type.Type type = hibernateValue.getType();
|
final org.hibernate.type.Type type = hibernateValue.getType();
|
||||||
if ( type instanceof BasicPluralType<?, ?> ) {
|
if ( type instanceof BasicPluralType<?, ?> pluralType ) {
|
||||||
final JavaType<?> javaTypeDescriptor = ( (BasicPluralType<?, ?>) type ).getElementType()
|
if ( pluralType.getElementType().getJavaTypeDescriptor()
|
||||||
.getJavaTypeDescriptor();
|
instanceof EmbeddableAggregateJavaType<?> ) {
|
||||||
if ( javaTypeDescriptor instanceof EmbeddableAggregateJavaType<?> ) {
|
final AggregateColumn aggregateColumn =
|
||||||
final AggregateColumn aggregateColumn = (AggregateColumn) hibernateValue.getColumns().get( 0 );
|
(AggregateColumn) hibernateValue.getColumns().get( 0 );
|
||||||
classEmbeddableType( context, aggregateColumn.getComponent() );
|
classEmbeddableType( context, aggregateColumn.getComponent() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -483,18 +478,15 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
else if ( type instanceof CollectionType ) {
|
else if ( type instanceof CollectionType ) {
|
||||||
// collection
|
// collection
|
||||||
if ( value instanceof Collection ) {
|
if ( value instanceof Collection collection ) {
|
||||||
final Collection collValue = (Collection) value;
|
final org.hibernate.type.Type elementType = collection.getElement().getType();
|
||||||
final Value elementValue = collValue.getElement();
|
|
||||||
final org.hibernate.type.Type elementType = elementValue.getType();
|
|
||||||
final boolean isManyToMany = isManyToMany( member );
|
final boolean isManyToMany = isManyToMany( member );
|
||||||
|
|
||||||
return new PluralAttributeMetadataImpl<>(
|
return new PluralAttributeMetadataImpl<>(
|
||||||
propertyMapping,
|
propertyMapping,
|
||||||
attributeContext.getOwnerType(),
|
attributeContext.getOwnerType(),
|
||||||
member,
|
member,
|
||||||
collectionClassification( elementType, elementValue, isManyToMany ),
|
collectionClassification( elementType, isManyToMany ),
|
||||||
elementClassification( elementType, elementValue, isManyToMany ),
|
elementClassification( elementType, isManyToMany ),
|
||||||
indexClassification( value ),
|
indexClassification( value ),
|
||||||
context
|
context
|
||||||
);
|
);
|
||||||
|
@ -544,9 +536,8 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static AttributeClassification indexClassification(Value value) {
|
private static AttributeClassification indexClassification(Value value) {
|
||||||
if ( value instanceof Map ) {
|
if ( value instanceof Map map ) {
|
||||||
final Value keyValue = ( (Map) value).getIndex();
|
return keyClassification( map.getIndex().getType() );
|
||||||
return keyClassification( keyValue.getType(), keyValue );
|
|
||||||
}
|
}
|
||||||
else if ( value instanceof List ) {
|
else if ( value instanceof List ) {
|
||||||
return AttributeClassification.BASIC;
|
return AttributeClassification.BASIC;
|
||||||
|
@ -557,7 +548,7 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static AttributeClassification elementClassification(
|
private static AttributeClassification elementClassification(
|
||||||
org.hibernate.type.Type elementType, Value elementValue, boolean isManyToMany) {
|
org.hibernate.type.Type elementType, boolean isManyToMany) {
|
||||||
// First, determine the type of the elements and use that to help determine the
|
// First, determine the type of the elements and use that to help determine the
|
||||||
// collection type
|
// collection type
|
||||||
if ( elementType instanceof AnyType ) {
|
if ( elementType instanceof AnyType ) {
|
||||||
|
@ -577,7 +568,7 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static AttributeClassification collectionClassification(
|
private static AttributeClassification collectionClassification(
|
||||||
org.hibernate.type.Type elementType, Value elementValue, boolean isManyToMany) {
|
org.hibernate.type.Type elementType, boolean isManyToMany) {
|
||||||
if ( elementType instanceof EntityType ) {
|
if ( elementType instanceof EntityType ) {
|
||||||
return isManyToMany ?
|
return isManyToMany ?
|
||||||
AttributeClassification.MANY_TO_MANY :
|
AttributeClassification.MANY_TO_MANY :
|
||||||
|
@ -588,7 +579,7 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static AttributeClassification keyClassification(org.hibernate.type.Type keyType, Value keyValue) {
|
private static AttributeClassification keyClassification(org.hibernate.type.Type keyType) {
|
||||||
if ( keyType instanceof AnyType ) {
|
if ( keyType instanceof AnyType ) {
|
||||||
return AttributeClassification.ANY;
|
return AttributeClassification.ANY;
|
||||||
}
|
}
|
||||||
|
@ -604,47 +595,48 @@ public class AttributeFactory {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static AttributeClassification determineSingularAssociationClassification(Member member) {
|
public static AttributeClassification determineSingularAssociationClassification(Member member) {
|
||||||
if ( member instanceof Field ) {
|
if ( member instanceof Field field ) {
|
||||||
return ( (Field) member ).getAnnotation( OneToOne.class ) != null
|
return field.getAnnotation( OneToOne.class ) != null
|
||||||
? AttributeClassification.ONE_TO_ONE
|
? AttributeClassification.ONE_TO_ONE
|
||||||
: AttributeClassification.MANY_TO_ONE;
|
: AttributeClassification.MANY_TO_ONE;
|
||||||
}
|
}
|
||||||
else if ( member instanceof MapMember ) {
|
else if ( member instanceof MapMember ) {
|
||||||
return AttributeClassification.MANY_TO_ONE; // curious to see how this works for non-annotated methods
|
return AttributeClassification.MANY_TO_ONE; // curious to see how this works for non-annotated methods
|
||||||
}
|
}
|
||||||
else {
|
else if ( member instanceof Method method) {
|
||||||
return ( (Method) member ).getAnnotation( OneToOne.class ) != null
|
return method.getAnnotation( OneToOne.class ) != null
|
||||||
? AttributeClassification.ONE_TO_ONE
|
? AttributeClassification.ONE_TO_ONE
|
||||||
: AttributeClassification.MANY_TO_ONE;
|
: AttributeClassification.MANY_TO_ONE;
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
throw new AssertionFailure( "Unexpected member type" );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ParameterizedType getSignatureType(Member member) {
|
public static ParameterizedType getSignatureType(Member member) {
|
||||||
final java.lang.reflect.Type type;
|
final java.lang.reflect.Type type;
|
||||||
if ( member instanceof Field ) {
|
if ( member instanceof Field field ) {
|
||||||
type = ( (Field) member ).getGenericType();
|
type = field.getGenericType();
|
||||||
}
|
}
|
||||||
else if ( member instanceof Method ) {
|
else if ( member instanceof Method method ) {
|
||||||
type = ( (Method) member ).getGenericReturnType();
|
type = method.getGenericReturnType();
|
||||||
|
}
|
||||||
|
else if ( member instanceof MapMember mapMember ) {
|
||||||
|
type = mapMember.getType();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
type = ( (MapMember) member ).getType();
|
throw new AssertionFailure( "Unexpected member type" );
|
||||||
}
|
}
|
||||||
//this is a raw type
|
//this is a raw type
|
||||||
if ( type instanceof Class ) {
|
return type instanceof Class ? null : (ParameterizedType) type;
|
||||||
return null;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return (ParameterizedType) type;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isManyToMany(Member member) {
|
public static boolean isManyToMany(Member member) {
|
||||||
if ( member instanceof Field ) {
|
if ( member instanceof Field field ) {
|
||||||
return ( (Field) member ).getAnnotation( ManyToMany.class ) != null;
|
return field.getAnnotation( ManyToMany.class ) != null;
|
||||||
}
|
}
|
||||||
else if ( member instanceof Method ) {
|
else if ( member instanceof Method method ) {
|
||||||
return ( (Method) member ).getAnnotation( ManyToMany.class ) != null;
|
return method.getAnnotation( ManyToMany.class ) != null;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -74,15 +74,10 @@ public abstract class AbstractIdentifiableType<J>
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected InFlightAccessImpl createInFlightAccess() {
|
protected InFlightAccess<J> createInFlightAccess() {
|
||||||
return new InFlightAccessImpl( super.createInFlightAccess() );
|
return new InFlightAccessImpl( super.createInFlightAccess() );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public InFlightAccessImpl getInFlightAccess() {
|
|
||||||
return (InFlightAccessImpl) super.getInFlightAccess();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SqmPathSource<?> getIdentifierDescriptor() {
|
public SqmPathSource<?> getIdentifierDescriptor() {
|
||||||
return identifierDescriptor;
|
return identifierDescriptor;
|
||||||
|
|
|
@ -599,7 +599,7 @@ public class JpaMetamodelImpl implements JpaMetamodelImplementor, Serializable {
|
||||||
Collection<NamedEntityGraphDefinition> namedEntityGraphDefinitions,
|
Collection<NamedEntityGraphDefinition> namedEntityGraphDefinitions,
|
||||||
RuntimeModelCreationContext runtimeModelCreationContext) {
|
RuntimeModelCreationContext runtimeModelCreationContext) {
|
||||||
bootMetamodel.getImports()
|
bootMetamodel.getImports()
|
||||||
.forEach( ( k, v ) -> this.nameToImportMap.put( k, new ImportInfo<>( v, null ) ) );
|
.forEach( (key, value) -> this.nameToImportMap.put( key, new ImportInfo<>( value, null ) ) );
|
||||||
this.entityProxyInterfaceMap.putAll( entityProxyInterfaceMap );
|
this.entityProxyInterfaceMap.putAll( entityProxyInterfaceMap );
|
||||||
|
|
||||||
final MetadataContext context = new MetadataContext(
|
final MetadataContext context = new MetadataContext(
|
||||||
|
|
Loading…
Reference in New Issue