HHH-6371 - Develop metamodel binding creation using a push approach

This commit is contained in:
Steve Ebersole 2011-06-30 21:34:19 -05:00 committed by Steve Ebersole
parent 182150769a
commit 5efd0a8471
13 changed files with 345 additions and 57 deletions

View File

@ -12,6 +12,7 @@ allprojects {
buildscript { buildscript {
repositories { repositories {
mavenCentral()
mavenLocal() mavenLocal()
mavenRepo name: 'jboss-nexus', urls: "https://repository.jboss.org/nexus/content/groups/public/" mavenRepo name: 'jboss-nexus', urls: "https://repository.jboss.org/nexus/content/groups/public/"
mavenRepo name: "jboss-snapshots", urls: "http://snapshots.jboss.org/maven2/" mavenRepo name: "jboss-snapshots", urls: "http://snapshots.jboss.org/maven2/"

View File

@ -41,6 +41,7 @@ import org.hibernate.metamodel.source.Origin;
import org.hibernate.metamodel.source.hbm.HbmBindingContext; import org.hibernate.metamodel.source.hbm.HbmBindingContext;
import org.hibernate.metamodel.source.hbm.HbmHelper; import org.hibernate.metamodel.source.hbm.HbmHelper;
import org.hibernate.metamodel.source.hbm.util.MappingHelper; import org.hibernate.metamodel.source.hbm.util.MappingHelper;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLCacheElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLCacheElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLSqlDeleteElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLSqlDeleteElement;
@ -53,6 +54,8 @@ import org.hibernate.persister.entity.EntityPersister;
import org.hibernate.tuple.entity.EntityTuplizer; import org.hibernate.tuple.entity.EntityTuplizer;
/** /**
* TODO : thinking it might be better to have one of these for distinct mapping type (root, subclass, joined, etc)
*
* @author Gail Badner * @author Gail Badner
* @author Steve Ebersole * @author Steve Ebersole
*/ */
@ -102,7 +105,7 @@ public class EntityViewImpl implements EntityView {
public EntityViewImpl( public EntityViewImpl(
Hierarchical superType, Hierarchical superType,
XMLHibernateMapping.XMLClass entityClazz, EntityElement entityClazz,
boolean isRoot, boolean isRoot,
InheritanceType inheritanceType, InheritanceType inheritanceType,
HbmBindingContext bindingContext) { HbmBindingContext bindingContext) {
@ -110,7 +113,7 @@ public class EntityViewImpl implements EntityView {
this.bindingContext = bindingContext; this.bindingContext = bindingContext;
this.superType = superType; this.superType = superType;
this.entityName = bindingContext.extractEntityName( entityClazz ); this.entityName = bindingContext.determineEntityName( entityClazz );
final String verbatimClassName = entityClazz.getName(); final String verbatimClassName = entityClazz.getName();
this.entityMode = verbatimClassName == null ? EntityMode.MAP : EntityMode.POJO; this.entityMode = verbatimClassName == null ? EntityMode.MAP : EntityMode.POJO;
@ -135,7 +138,7 @@ public class EntityViewImpl implements EntityView {
this.isRoot = isRoot; this.isRoot = isRoot;
this.entityInheritanceType = inheritanceType; this.entityInheritanceType = inheritanceType;
this.caching = createCaching( entityClazz, bindingContext.extractEntityName( entityClazz ) ); this.caching = isRoot ? createCaching( entityClazz, this.entityName ) : null;
this.metaAttributeContext = HbmHelper.extractMetaAttributeContext( this.metaAttributeContext = HbmHelper.extractMetaAttributeContext(
entityClazz.getMeta(), true, bindingContext.getMetaAttributeContext() entityClazz.getMeta(), true, bindingContext.getMetaAttributeContext()
@ -215,11 +218,11 @@ public class EntityViewImpl implements EntityView {
); );
} }
private String extractCustomTuplizerClassName(XMLHibernateMapping.XMLClass entityClazz, EntityMode entityMode) { private String extractCustomTuplizerClassName(EntityElement entityMapping, EntityMode entityMode) {
if ( entityClazz.getTuplizer() == null ) { if ( entityMapping.getTuplizer() == null ) {
return null; return null;
} }
for ( XMLTuplizerElement tuplizerElement : entityClazz.getTuplizer() ) { for ( XMLTuplizerElement tuplizerElement : entityMapping.getTuplizer() ) {
if ( entityMode == EntityMode.parse( tuplizerElement.getEntityMode() ) ) { if ( entityMode == EntityMode.parse( tuplizerElement.getEntityMode() ) ) {
return tuplizerElement.getClazz(); return tuplizerElement.getClazz();
} }
@ -227,8 +230,13 @@ public class EntityViewImpl implements EntityView {
return null; return null;
} }
private static Caching createCaching(XMLHibernateMapping.XMLClass entityClazz, String entityName) { private static Caching createCaching(EntityElement entityMapping, String entityName) {
XMLCacheElement cache = entityClazz.getCache(); if ( ! XMLHibernateMapping.XMLClass.class.isInstance( entityMapping ) ) {
// only the root entity can define caching
return null;
}
final XMLHibernateMapping.XMLClass rootEntityMapping = (XMLHibernateMapping.XMLClass) entityMapping;
XMLCacheElement cache = rootEntityMapping.getCache();
if ( cache == null ) { if ( cache == null ) {
return null; return null;
} }

View File

@ -137,7 +137,7 @@ abstract class AbstractEntityBinder {
final String entityName = entityBinding.getEntity().getName(); final String entityName = entityBinding.getEntity().getName();
if ( entityClazz.getFetchProfile() != null ) { if ( entityClazz.getFetchProfile() != null ) {
bindingContext.bindFetchProfiles( entityClazz.getFetchProfile(), entityName ); bindingContext.processFetchProfiles( entityClazz.getFetchProfile(), entityName );
} }
getMetadata().addImport( entityName, entityName ); getMetadata().addImport( entityName, entityName );

View File

@ -26,12 +26,13 @@ package org.hibernate.metamodel.source.hbm;
import org.hibernate.metamodel.binder.EntityBinder; import org.hibernate.metamodel.binder.EntityBinder;
import org.hibernate.metamodel.binder.view.hbm.EntityViewImpl; import org.hibernate.metamodel.binder.view.hbm.EntityViewImpl;
import org.hibernate.metamodel.binding.EntityBinding; import org.hibernate.metamodel.binding.EntityBinding;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping;
/** /**
* @author Steve Ebersole * @author Steve Ebersole
*/ */
public class EntityProcessor { public abstract class EntityProcessor {
private final HbmBindingContext bindingContext; private final HbmBindingContext bindingContext;
private final EntityBinder entityBinder; private final EntityBinder entityBinder;
@ -40,17 +41,17 @@ public class EntityProcessor {
this.entityBinder = new EntityBinder( bindingContext.getMetadataImplementor() ); this.entityBinder = new EntityBinder( bindingContext.getMetadataImplementor() );
} }
public void process(XMLHibernateMapping.XMLClass xmlClass) { public void process(EntityElement entityMapping) {
EntityBinding entityBinding = entityBinder.createEntityBinding( EntityBinding entityBinding = entityBinder.createEntityBinding(
new EntityViewImpl( new EntityViewImpl(
null, // superType null, // superType
xmlClass, entityMapping,
true, // isRoot true, // isRoot
null, // inheritanceType null, // inheritanceType
bindingContext bindingContext
) )
); );
bindingContext. bindingContext.getMetadataImplementor().addEntity( entityBinding );
} }
} }

View File

@ -25,8 +25,8 @@ package org.hibernate.metamodel.source.hbm;
import java.util.List; import java.util.List;
import org.hibernate.internal.util.xml.XmlDocument;
import org.hibernate.metamodel.source.Origin; import org.hibernate.metamodel.source.Origin;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLFetchProfileElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLFetchProfileElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping;
import org.hibernate.metamodel.source.spi.BindingContext; import org.hibernate.metamodel.source.spi.BindingContext;
@ -37,11 +37,12 @@ import org.hibernate.metamodel.source.spi.BindingContext;
public interface HbmBindingContext extends BindingContext { public interface HbmBindingContext extends BindingContext {
public boolean isAutoImport(); public boolean isAutoImport();
public Origin getOrigin();
public String extractEntityName(XMLHibernateMapping.XMLClass entityClazz); public String extractEntityName(XMLHibernateMapping.XMLClass entityClazz);
public String determineEntityName(EntityElement entityElement);
public String getClassName(String unqualifiedName); public String getClassName(String unqualifiedName);
public void bindFetchProfiles(List<XMLFetchProfileElement> fetchProfiles, String containingEntityName); public void processFetchProfiles(List<XMLFetchProfileElement> fetchProfiles, String containingEntityName);
public Origin getOrigin();
} }

View File

@ -34,6 +34,7 @@ import org.hibernate.MappingException;
import org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle; import org.hibernate.engine.spi.ExecuteUpdateResultCheckStyle;
import org.hibernate.metamodel.binding.CustomSQL; import org.hibernate.metamodel.binding.CustomSQL;
import org.hibernate.metamodel.binding.MetaAttribute; import org.hibernate.metamodel.binding.MetaAttribute;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping.XMLClass; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping.XMLClass;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLMetaElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLMetaElement;
import org.hibernate.metamodel.source.hbm.util.MappingHelper; import org.hibernate.metamodel.source.hbm.util.MappingHelper;
@ -102,6 +103,14 @@ public class HbmHelper {
return entityName == null ? getClassName( entityClassName, unqualifiedPackageName ) : entityName; return entityName == null ? getClassName( entityClassName, unqualifiedPackageName ) : entityName;
} }
public static String determineEntityName(EntityElement entityElement, String packageName) {
return extractEntityName( entityElement.getEntityName(), entityElement.getName(), packageName );
}
public static String determineClassName(EntityElement entityElement, String packageName) {
return getClassName( entityElement.getName(), packageName );
}
public static String getClassName(Attribute att, String unqualifiedPackageName) { public static String getClassName(Attribute att, String unqualifiedPackageName) {
if ( att == null ) { if ( att == null ) {
return null; return null;

View File

@ -24,13 +24,20 @@
package org.hibernate.metamodel.source.hbm; package org.hibernate.metamodel.source.hbm;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.List; import java.util.List;
import java.util.Set;
import org.hibernate.MappingException;
import org.hibernate.metamodel.MetadataSources; import org.hibernate.metamodel.MetadataSources;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.SubclassEntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping;
import org.hibernate.metamodel.source.internal.JaxbRoot; import org.hibernate.metamodel.source.internal.JaxbRoot;
import org.hibernate.metamodel.source.spi.SourceProcessor;
import org.hibernate.metamodel.source.spi.MetadataImplementor; import org.hibernate.metamodel.source.spi.MetadataImplementor;
import org.hibernate.metamodel.source.spi.SourceProcessor;
/** /**
* Responsible for performing binding of hbm xml. * Responsible for performing binding of hbm xml.
@ -57,28 +64,118 @@ public class HbmSourceProcessor implements SourceProcessor {
@Override @Override
public void processIndependentMetadata(MetadataSources sources) { public void processIndependentMetadata(MetadataSources sources) {
for ( HibernateMappingProcessor processor : processors ) { for ( HibernateMappingProcessor processor : processors ) {
processor.bindIndependentMetadata(); processor.processIndependentMetadata();
} }
} }
@Override @Override
public void processTypeDependentMetadata(MetadataSources sources) { public void processTypeDependentMetadata(MetadataSources sources) {
for ( HibernateMappingProcessor processor : processors ) { for ( HibernateMappingProcessor processor : processors ) {
processor.bindTypeDependentMetadata(); processor.processTypeDependentMetadata();
} }
} }
@Override @Override
public void processMappingMetadata(MetadataSources sources, List<String> processedEntityNames) { public void processMappingMetadata(MetadataSources sources, List<String> processedEntityNames) {
// Lets get the entities into a better order for processing based on inheritance hierarchy to avoid the need
// for an "extends queue". Really, for correctly, we localize the "extends queue" to just this method stack.
//
// The variable entityMappingByEntityNameMap holds the "resolved" mappings, keyed by entity name. It uses a
// linked map because the order is important here as we will use it to track which entities depend on which
// other entities.
//
// The extendsQueue variable is a temporary queue where we place mappings which have an extends but for which
// we could not find the referenced entity being extended.
final Set<String> availableEntityNames = new HashSet<String>();
availableEntityNames.addAll( processedEntityNames );
final LinkedHashSet<HibernateMappingProcessor> orderedProcessors = new LinkedHashSet<HibernateMappingProcessor>();
final Set<ExtendsQueueEntry> extendsQueue = new HashSet<ExtendsQueueEntry>();
for ( HibernateMappingProcessor processor : processors ) { for ( HibernateMappingProcessor processor : processors ) {
processor.bindMappingMetadata( processedEntityNames ); final HibernateMappingInformation hibernateMappingInformation = new HibernateMappingInformation( processor );
ExtendsQueueEntry extendsQueueEntry = null;
for ( Object entityElementO : processor.getHibernateMapping().getClazzOrSubclassOrJoinedSubclass() ) {
final EntityElement entityElement = (EntityElement) entityElementO;
final String entityName = processor.determineEntityName( entityElement );
hibernateMappingInformation.includedEntityNames.add( entityName );
if ( SubclassEntityElement.class.isInstance( entityElement ) ) {
final String entityItExtends = ( (SubclassEntityElement) entityElement ).getExtends();
if ( ! availableEntityNames.contains( entityItExtends ) ) {
if ( extendsQueueEntry == null ) {
extendsQueueEntry = new ExtendsQueueEntry( hibernateMappingInformation );
extendsQueue.add( extendsQueueEntry );
}
extendsQueueEntry.waitingOnEntityNames.add( entityItExtends );
}
}
}
if ( extendsQueueEntry == null ) {
// we found no extends names that we have to wait on
orderedProcessors.add( processor );
availableEntityNames.addAll( hibernateMappingInformation.includedEntityNames );
}
}
while ( ! extendsQueue.isEmpty() ) {
// set up a pass over the queue
int numberOfMappingsProcessed = 0;
Iterator<ExtendsQueueEntry> iterator = extendsQueue.iterator();
while ( iterator.hasNext() ) {
final ExtendsQueueEntry entry = iterator.next();
if ( availableEntityNames.containsAll( entry.waitingOnEntityNames ) ) {
// all the entity names this entry was waiting on have been made available
iterator.remove();
orderedProcessors.add( entry.hibernateMappingInformation.processor );
availableEntityNames.addAll( entry.hibernateMappingInformation.includedEntityNames );
numberOfMappingsProcessed++;
}
}
if ( numberOfMappingsProcessed == 0 ) {
// todo : we could log the waiting dependencies...
throw new MappingException( "Unable to process extends dependencies in hbm files" );
}
}
for ( HibernateMappingProcessor processor : orderedProcessors ) {
processor.processMappingMetadata( processedEntityNames );
}
}
private static class HibernateMappingInformation {
private final HibernateMappingProcessor processor;
private final Set<String> includedEntityNames = new HashSet<String>();
private HibernateMappingInformation(HibernateMappingProcessor processor) {
this.processor = processor;
}
}
private static class ExtendsQueueEntry {
private HibernateMappingInformation hibernateMappingInformation;
private final Set<String> waitingOnEntityNames = new HashSet<String>();
private ExtendsQueueEntry(HibernateMappingInformation hibernateMappingInformation) {
this.hibernateMappingInformation = hibernateMappingInformation;
} }
} }
@Override @Override
public void processMappingDependentMetadata(MetadataSources sources) { public void processMappingDependentMetadata(MetadataSources sources) {
for ( HibernateMappingProcessor processor : processors ) { for ( HibernateMappingProcessor processor : processors ) {
processor.bindMappingDependentMetadata(); processor.processMappingDependentMetadata();
} }
} }
} }

View File

@ -32,6 +32,7 @@ import java.util.Set;
import org.hibernate.cfg.NamingStrategy; import org.hibernate.cfg.NamingStrategy;
import org.hibernate.engine.spi.FilterDefinition; import org.hibernate.engine.spi.FilterDefinition;
import org.hibernate.internal.util.StringHelper; import org.hibernate.internal.util.StringHelper;
import org.hibernate.internal.util.Value;
import org.hibernate.metamodel.binding.FetchProfile; import org.hibernate.metamodel.binding.FetchProfile;
import org.hibernate.metamodel.binding.TypeDef; import org.hibernate.metamodel.binding.TypeDef;
import org.hibernate.metamodel.domain.JavaType; import org.hibernate.metamodel.domain.JavaType;
@ -39,6 +40,7 @@ import org.hibernate.metamodel.relational.AuxiliaryDatabaseObject;
import org.hibernate.metamodel.relational.BasicAuxiliaryDatabaseObjectImpl; import org.hibernate.metamodel.relational.BasicAuxiliaryDatabaseObjectImpl;
import org.hibernate.metamodel.source.MappingException; import org.hibernate.metamodel.source.MappingException;
import org.hibernate.metamodel.source.Origin; import org.hibernate.metamodel.source.Origin;
import org.hibernate.metamodel.source.hbm.xml.mapping.EntityElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLFetchProfileElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLFetchProfileElement;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLHibernateMapping;
import org.hibernate.metamodel.source.hbm.xml.mapping.XMLJoinedSubclassElement; import org.hibernate.metamodel.source.hbm.xml.mapping.XMLJoinedSubclassElement;
@ -85,8 +87,8 @@ public class HibernateMappingProcessor implements HbmBindingContext {
hibernateMapping.getPackage(), hibernateMapping.getPackage(),
hibernateMapping.getSchema(), hibernateMapping.getSchema(),
hibernateMapping.getCatalog(), hibernateMapping.getCatalog(),
null, null, // idColumnName
null, null, // discriminatorColumnName
hibernateMapping.getDefaultCascade(), hibernateMapping.getDefaultCascade(),
hibernateMapping.getDefaultAccess(), hibernateMapping.getDefaultAccess(),
hibernateMapping.isDefaultLazy() hibernateMapping.isDefaultLazy()
@ -103,6 +105,10 @@ public class HibernateMappingProcessor implements HbmBindingContext {
: HbmHelper.extractMetaAttributeContext( hibernateMapping.getMeta(), true, metadata.getMetaAttributeContext() ); : HbmHelper.extractMetaAttributeContext( hibernateMapping.getMeta(), true, metadata.getMetaAttributeContext() );
} }
XMLHibernateMapping getHibernateMapping() {
return hibernateMapping;
}
@Override @Override
public boolean isAutoImport() { public boolean isAutoImport() {
return autoImport; return autoImport;
@ -153,12 +159,12 @@ public class HibernateMappingProcessor implements HbmBindingContext {
return metadata.makeJavaType( className ); return metadata.makeJavaType( className );
} }
public void bindIndependentMetadata() { public void processIndependentMetadata() {
bindDatabaseObjectDefinitions(); processDatabaseObjectDefinitions();
bindTypeDefinitions(); processTypeDefinitions();
} }
private void bindDatabaseObjectDefinitions() { private void processDatabaseObjectDefinitions() {
if ( hibernateMapping.getDatabaseObject() == null ) { if ( hibernateMapping.getDatabaseObject() == null ) {
return; return;
} }
@ -167,7 +173,7 @@ public class HibernateMappingProcessor implements HbmBindingContext {
if ( databaseObjectElement.getDefinition() != null ) { if ( databaseObjectElement.getDefinition() != null ) {
final String className = databaseObjectElement.getDefinition().getClazz(); final String className = databaseObjectElement.getDefinition().getClazz();
try { try {
auxiliaryDatabaseObject = (AuxiliaryDatabaseObject) classLoaderService().classForName( className ).newInstance(); auxiliaryDatabaseObject = (AuxiliaryDatabaseObject) classLoaderService.getValue().classForName( className ).newInstance();
} }
catch (ClassLoadingException e) { catch (ClassLoadingException e) {
throw e; throw e;
@ -196,7 +202,7 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
private void bindTypeDefinitions() { private void processTypeDefinitions() {
if ( hibernateMapping.getTypedef() == null ) { if ( hibernateMapping.getTypedef() == null ) {
return; return;
} }
@ -209,12 +215,12 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
public void bindTypeDependentMetadata() { public void processTypeDependentMetadata() {
bindFilterDefinitions(); processFilterDefinitions();
bindIdentifierGenerators(); processIdentifierGenerators();
} }
private void bindFilterDefinitions() { private void processFilterDefinitions() {
if(hibernateMapping.getFilterDef() == null){ if(hibernateMapping.getFilterDef() == null){
return; return;
} }
@ -249,7 +255,7 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
private void bindIdentifierGenerators() { private void processIdentifierGenerators() {
if ( hibernateMapping.getIdentifierGenerator() == null ) { if ( hibernateMapping.getIdentifierGenerator() == null ) {
return; return;
} }
@ -262,10 +268,17 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
public void bindMappingMetadata(List<String> processedEntityNames) { public void processMappingMetadata(List<String> processedEntityNames) {
if ( hibernateMapping.getClazzOrSubclassOrJoinedSubclass() == null ) { if ( hibernateMapping.getClazzOrSubclassOrJoinedSubclass() == null ) {
return; return;
} }
for ( Object entityElementO : hibernateMapping.getClazzOrSubclassOrJoinedSubclass() ) {
final EntityElement entityElement = (EntityElement) entityElementO;
}
for ( Object clazzOrSubclass : hibernateMapping.getClazzOrSubclassOrJoinedSubclass() ) { for ( Object clazzOrSubclass : hibernateMapping.getClazzOrSubclassOrJoinedSubclass() ) {
if ( XMLHibernateMapping.XMLClass.class.isInstance( clazzOrSubclass ) ) { if ( XMLHibernateMapping.XMLClass.class.isInstance( clazzOrSubclass ) ) {
XMLHibernateMapping.XMLClass clazz = XMLHibernateMapping.XMLClass clazz =
@ -293,21 +306,21 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
public void bindMappingDependentMetadata() { public void processMappingDependentMetadata() {
bindFetchProfiles(); processFetchProfiles();
bindImports(); processImports();
bindResultSetMappings(); processResultSetMappings();
bindNamedQueries(); processNamedQueries();
} }
private void bindFetchProfiles(){ private void processFetchProfiles(){
if(hibernateMapping.getFetchProfile() == null){ if ( hibernateMapping.getFetchProfile() == null ) {
return; return;
} }
bindFetchProfiles( hibernateMapping.getFetchProfile(),null ); processFetchProfiles( hibernateMapping.getFetchProfile(), null );
} }
public void bindFetchProfiles(List<XMLFetchProfileElement> fetchProfiles, String containingEntityName) { public void processFetchProfiles(List<XMLFetchProfileElement> fetchProfiles, String containingEntityName) {
for ( XMLFetchProfileElement fetchProfile : fetchProfiles ) { for ( XMLFetchProfileElement fetchProfile : fetchProfiles ) {
String profileName = fetchProfile.getName(); String profileName = fetchProfile.getName();
Set<FetchProfile.Fetch> fetches = new HashSet<FetchProfile.Fetch>(); Set<FetchProfile.Fetch> fetches = new HashSet<FetchProfile.Fetch>();
@ -326,7 +339,7 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
private void bindImports() { private void processImports() {
if ( hibernateMapping.getImport() == null ) { if ( hibernateMapping.getImport() == null ) {
return; return;
} }
@ -338,14 +351,14 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
private void bindResultSetMappings() { private void processResultSetMappings() {
if ( hibernateMapping.getResultset() == null ) { if ( hibernateMapping.getResultset() == null ) {
return; return;
} }
// bindResultSetMappingDefinitions( element, null, mappings ); // bindResultSetMappingDefinitions( element, null, mappings );
} }
private void bindNamedQueries() { private void processNamedQueries() {
if ( hibernateMapping.getQueryOrSqlQuery() == null ) { if ( hibernateMapping.getQueryOrSqlQuery() == null ) {
return; return;
} }
@ -365,14 +378,14 @@ public class HibernateMappingProcessor implements HbmBindingContext {
} }
} }
private ClassLoaderService classLoaderService; private Value<ClassLoaderService> classLoaderService = new Value<ClassLoaderService>(
new Value.DeferredInitializer<ClassLoaderService>() {
private ClassLoaderService classLoaderService() { @Override
if ( classLoaderService == null ) { public ClassLoaderService initialize() {
classLoaderService = metadata.getServiceRegistry().getService( ClassLoaderService.class ); return metadata.getServiceRegistry().getService( ClassLoaderService.class );
} }
return classLoaderService;
} }
);
@Override @Override
public String extractEntityName(XMLHibernateMapping.XMLClass entityClazz) { public String extractEntityName(XMLHibernateMapping.XMLClass entityClazz) {
@ -383,4 +396,9 @@ public class HibernateMappingProcessor implements HbmBindingContext {
public String getClassName(String unqualifiedName) { public String getClassName(String unqualifiedName) {
return HbmHelper.getClassName( unqualifiedName, mappingDefaults.getPackageName() ); return HbmHelper.getClassName( unqualifiedName, mappingDefaults.getPackageName() );
} }
@Override
public String determineEntityName(EntityElement entityElement) {
return HbmHelper.determineEntityName( entityElement, mappingDefaults.getPackageName() );
}
} }

View File

@ -0,0 +1,31 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2011, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.hibernate.metamodel.source.hbm.xml.mapping;
/**
* @author Steve Ebersole
*/
public interface Discriminated {
}

View File

@ -0,0 +1,58 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2011, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.hibernate.metamodel.source.hbm.xml.mapping;
import java.util.List;
/**
* @author Steve Ebersole
*/
public interface EntityElement extends MetaAttributeContainer {
public String getName();
public String getEntityName();
public Boolean isAbstract();
public Boolean isLazy();
public String getProxy();
public String getBatchSize();
public boolean isDynamicInsert();
public boolean isDynamicUpdate();
public boolean isSelectBeforeUpdate();
public List<XMLTuplizerElement> getTuplizer();
public String getPersister();
public XMLLoaderElement getLoader();
public XMLSqlInsertElement getSqlInsert();
public XMLSqlUpdateElement getSqlUpdate();
public XMLSqlDeleteElement getSqlDelete();
public List<XMLSynchronizeElement> getSynchronize();
public List<XMLFetchProfileElement> getFetchProfile();
public List<XMLResultsetElement> getResultset();
public List<Object> getQueryOrSqlQuery();
}

View File

@ -0,0 +1,33 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2011, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.hibernate.metamodel.source.hbm.xml.mapping;
import java.util.List;
/**
* @author Steve Ebersole
*/
public interface MetaAttributeContainer {
public List<XMLMetaElement> getMeta();
}

View File

@ -0,0 +1,31 @@
/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* Copyright (c) 2011, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.hibernate.metamodel.source.hbm.xml.mapping;
/**
* @author Steve Ebersole
*/
public interface SubclassEntityElement extends EntityElement {
public String getExtends();
}

View File

@ -565,7 +565,7 @@ public class EntityMetamodel implements Serializable {
entityMode = hasPojoRepresentation ? EntityMode.POJO : EntityMode.MAP; entityMode = hasPojoRepresentation ? EntityMode.POJO : EntityMode.MAP;
final EntityTuplizerFactory entityTuplizerFactory = sessionFactory.getSettings().getEntityTuplizerFactory(); final EntityTuplizerFactory entityTuplizerFactory = sessionFactory.getSettings().getEntityTuplizerFactory();
Class<EntityTuplizer> tuplizerClass = entityBinding.getCustomEntityTuplizerClass(); Class<? extends EntityTuplizer> tuplizerClass = entityBinding.getCustomEntityTuplizerClass();
if ( tuplizerClass == null ) { if ( tuplizerClass == null ) {
entityTuplizer = entityTuplizerFactory.constructDefaultTuplizer( entityMode, this, entityBinding ); entityTuplizer = entityTuplizerFactory.constructDefaultTuplizer( entityMode, this, entityBinding );