remove deprecated operations of MetamodelImplementor
This commit is contained in:
parent
fa9ab7bdae
commit
23324318fd
|
@ -41,8 +41,8 @@ public interface MappingMetamodel {
|
||||||
/**
|
/**
|
||||||
* todo (6.0) : POC!!! Intended for use in SQM -> SQL translation
|
* todo (6.0) : POC!!! Intended for use in SQM -> SQL translation
|
||||||
*/
|
*/
|
||||||
MappingModelExpressable resolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator);
|
MappingModelExpressable<?> resolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator);
|
||||||
MappingModelExpressable lenientlyResolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator);
|
MappingModelExpressable<?> lenientlyResolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Given a Java type, determine the corresponding BindableType to
|
* Given a Java type, determine the corresponding BindableType to
|
||||||
|
|
|
@ -17,7 +17,6 @@ import java.util.Set;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.function.Consumer;
|
import java.util.function.Consumer;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
import jakarta.persistence.EntityGraph;
|
|
||||||
import jakarta.persistence.metamodel.EmbeddableType;
|
import jakarta.persistence.metamodel.EmbeddableType;
|
||||||
import jakarta.persistence.metamodel.EntityType;
|
import jakarta.persistence.metamodel.EntityType;
|
||||||
import jakarta.persistence.metamodel.ManagedType;
|
import jakarta.persistence.metamodel.ManagedType;
|
||||||
|
@ -91,7 +90,6 @@ import static org.hibernate.metamodel.internal.JpaStaticMetaModelPopulationSetti
|
||||||
* @author Emmanuel Bernard
|
* @author Emmanuel Bernard
|
||||||
* @author Andrea Boriero
|
* @author Andrea Boriero
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplementor, Serializable {
|
public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplementor, Serializable {
|
||||||
// todo : Integrate EntityManagerLogger into CoreMessageLogger
|
// todo : Integrate EntityManagerLogger into CoreMessageLogger
|
||||||
private static final EntityManagerMessageLogger log = HEMLogging.messageLogger( MappingMetamodelImpl.class );
|
private static final EntityManagerMessageLogger log = HEMLogging.messageLogger( MappingMetamodelImpl.class );
|
||||||
|
@ -365,7 +363,6 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
return entityNameResolvers;
|
return entityNameResolvers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TypeConfiguration getTypeConfiguration() {
|
public TypeConfiguration getTypeConfiguration() {
|
||||||
return typeConfiguration;
|
return typeConfiguration;
|
||||||
|
@ -519,7 +516,6 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
throw new UnsupportedOperationException( );
|
throw new UnsupportedOperationException( );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String[] getImplementors(String className) throws MappingException {
|
public String[] getImplementors(String className) throws MappingException {
|
||||||
// computeIfAbsent() can be a contention point and we expect all the values to be in the map at some point so
|
// computeIfAbsent() can be a contention point and we expect all the values to be in the map at some point so
|
||||||
|
@ -644,11 +640,6 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
jpaMetamodel.addNamedEntityGraph( graphName, entityGraph );
|
jpaMetamodel.addNamedEntityGraph( graphName, entityGraph );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public <T> void addNamedEntityGraph(String graphName, EntityGraph<T> entityGraph) {
|
|
||||||
addNamedEntityGraph( graphName, (RootGraphImplementor<T>) entityGraph );
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public <T> RootGraphImplementor<T> findEntityGraphByName(String name) {
|
public <T> RootGraphImplementor<T> findEntityGraphByName(String name) {
|
||||||
return jpaMetamodel.findEntityGraphByName( name );
|
return jpaMetamodel.findEntityGraphByName( name );
|
||||||
|
@ -717,55 +708,53 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
private String[] doGetImplementors(Class<?> clazz) throws MappingException {
|
private String[] doGetImplementors(Class<?> clazz) throws MappingException {
|
||||||
ArrayList<String> results = new ArrayList<>();
|
ArrayList<String> results = new ArrayList<>();
|
||||||
for ( EntityPersister checkPersister : entityPersisters().values() ) {
|
for ( EntityPersister checkPersister : entityPersisters().values() ) {
|
||||||
if ( !Queryable.class.isInstance( checkPersister ) ) {
|
if ( checkPersister instanceof Queryable ) {
|
||||||
continue;
|
final Queryable checkQueryable = (Queryable) checkPersister;
|
||||||
}
|
final String checkQueryableEntityName = checkQueryable.getEntityName();
|
||||||
final Queryable checkQueryable = Queryable.class.cast( checkPersister );
|
final boolean isMappedClass = clazz.getName().equals( checkQueryableEntityName );
|
||||||
final String checkQueryableEntityName = checkQueryable.getEntityName();
|
if ( checkQueryable.isExplicitPolymorphism() ) {
|
||||||
final boolean isMappedClass = clazz.getName().equals( checkQueryableEntityName );
|
if ( isMappedClass ) {
|
||||||
if ( checkQueryable.isExplicitPolymorphism() ) {
|
return new String[] { clazz.getName() }; // NOTE EARLY EXIT
|
||||||
if ( isMappedClass ) {
|
}
|
||||||
return new String[] { clazz.getName() }; // NOTE EARLY EXIT
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if ( isMappedClass ) {
|
|
||||||
results.add( checkQueryableEntityName );
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
final Class<?> mappedClass = checkQueryable.getMappedClass();
|
if ( isMappedClass ) {
|
||||||
if ( mappedClass != null && clazz.isAssignableFrom( mappedClass ) ) {
|
results.add( checkQueryableEntityName );
|
||||||
final boolean assignableSuperclass;
|
}
|
||||||
if ( checkQueryable.isInherited() ) {
|
else {
|
||||||
Class<?> mappedSuperclass = entityPersister( checkQueryable.getMappedSuperclass() ).getMappedClass();
|
final Class<?> mappedClass = checkQueryable.getMappedClass();
|
||||||
assignableSuperclass = clazz.isAssignableFrom( mappedSuperclass );
|
if ( mappedClass != null && clazz.isAssignableFrom( mappedClass ) ) {
|
||||||
}
|
final boolean assignableSuperclass;
|
||||||
else {
|
if ( checkQueryable.isInherited() ) {
|
||||||
assignableSuperclass = false;
|
Class<?> mappedSuperclass = entityPersister( checkQueryable.getMappedSuperclass() ).getMappedClass();
|
||||||
}
|
assignableSuperclass = clazz.isAssignableFrom( mappedSuperclass );
|
||||||
if ( !assignableSuperclass ) {
|
}
|
||||||
results.add( checkQueryableEntityName );
|
else {
|
||||||
|
assignableSuperclass = false;
|
||||||
|
}
|
||||||
|
if ( !assignableSuperclass ) {
|
||||||
|
results.add( checkQueryableEntityName );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return results.toArray( new String[results.size()] );
|
return results.toArray( ArrayHelper.EMPTY_STRING_ARRAY );
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MappingModelExpressable lenientlyResolveMappingExpressable(
|
public MappingModelExpressable<?> lenientlyResolveMappingExpressable(
|
||||||
SqmExpressable<?> sqmExpressable,
|
SqmExpressable<?> sqmExpressable,
|
||||||
Function<NavigablePath, TableGroup> tableGroupLocator) {
|
Function<NavigablePath, TableGroup> tableGroupLocator) {
|
||||||
return resolveMappingExpressable( sqmExpressable, tableGroupLocator );
|
return resolveMappingExpressable( sqmExpressable, tableGroupLocator );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public MappingModelExpressable resolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator) {
|
public MappingModelExpressable<?> resolveMappingExpressable(SqmExpressable<?> sqmExpressable, Function<NavigablePath, TableGroup> tableGroupLocator) {
|
||||||
if ( sqmExpressable instanceof SqmPath ) {
|
if ( sqmExpressable instanceof SqmPath ) {
|
||||||
final SqmPath sqmPath = (SqmPath) sqmExpressable;
|
final SqmPath<?> sqmPath = (SqmPath<?>) sqmExpressable;
|
||||||
final NavigablePath navigablePath = sqmPath.getNavigablePath();
|
final NavigablePath navigablePath = sqmPath.getNavigablePath();
|
||||||
if ( navigablePath.getParent() != null ) {
|
if ( navigablePath.getParent() != null ) {
|
||||||
final TableGroup parentTableGroup = tableGroupLocator.apply( navigablePath.getParent() );
|
final TableGroup parentTableGroup = tableGroupLocator.apply( navigablePath.getParent() );
|
||||||
|
@ -775,7 +764,7 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( sqmExpressable instanceof BasicType<?> ) {
|
if ( sqmExpressable instanceof BasicType<?> ) {
|
||||||
return (BasicType) sqmExpressable;
|
return (BasicType<?>) sqmExpressable;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( sqmExpressable instanceof BasicSqmPathSource<?> ) {
|
if ( sqmExpressable instanceof BasicSqmPathSource<?> ) {
|
||||||
|
@ -791,7 +780,7 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( sqmExpressable instanceof EmbeddableTypeImpl ) {
|
if ( sqmExpressable instanceof EmbeddableTypeImpl ) {
|
||||||
return (MappingModelExpressable) sqmExpressable;
|
return (MappingModelExpressable<?>) sqmExpressable;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( sqmExpressable instanceof EntityDomainType<?> ) {
|
if ( sqmExpressable instanceof EntityDomainType<?> ) {
|
||||||
|
@ -808,7 +797,7 @@ public class MappingMetamodelImpl implements MappingMetamodel, MetamodelImplemen
|
||||||
for ( int i = 0; i < components.length; i++ ) {
|
for ( int i = 0; i < components.length; i++ ) {
|
||||||
components[i] = resolveMappingExpressable( tupleType.get( i ), tableGroupLocator );
|
components[i] = resolveMappingExpressable( tupleType.get( i ), tableGroupLocator );
|
||||||
}
|
}
|
||||||
final MappingModelExpressable createdMappingModelExpressable = new TupleMappingModelExpressable( components );
|
final MappingModelExpressable<?> createdMappingModelExpressable = new TupleMappingModelExpressable( components );
|
||||||
final MappingModelExpressable<?> existingMappingModelExpressable = tupleTypeCache.putIfAbsent(
|
final MappingModelExpressable<?> existingMappingModelExpressable = tupleTypeCache.putIfAbsent(
|
||||||
tupleType,
|
tupleType,
|
||||||
createdMappingModelExpressable
|
createdMappingModelExpressable
|
||||||
|
|
|
@ -7,18 +7,14 @@
|
||||||
package org.hibernate.metamodel.spi;
|
package org.hibernate.metamodel.spi;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import jakarta.persistence.EntityGraph;
|
|
||||||
|
|
||||||
import org.hibernate.EntityNameResolver;
|
import org.hibernate.EntityNameResolver;
|
||||||
import org.hibernate.MappingException;
|
import org.hibernate.MappingException;
|
||||||
import org.hibernate.Metamodel;
|
import org.hibernate.Metamodel;
|
||||||
import org.hibernate.engine.spi.SessionFactoryImplementor;
|
import org.hibernate.engine.spi.SessionFactoryImplementor;
|
||||||
import org.hibernate.graph.spi.RootGraphImplementor;
|
|
||||||
import org.hibernate.metamodel.MappingMetamodel;
|
import org.hibernate.metamodel.MappingMetamodel;
|
||||||
import org.hibernate.metamodel.model.domain.EntityDomainType;
|
|
||||||
import org.hibernate.persister.collection.CollectionPersister;
|
import org.hibernate.persister.collection.CollectionPersister;
|
||||||
import org.hibernate.persister.entity.EntityPersister;
|
import org.hibernate.persister.entity.EntityPersister;
|
||||||
|
|
||||||
|
@ -103,39 +99,16 @@ public interface MetamodelImplementor extends MappingMetamodel, Metamodel {
|
||||||
/**
|
/**
|
||||||
* Get the names of all entities known to this Metamodel
|
* Get the names of all entities known to this Metamodel
|
||||||
*
|
*
|
||||||
* @return All of the entity names
|
* @return All the entity names
|
||||||
*/
|
*/
|
||||||
String[] getAllEntityNames();
|
String[] getAllEntityNames();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the names of all collections known to this Metamodel
|
* Get the names of all collections known to this Metamodel
|
||||||
*
|
*
|
||||||
* @return All of the entity names
|
* @return All the entity names
|
||||||
*/
|
*/
|
||||||
String[] getAllCollectionRoles();
|
String[] getAllCollectionRoles();
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link #addNamedEntityGraph(String, RootGraphImplementor)} instead.
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
<T> void addNamedEntityGraph(String graphName, EntityGraph<T> entityGraph);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @deprecated Use {@link #findEntityGraphsByJavaType(Class)} instead.
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
default <T> List<EntityGraph<? super T>> findEntityGraphsByType(Class<T> entityClass) {
|
|
||||||
return (List) findEntityGraphsByJavaType( entityClass );
|
|
||||||
}
|
|
||||||
|
|
||||||
void close();
|
void close();
|
||||||
|
|
||||||
|
|
||||||
// ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
// Co-variant returns
|
|
||||||
|
|
||||||
@Override
|
|
||||||
default EntityDomainType getEntityTypeByName(String entityName) {
|
|
||||||
return entity( entityName );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue