/* * Hibernate, Relational Persistence for Idiomatic Java * * Copyright (c) 2008, Red Hat Middleware LLC 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 Middleware LLC. * * 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.tuple; import org.hibernate.FetchMode; import org.hibernate.engine.spi.CascadeStyle; import org.hibernate.type.Type; /** * Represents a basic property within the Hibernate runtime-metamodel. * * @author Steve Ebersole */ public class StandardProperty extends Property { private final boolean lazy; private final boolean insertable; private final boolean updateable; private final boolean insertGenerated; private final boolean updateGenerated; private final boolean nullable; private final boolean dirtyCheckable; private final boolean versionable; private final CascadeStyle cascadeStyle; private final FetchMode fetchMode; /** * Constructs StandardProperty instances. * * @param name The name by which the property can be referenced within * its owner. * @param node The node name to use for XML-based representation of this * property. * @param type The Hibernate Type of this property. * @param lazy Should this property be handled lazily? * @param insertable Is this property an insertable value? * @param updateable Is this property an updateable value? * @param insertGenerated Is this property generated in the database on insert? * @param updateGenerated Is this property generated in the database on update? * @param nullable Is this property a nullable value? * @param checkable Is this property a checkable value? * @param versionable Is this property a versionable value? * @param cascadeStyle The cascade style for this property's value. * @param fetchMode Any fetch mode defined for this property */ public StandardProperty( String name, String node, Type type, boolean lazy, boolean insertable, boolean updateable, boolean insertGenerated, boolean updateGenerated, boolean nullable, boolean checkable, boolean versionable, CascadeStyle cascadeStyle, FetchMode fetchMode) { super(name, node, type); this.lazy = lazy; this.insertable = insertable; this.updateable = updateable; this.insertGenerated = insertGenerated; this.updateGenerated = updateGenerated; this.nullable = nullable; this.dirtyCheckable = checkable; this.versionable = versionable; this.cascadeStyle = cascadeStyle; this.fetchMode = fetchMode; } public boolean isLazy() { return lazy; } public boolean isInsertable() { return insertable; } public boolean isUpdateable() { return updateable; } public boolean isInsertGenerated() { return insertGenerated; } public boolean isUpdateGenerated() { return updateGenerated; } public boolean isNullable() { return nullable; } public boolean isDirtyCheckable(boolean hasUninitializedProperties) { return isDirtyCheckable() && ( !hasUninitializedProperties || !isLazy() ); } public boolean isDirtyCheckable() { return dirtyCheckable; } public boolean isVersionable() { return versionable; } public CascadeStyle getCascadeStyle() { return cascadeStyle; } public FetchMode getFetchMode() { return fetchMode; } }