Class BeanContextServicesSupport
- All Implemented Interfaces:
-
BeanContext
,BeanContextChild
,BeanContextServiceRevokedListener
,BeanContextServices
,BeanContextServicesListener
,DesignMode
,PropertyChangeListener
,VetoableChangeListener
,Visibility
,Serializable
,Iterable
,Collection
,EventListener
public class BeanContextServicesSupport extends BeanContextSupport implements BeanContextServices
This helper class provides a utility implementation of the java.beans.beancontext.BeanContextServices interface.
Since this class directly implements the BeanContextServices interface, the class can, and is intended to be used either by subclassing this implementation, or via delegation of an instance of this class from another through the BeanContextProxy interface.
- Since:
- 1.2
- See Also:
Nested Class Summary
Modifier and Type | Class | Description |
---|---|---|
protected class |
BeanContextServicesSupport.BCSSChild |
|
protected class |
BeanContextServicesSupport.BCSSProxyServiceProvider |
|
protected static class |
BeanContextServicesSupport.BCSSServiceProvider |
subclasses may subclass this nested class to add behaviors for each BeanContextServicesProvider. |
Nested classes/interfaces declared in class java.beans.beancontext.BeanContextSupport
BeanContextSupport.BCSChild, BeanContextSupport.BCSIterator
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected ArrayList<BeanContextServicesListener> |
bcsListeners |
List of BeanContextServicesListener objects. |
protected BeanContextServicesSupport.BCSSProxyServiceProvider |
proxy |
Delegate for the BeanContextServiceProvider . |
protected int |
serializable |
The number of instances of a serializable BeanContextServceProvider . |
protected HashMap<Object, |
services |
all accesses to the protected transient HashMap services field should be synchronized on that object |
Fields declared in class java.beans.beancontext.BeanContextSupport
bcmListeners, children, designTime, locale, okToUseGui
Fields declared in class java.beans.beancontext.BeanContextChildSupport
beanContext, beanContextChildPeer, pcSupport, rejectedSetBCOnce, vcSupport
Fields declared in interface java.beans.beancontext.BeanContext
globalHierarchyLock
Fields declared in interface java.beans.DesignMode
PROPERTYNAME
Constructor Summary
Constructor | Description |
---|---|
BeanContextServicesSupport() |
Create an instance that is not a delegate of another object |
BeanContextServicesSupport |
Create an instance with a peer |
BeanContextServicesSupport |
Create an instance using the specified locale |
BeanContextServicesSupport |
Create an instance using the specified Locale and design mode. |
BeanContextServicesSupport |
Construct a BeanContextServicesSupport instance |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
void |
addBeanContextServicesListener |
add a BeanContextServicesListener |
boolean |
addService |
add a service |
protected boolean |
addService |
add a service |
protected void |
bcsPreDeserializationHook |
called from BeanContextSupport readObject before it deserializes the children ... |
protected void |
bcsPreSerializationHook |
called from BeanContextSupport writeObject before it serializes the children ... |
protected void |
childJustRemovedHook |
called from superclass child removal operations after a child has been successfully removed. called with child synchronized. |
protected BeanContextSupport.BCSChild |
createBCSChild |
Subclasses can override this method to insert their own subclass of Child without having to override add() or the other Collection methods that add children to the set. |
protected BeanContextServicesSupport.BCSSServiceProvider |
createBCSSServiceProvider |
subclasses can override this method to create new subclasses of BCSSServiceProvider without having to override addService() in order to instantiate. |
protected final void |
fireServiceAdded |
Fires a BeanContextServiceAvailableEvent indicating that a new service has become available. |
protected final void |
fireServiceAdded |
Fires a BeanContextServiceEvent notifying of a new service. |
protected final void |
fireServiceRevoked |
Fires a BeanContextServiceEvent notifying of a service being revoked. |
protected final void |
fireServiceRevoked |
Fires a BeanContextServiceRevokedEvent indicating that a particular service is no longer available. |
BeanContextServices |
getBeanContextServicesPeer() |
Gets the BeanContextServices associated with this BeanContextServicesSupport . |
protected static final BeanContextServicesListener |
getChildBeanContextServicesListener |
Gets the BeanContextServicesListener (if any) of the specified child. |
Iterator<Object> |
getCurrentServiceClasses() |
Gets the currently available services for this context. |
Iterator<?> |
getCurrentServiceSelectors |
Gets the list of service dependent service parameters (Service Selectors) for the specified service, by calling getCurrentServiceSelectors() on the underlying BeanContextServiceProvider. |
Object |
getService |
obtain a service which may be delegated |
boolean |
hasService |
has a service, which may be delegated |
void |
initialize() |
called by BeanContextSupport superclass during construction and deserialization to initialize subclass transient state. |
protected void |
initializeBeanContextResources() |
called from setBeanContext to notify a BeanContextChild to allocate resources obtained from the nesting BeanContext. |
protected void |
releaseBeanContextResources() |
called from setBeanContext to notify a BeanContextChild to release resources obtained from the nesting BeanContext. |
void |
releaseService |
release a service |
void |
removeBeanContextServicesListener |
remove a BeanContextServicesListener |
void |
revokeService |
remove a service |
void |
serviceAvailable |
BeanContextServicesListener callback, propagates event to all currently registered listeners and BeanContextServices children, if this BeanContextService does not already implement this service itself. |
void |
serviceRevoked |
BeanContextServicesListener callback, propagates event to all currently registered listeners and BeanContextServices children, if this BeanContextService does not already implement this service itself. |
Methods declared in class java.beans.beancontext.BeanContextSupport
add, addAll, addBeanContextMembershipListener, avoidingGui, bcsChildren, childDeserializedHook, childJustAddedHook, classEquals, clear, contains, containsAll, containsKey, copyChildren, deserialize, dontUseGui, fireChildrenAdded, fireChildrenRemoved, getBeanContextPeer, getChildBeanContextChild, getChildBeanContextMembershipListener, getChildPropertyChangeListener, getChildSerializable, getChildVetoableChangeListener, getChildVisibility, getLocale, getResource, getResourceAsStream, instantiateChild, isDesignTime, isEmpty, isSerializing, iterator, needsGui, okToUseGui, propertyChange, readChildren, remove, remove, removeAll, removeBeanContextMembershipListener, retainAll, serialize, setDesignTime, setLocale, size, toArray, toArray, validatePendingAdd, validatePendingRemove, vetoableChange, writeChildren
Methods declared in class java.beans.beancontext.BeanContextChildSupport
addPropertyChangeListener, addVetoableChangeListener, firePropertyChange, fireVetoableChange, getBeanContext, getBeanContextChildPeer, isDelegated, removePropertyChangeListener, removeVetoableChangeListener, setBeanContext, validatePendingSetBeanContext
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods declared in interface java.beans.beancontext.BeanContext
addBeanContextMembershipListener, getResource, getResourceAsStream, instantiateChild, removeBeanContextMembershipListener
Methods declared in interface java.beans.beancontext.BeanContextChild
addPropertyChangeListener, addVetoableChangeListener, getBeanContext, removePropertyChangeListener, removeVetoableChangeListener, setBeanContext
Methods declared in interface java.util.Collection
add, addAll, clear, contains, containsAll, equals, hashCode, isEmpty, iterator, parallelStream, remove, removeAll, removeIf, retainAll, size, spliterator, stream, toArray, toArray, toArray
Methods declared in interface java.beans.DesignMode
isDesignTime, setDesignTime
Methods declared in interface java.beans.Visibility
avoidingGui, dontUseGui, needsGui, okToUseGui
Field Details
services
protected transient HashMap<Object,BeanContextServicesSupport.BCSSServiceProvider> services
protected transient HashMap services
field should be synchronized on that objectserializable
protected transient int serializable
BeanContextServceProvider
.proxy
protected transient BeanContextServicesSupport.BCSSProxyServiceProvider proxy
BeanContextServiceProvider
.bcsListeners
protected transient ArrayList<BeanContextServicesListener> bcsListeners
BeanContextServicesListener
objects.Constructor Details
BeanContextServicesSupport
public BeanContextServicesSupport(BeanContextServices peer, Locale lcle, boolean dTime, boolean visible)
Construct a BeanContextServicesSupport instance
- Parameters:
-
peer
- The peer BeanContext we are supplying an implementation for, if null the this object is its own peer -
lcle
- The current Locale for this BeanContext. -
dTime
- The initial state, true if in design mode, false if runtime. -
visible
- The initial visibility.
BeanContextServicesSupport
public BeanContextServicesSupport(BeanContextServices peer, Locale lcle, boolean dtime)
- Parameters:
-
peer
- The peer BeanContext we are supplying an implementation for, if null the this object is its own peer -
lcle
- The current Locale for this BeanContext. -
dtime
- The initial state, true if in design mode, false if runtime.
BeanContextServicesSupport
public BeanContextServicesSupport(BeanContextServices peer, Locale lcle)
- Parameters:
-
peer
- The peer BeanContext we are supplying an implementation for, if null the this object is its own peer -
lcle
- The current Locale for this BeanContext.
BeanContextServicesSupport
public BeanContextServicesSupport(BeanContextServices peer)
- Parameters:
-
peer
- The peer BeanContext we are supplying an implementation for, if null the this object is its own peer
BeanContextServicesSupport
public BeanContextServicesSupport()
Method Details
initialize
public void initialize()
- Overrides:
-
initialize
in classBeanContextSupport
getBeanContextServicesPeer
public BeanContextServices getBeanContextServicesPeer()
BeanContextServices
associated with this BeanContextServicesSupport
.- Returns:
- the instance of
BeanContext
this object is providing the implementation for.
createBCSChild
protected BeanContextSupport.BCSChild createBCSChild(Object targetChild, Object peer)
Subclasses can override this method to insert their own subclass of Child without having to override add() or the other Collection methods that add children to the set.
- Overrides:
-
createBCSChild
in classBeanContextSupport
- Parameters:
-
targetChild
- the child to create the Child on behalf of -
peer
- the peer if the targetChild and peer are related by BeanContextProxy - Returns:
- Subtype-specific subclass of Child without overriding collection methods
createBCSSServiceProvider
protected BeanContextServicesSupport.BCSSServiceProvider createBCSSServiceProvider(Class<?> sc, BeanContextServiceProvider bcsp)
- Parameters:
-
sc
- the class -
bcsp
- the service provider - Returns:
- a service provider without overriding addService()
addBeanContextServicesListener
public void addBeanContextServicesListener(BeanContextServicesListener bcsl)
- Specified by:
-
addBeanContextServicesListener
in interfaceBeanContextServices
- Parameters:
-
bcsl
- theBeanContextServicesListener
to add - Throws:
-
NullPointerException
- if the argument is null
removeBeanContextServicesListener
public void removeBeanContextServicesListener(BeanContextServicesListener bcsl)
- Specified by:
-
removeBeanContextServicesListener
in interfaceBeanContextServices
- Parameters:
-
bcsl
- theBeanContextServicesListener
to remove from this context
addService
public boolean addService(Class<?> serviceClass, BeanContextServiceProvider bcsp)
- Specified by:
-
addService
in interfaceBeanContextServices
- Parameters:
-
serviceClass
- the service class -
bcsp
- the service provider - Returns:
- true if the service was successful added, false otherwise
addService
protected boolean addService(Class<?> serviceClass, BeanContextServiceProvider bcsp, boolean fireEvent)
- Parameters:
-
serviceClass
- the service class -
bcsp
- the service provider -
fireEvent
- whether or not an event should be fired - Returns:
- true if the service was successfully added
revokeService
public void revokeService(Class<?> serviceClass, BeanContextServiceProvider bcsp, boolean revokeCurrentServicesNow)
- Specified by:
-
revokeService
in interfaceBeanContextServices
- Parameters:
-
serviceClass
- the service class -
bcsp
- the service provider -
revokeCurrentServicesNow
- whether or not to revoke the service
hasService
public boolean hasService(Class<?> serviceClass)
- Specified by:
-
hasService
in interfaceBeanContextServices
- Parameters:
-
serviceClass
- the service in question - Returns:
- true if the service is available
getService
public Object getService(BeanContextChild child, Object requestor, Class<?> serviceClass, Object serviceSelector, BeanContextServiceRevokedListener bcsrl) throws TooManyListenersException
- Specified by:
-
getService
in interfaceBeanContextServices
- Parameters:
-
child
- theBeanContextChild
associated with this request -
requestor
- the object requesting the service -
serviceClass
- class of the requested service -
serviceSelector
- the service dependent parameter -
bcsrl
- theBeanContextServiceRevokedListener
to notify if the service should later become revoked - Returns:
- a reference to this context's named Service as requested or
null
- Throws:
-
TooManyListenersException
- if there are too many listeners
releaseService
public void releaseService(BeanContextChild child, Object requestor, Object service)
- Specified by:
-
releaseService
in interfaceBeanContextServices
- Parameters:
-
child
- theBeanContextChild
-
requestor
- the requestor -
service
- the service
getCurrentServiceClasses
public Iterator<Object> getCurrentServiceClasses()
BeanContextServices
- Specified by:
-
getCurrentServiceClasses
in interfaceBeanContextServices
- Returns:
- an iterator for all the currently registered service classes.
getCurrentServiceSelectors
public Iterator<?> getCurrentServiceSelectors(Class<?> serviceClass)
BeanContextServices
- Specified by:
-
getCurrentServiceSelectors
in interfaceBeanContextServices
- Parameters:
-
serviceClass
- the specified service - Returns:
- an iterator for all the currently available service selectors (if any) available for the specified service.
serviceAvailable
public void serviceAvailable(BeanContextServiceAvailableEvent bcssae)
- Specified by:
-
serviceAvailable
in interfaceBeanContextServicesListener
- Overrides:
-
serviceAvailable
in classBeanContextChildSupport
- Parameters:
-
bcssae
- The BeanContextServiceAvailableEvent fired as a result of a service becoming available
serviceRevoked
public void serviceRevoked(BeanContextServiceRevokedEvent bcssre)
- Specified by:
-
serviceRevoked
in interfaceBeanContextServiceRevokedListener
- Overrides:
-
serviceRevoked
in classBeanContextChildSupport
- Parameters:
-
bcssre
- TheBeanContextServiceRevokedEvent
fired as a result of a service being revoked
getChildBeanContextServicesListener
protected static final BeanContextServicesListener getChildBeanContextServicesListener(Object child)
BeanContextServicesListener
(if any) of the specified child.- Parameters:
-
child
- the specified child - Returns:
- the BeanContextServicesListener (if any) of the specified child
childJustRemovedHook
protected void childJustRemovedHook(Object child, BeanContextSupport.BCSChild bcsc)
- Overrides:
-
childJustRemovedHook
in classBeanContextSupport
- Parameters:
-
child
- the child -
bcsc
- the BCSChild
releaseBeanContextResources
protected void releaseBeanContextResources()
- Overrides:
-
releaseBeanContextResources
in classBeanContextChildSupport
initializeBeanContextResources
protected void initializeBeanContextResources()
- Overrides:
-
initializeBeanContextResources
in classBeanContextChildSupport
fireServiceAdded
protected final void fireServiceAdded(Class<?> serviceClass)
BeanContextServiceEvent
notifying of a new service.- Parameters:
-
serviceClass
- the service class
fireServiceAdded
protected final void fireServiceAdded(BeanContextServiceAvailableEvent bcssae)
BeanContextServiceAvailableEvent
indicating that a new service has become available.- Parameters:
-
bcssae
- theBeanContextServiceAvailableEvent
fireServiceRevoked
protected final void fireServiceRevoked(BeanContextServiceRevokedEvent bcsre)
BeanContextServiceEvent
notifying of a service being revoked.- Parameters:
-
bcsre
- theBeanContextServiceRevokedEvent
fireServiceRevoked
protected final void fireServiceRevoked(Class<?> serviceClass, boolean revokeNow)
BeanContextServiceRevokedEvent
indicating that a particular service is no longer available.- Parameters:
-
serviceClass
- the service class -
revokeNow
- whether or not the event should be revoked now
bcsPreSerializationHook
protected void bcsPreSerializationHook(ObjectOutputStream oos) throws IOException
- Overrides:
-
bcsPreSerializationHook
in classBeanContextSupport
- Parameters:
-
oos
- theObjectOutputStream
to use during serialization - Throws:
-
IOException
- if serialization failed
bcsPreDeserializationHook
protected void bcsPreDeserializationHook(ObjectInputStream ois) throws IOException, ClassNotFoundException
- Overrides:
-
bcsPreDeserializationHook
in classBeanContextSupport
- Parameters:
-
ois
- theObjectInputStream
to use during deserialization - Throws:
-
IOException
- if deserialization failed -
ClassNotFoundException
- if needed classes are not found
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.desktop/java/beans/beancontext/BeanContextServicesSupport.html