- java.lang.Object
- 
- java.beans.beancontext.BeanContextChildSupport
 
- 
- All Implemented Interfaces:
- BeanContextChild,- BeanContextServiceRevokedListener,- BeanContextServicesListener,- Serializable,- EventListener
 - Direct Known Subclasses:
- BeanContextSupport
 
 public class BeanContextChildSupport extends Object implements BeanContextChild, BeanContextServicesListener, Serializable This is a general support class to provide support for implementing the BeanContextChild protocol. This class may either be directly subclassed, or encapsulated and delegated to in order to implement this interface for a given component. - Since:
- 1.2
- See Also:
- BeanContext,- BeanContextServices,- BeanContextChild, Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected BeanContextbeanContextThe bean context.BeanContextChildbeanContextChildPeerTheBeanContextin which thisBeanContextChildis nested.protected PropertyChangeSupportpcSupportThePropertyChangeSupportassociated with thisBeanContextChildSupport.protected booleanrejectedSetBCOnceA flag indicating that there has been at least onePropertyChangeVetoExceptionthrown for the attempted setBeanContext operation.protected VetoableChangeSupportvcSupportTheVetoableChangeSupportassociated with thisBeanContextChildSupport.
 - 
Constructor SummaryConstructors Constructor Description BeanContextChildSupport()construct a BeanContextChildSupport where this class has been subclassed in order to implement the JavaBean component itself.BeanContextChildSupport(BeanContextChild bcc)construct a BeanContextChildSupport where the JavaBean component itself implements BeanContextChild, and encapsulates this, delegating that interface to this implementation
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddPropertyChangeListener(String name, PropertyChangeListener pcl)Add a PropertyChangeListener for a specific property.voidaddVetoableChangeListener(String name, VetoableChangeListener vcl)Add a VetoableChangeListener for a specific property.voidfirePropertyChange(String name, Object oldValue, Object newValue)Report a bound property update to any registered listeners.voidfireVetoableChange(String name, Object oldValue, Object newValue)Report a vetoable property update to any registered listeners.BeanContextgetBeanContext()Gets the nestingBeanContextfor thisBeanContextChildSupport.BeanContextChildgetBeanContextChildPeer()Gets theBeanContextChildassociated with thisBeanContextChildSupport.protected voidinitializeBeanContextResources()This method may be overridden by subclasses to provide their own initialization behaviors.booleanisDelegated()Reports whether or not this class is a delegate of another.protected voidreleaseBeanContextResources()This method may be overridden by subclasses to provide their own release behaviors.voidremovePropertyChangeListener(String name, PropertyChangeListener pcl)Remove a PropertyChangeListener for a specific property.voidremoveVetoableChangeListener(String name, VetoableChangeListener vcl)Removes aVetoableChangeListener.voidserviceAvailable(BeanContextServiceAvailableEvent bcsae)A new service is available from the nesting BeanContext.voidserviceRevoked(BeanContextServiceRevokedEvent bcsre)A service provided by the nesting BeanContext has been revoked.voidsetBeanContext(BeanContext bc)Sets theBeanContextfor thisBeanContextChildSupport.booleanvalidatePendingSetBeanContext(BeanContext newValue)Called from setBeanContext to validate (or otherwise) the pending change in the nesting BeanContext property value.
 
- 
- 
- 
Field Detail- 
beanContextChildPeerpublic BeanContextChild beanContextChildPeer TheBeanContextin which thisBeanContextChildis nested.
 - 
pcSupportprotected PropertyChangeSupport pcSupport ThePropertyChangeSupportassociated with thisBeanContextChildSupport.
 - 
vcSupportprotected VetoableChangeSupport vcSupport TheVetoableChangeSupportassociated with thisBeanContextChildSupport.
 - 
beanContextprotected transient BeanContext beanContext The bean context.
 - 
rejectedSetBCOnceprotected transient boolean rejectedSetBCOnce A flag indicating that there has been at least onePropertyChangeVetoExceptionthrown for the attempted setBeanContext operation.
 
- 
 - 
Constructor Detail- 
BeanContextChildSupportpublic BeanContextChildSupport() construct a BeanContextChildSupport where this class has been subclassed in order to implement the JavaBean component itself.
 - 
BeanContextChildSupportpublic BeanContextChildSupport(BeanContextChild bcc) construct a BeanContextChildSupport where the JavaBean component itself implements BeanContextChild, and encapsulates this, delegating that interface to this implementation- Parameters:
- bcc- the underlying bean context child
 
 
- 
 - 
Method Detail- 
setBeanContextpublic void setBeanContext(BeanContext bc) throws PropertyVetoException Sets theBeanContextfor thisBeanContextChildSupport.- Specified by:
- setBeanContextin interface- BeanContextChild
- Parameters:
- bc- the new value to be assigned to the- BeanContextproperty
- Throws:
- PropertyVetoException- if the change is rejected
 
 - 
getBeanContextpublic BeanContext getBeanContext() Gets the nestingBeanContextfor thisBeanContextChildSupport.- Specified by:
- getBeanContextin interface- BeanContextChild
- Returns:
- the nesting BeanContextfor thisBeanContextChildSupport.
 
 - 
