/*
* Hibernate, Relational Persistence for Idiomatic Java
*
* License: GNU Lesser General Public License (LGPL), version 2.1 or later.
* See the lgpl.txt file in the root directory or <http://www.gnu.org/licenses/lgpl-2.1.html>.
*/
package org.hibernate.tuple.component;
import java.io.Serializable;
import java.lang.reflect.Method;
import org.hibernate.engine.spi.SessionFactoryImplementor;
import org.hibernate.tuple.Tuplizer;
Defines further responsibilities regarding tuplization based on
a mapped components.
ComponentTuplizer implementations should have the following constructor signature:
(org.hibernate.mapping.Component)
Author: Gavin King, Steve Ebersole
/**
* Defines further responsibilities regarding tuplization based on
* a mapped components.
* </p>
* ComponentTuplizer implementations should have the following constructor signature:
* (org.hibernate.mapping.Component)
*
* @author Gavin King
* @author Steve Ebersole
*/
public interface ComponentTuplizer extends Tuplizer, Serializable {
Retrieve the current value of the parent property.
Params: - component – The component instance from which to extract the parent
property value.
Returns: The current value of the parent property.
/**
* Retrieve the current value of the parent property.
*
* @param component The component instance from which to extract the parent
* property value.
* @return The current value of the parent property.
*/
public Object getParent(Object component);
Set the value of the parent property.
Params: - component – The component instance on which to set the parent.
- parent – The parent to be set on the comonent.
- factory – The current session factory.
/**
* Set the value of the parent property.
*
* @param component The component instance on which to set the parent.
* @param parent The parent to be set on the comonent.
* @param factory The current session factory.
*/
public void setParent(Object component, Object parent, SessionFactoryImplementor factory);
Does the component managed by this tuuplizer contain a parent property?
Returns: True if the component does contain a parent property; false otherwise.
/**
* Does the component managed by this tuuplizer contain a parent property?
*
* @return True if the component does contain a parent property; false otherwise.
*/
public boolean hasParentProperty();
Is the given method available via the managed component as a property getter?
Params: - method – The method which to check against the managed component.
Returns: True if the managed component is available from the managed component; else false.
/**
* Is the given method available via the managed component as a property getter?
*
* @param method The method which to check against the managed component.
* @return True if the managed component is available from the managed component; else false.
*/
public boolean isMethodOf(Method method);
}