/*
 * 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.binder;

import org.hibernate.EntityMode;
import org.hibernate.engine.OptimisticLockStyle;
import org.hibernate.metamodel.binding.Caching;

Contract for the entity that is the root of an inheritance hierarchy.

NOTE : I think most of this could be moved to EntityHierarchy much like was done with HierarchyDetails
Author:Steve Ebersole
@todoMove these concepts to EntityHierarchy ?
/** * Contract for the entity that is the root of an inheritance hierarchy. * <p/> * <b>NOTE</b> : I think most of this could be moved to {@link EntityHierarchy} much like was done with * {@link org.hibernate.metamodel.binding.HierarchyDetails} * * @author Steve Ebersole * * @todo Move these concepts to {@link EntityHierarchy} ? */
public interface RootEntitySource extends EntitySource {
Obtain source information about this entity's identifier.
Returns:Identifier source information.
/** * Obtain source information about this entity's identifier. * * @return Identifier source information. */
public IdentifierSource getIdentifierSource();
Obtain the source information about the attribute used for versioning.
Returns:the source information about the attribute used for versioning
/** * Obtain the source information about the attribute used for versioning. * * @return the source information about the attribute used for versioning */
public SingularAttributeSource getVersioningAttributeSource();
Obtain the source information about the discriminator attribute for single table inheritance
Returns:the source information about the discriminator attribute for single table inheritance
/** * Obtain the source information about the discriminator attribute for single table inheritance * * @return the source information about the discriminator attribute for single table inheritance */
public DiscriminatorSource getDiscriminatorSource();
Obtain the entity mode for this entity.
Returns:The entity mode.
/** * Obtain the entity mode for this entity. * * @return The entity mode. */
public EntityMode getEntityMode();
Is this root entity mutable?
Returns:true indicates mutable; false non-mutable.
/** * Is this root entity mutable? * * @return {@code true} indicates mutable; {@code false} non-mutable. */
public boolean isMutable();
Should explicit polymorphism (querying) be applied to this entity?
Returns:true indicates explicit polymorphism; false implicit.
/** * Should explicit polymorphism (querying) be applied to this entity? * * @return {@code true} indicates explicit polymorphism; {@code false} implicit. */
public boolean isExplicitPolymorphism();
Obtain the specified extra where condition to be applied to this entity.
Returns:The extra where condition
/** * Obtain the specified extra where condition to be applied to this entity. * * @return The extra where condition */
public String getWhere();
Obtain the row-id name for this entity
Returns:The row-id name
/** * Obtain the row-id name for this entity * * @return The row-id name */
public String getRowId();
Obtain the optimistic locking style for this entity.
Returns:The optimistic locking style.
/** * Obtain the optimistic locking style for this entity. * * @return The optimistic locking style. */
public OptimisticLockStyle getOptimisticLockStyle();
Obtain the caching configuration for this entity.
Returns:The caching configuration.
/** * Obtain the caching configuration for this entity. * * @return The caching configuration. */
public Caching getCaching(); }