addPropertyChangeListenerpublic void addPropertyChangeListener(String name, PropertyChangeListener pcl) Add a PropertyChangeListener for a specific property. The same listener object may be added more than once. For each property, the listener will be invoked the number of times it was added for that property. Ifnameorpclis null, no exception is thrown and no action is taken.- Specified by:
- addPropertyChangeListenerin interface- BeanContextChild
- Parameters:
- name- The name of the property to listen on
- pcl- The- PropertyChangeListenerto be added
 
 - 
removePropertyChangeListenerpublic void removePropertyChangeListener(String name, PropertyChangeListener pcl) Remove a PropertyChangeListener for a specific property. Ifpclwas added more than once to the same event source for the specified property, it will be notified one less time after being removed. Ifnameis null, no exception is thrown and no action is taken. Ifpclis null, or was never added for the specified property, no exception is thrown and no action is taken.- Specified by:
- removePropertyChangeListenerin interface- BeanContextChild
- Parameters:
- name- The name of the property that was listened on
- pcl- The PropertyChangeListener to be removed
 
 - 
addVetoableChangeListenerpublic void addVetoableChangeListener(String name, VetoableChangeListener vcl) Add a VetoableChangeListener for a specific property. The same listener object may be added more than once. For each property, the listener will be invoked the number of times it was added for that property. Ifnameorvclis null, no exception is thrown and no action is taken.- Specified by:
- addVetoableChangeListenerin interface- BeanContextChild
- Parameters:
- name- The name of the property to listen on
- vcl- The- VetoableChangeListenerto be added
 
 - 
removeVetoableChangeListenerpublic void removeVetoableChangeListener(String name, VetoableChangeListener vcl) Removes aVetoableChangeListener. Ifpclwas added more than once to the same event source for the specified property, it will be notified one less time after being removed. Ifnameis null, no exception is thrown and no action is taken. Ifvclis null, or was never added for the specified property, no exception is thrown and no action is taken.- Specified by:
- removeVetoableChangeListenerin interface- BeanContextChild
- Parameters:
- name- The name of the property that was listened on
- vcl- The- VetoableChangeListenerto be removed
 
 - 
serviceRevokedpublic void serviceRevoked(BeanContextServiceRevokedEvent bcsre) A service provided by the nesting BeanContext has been revoked. Subclasses may override this method in order to implement their own behaviors.- Specified by:
- serviceRevokedin interface- BeanContextServiceRevokedListener
- Parameters:
- bcsre- The- BeanContextServiceRevokedEventfired as a result of a service being revoked
 
 - 
serviceAvailablepublic void serviceAvailable(BeanContextServiceAvailableEvent bcsae) A new service is available from the nesting BeanContext. Subclasses may override this method in order to implement their own behaviors- Specified by:
- serviceAvailablein interface- BeanContextServicesListener
- Parameters:
- bcsae- The BeanContextServiceAvailableEvent fired as a result of a service becoming available
 
 - 
getBeanContextChildPeerpublic BeanContextChild getBeanContextChildPeer() Gets theBeanContextChildassociated with thisBeanContextChildSupport.- Returns:
- the BeanContextChildpeer of this class
 
 - 
isDelegatedpublic boolean isDelegated() Reports whether or not this class is a delegate of another.- Returns:
- true if this class is a delegate of another
 
 - 
firePropertyChangepublic void firePropertyChange(String name, Object oldValue, Object newValue) Report a bound property update to any registered listeners. No event is fired if old and new are equal and non-null.- Parameters:
- name- The programmatic name of the property that was changed
- oldValue- The old value of the property
- newValue- The new value of the property
 
 - 
fireVetoableChangepublic void fireVetoableChange(String name, Object oldValue, Object newValue) throws PropertyVetoException Report a vetoable property update to any registered listeners. If anyone vetos the change, then fire a new event reverting everyone to the old value and then rethrow the PropertyVetoException.No event is fired if old and new are equal and non-null. - Parameters:
- name- The programmatic name of the property that is about to change
- oldValue- The old value of the property
- newValue- - The new value of the property
- Throws:
- PropertyVetoException- if the recipient wishes the property change to be rolled back.
 
 - 
validatePendingSetBeanContextpublic boolean validatePendingSetBeanContext(BeanContext newValue) Called from setBeanContext to validate (or otherwise) the pending change in the nesting BeanContext property value. Returning false will cause setBeanContext to throw PropertyVetoException.- Parameters:
- newValue- the new value that has been requested for the BeanContext property
- Returns:
- trueif the change operation is to be vetoed
 
 - 
releaseBeanContextResourcesprotected void releaseBeanContextResources() This method may be overridden by subclasses to provide their own release behaviors. When invoked any resources held by this instance obtained from its current BeanContext property should be released since the object is no longer nested within that BeanContext.
 - 
initializeBeanContextResourcesprotected void initializeBeanContextResources() This method may be overridden by subclasses to provide their own initialization behaviors. When invoked any resources required by the BeanContextChild should be obtained from the current BeanContext.
 
- 
 
-