Open Source Repository

Home /hibernate/hibernate-3.2.4.ga | Repository Home



org/hibernate/tuple/component/ComponentTuplizer.java
//$Id: ComponentTuplizer.java 7451 2005-07-11 21:49:08Z steveebersole $
package org.hibernate.tuple.component;

import java.io.Serializable;
import java.lang.reflect.Method;

import org.hibernate.engine.SessionFactoryImplementor;
import org.hibernate.tuple.Tuplizer;

/**
 * Defines further responsibilities reagarding 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 {
  /**
   * Retreive 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.
     *
     @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?
   *
   @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?
   *
   @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);
}