Package org.picocontainer.behaviors
Class AbstractBehavior<T>
- java.lang.Object
-
- org.picocontainer.behaviors.AbstractBehavior<T>
-
- All Implemented Interfaces:
java.io.Serializable,Behavior<T>,ComponentAdapter<T>,ComponentLifecycle<T>,ComponentMonitorStrategy,LifecycleStrategy
- Direct Known Subclasses:
Automated,Decorated,FieldDecorated,Guarded,HiddenImplementation,Locked,PropertyApplicator,Stored,Synchronized
public abstract class AbstractBehavior<T> extends java.lang.Object implements Behavior<T>, ComponentMonitorStrategy, LifecycleStrategy, java.io.Serializable
Component adapter which decorates another adapter.
This adapter supports a
component monitor strategyand will propagate change of monitor to the delegate if the delegate itself support the monitor strategy.This adapter also supports a
lifecycle managerand alifecycle strategyif the delegate does.- Author:
- Jon Tirsen, Aslak Hellesoy, Mauro Talevi
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.picocontainer.ComponentAdapter
ComponentAdapter.NOTHING
-
-
Field Summary
Fields Modifier and Type Field Description protected ComponentAdapter<T>delegate
-
Constructor Summary
Constructors Constructor Description AbstractBehavior(ComponentAdapter<T> delegate)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaccept(PicoVisitor visitor)Accepts a visitor for this ComponentAdapter.voidchangeMonitor(ComponentMonitor monitor)Delegates change of monitor if the delegate supports a component monitor strategy.booleancomponentHasLifecycle()Invokes delegate hasLifecycle method if the delegate is a Behavior Test if a component honors a lifecycle.ComponentMonitorcurrentMonitor()Returns delegate's current monitor if the delegate supports a component monitor strategy.voiddispose(java.lang.Object component)Invokes delegate dispose method if the delegate is a LifecycleStrategy Invoke the "dispose" method on the component instance if this is disposable.voiddispose(PicoContainer container)Invokes delegate dispose method if the delegate is a Behavior Invoke the "dispose" method on the component.<U extends ComponentAdapter>
UfindAdapterOfType(java.lang.Class<U> adapterType)Locates a component adapter of type componentAdapterType in the ComponentAdapter chain.java.lang.Class<? extends T>getComponentImplementation()Retrieve the class of the component.TgetComponentInstance(PicoContainer container)Retrieve the component instance.TgetComponentInstance(PicoContainer container, java.lang.reflect.Type into)Retrieve the component instance.java.lang.ObjectgetComponentKey()Retrieve the key associated with the component.ComponentAdapter<T>getDelegate()Component adapters may be nested in a chain, and this method is used to grab the next ComponentAdapter in the chain.booleanhasLifecycle(java.lang.Class<?> type)Invokes delegate hasLifecycle(Class) method if the delegate is a LifecycleStrategy Test if a component instance has a lifecycle.booleanisLazy(ComponentAdapter<?> adapter)Is a component eager (not lazy) in that it should start when start() or equivalent is called, or lazy (it will only start on first getComponent() ).booleanisStarted()voidstart(java.lang.Object component)Invokes delegate start method if the delegate is a LifecycleStrategy Invoke the "start" method on the component instance if this is startable.voidstart(PicoContainer container)Invokes delegate start method if the delegate is a Behavior Invoke the "start" method on the component.voidstop(java.lang.Object component)Invokes delegate stop method if the delegate is a LifecycleStrategy Invoke the "stop" method on the component instance if this is stoppable.voidstop(PicoContainer container)Invokes delegate stop method if the delegate is a Behavior Invoke the "stop" method on the component.java.lang.StringtoString()voidverify(PicoContainer container)Verify that all dependencies for this adapter can be satisfied.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.picocontainer.ComponentAdapter
getDescriptor
-
-
-
-
Field Detail
-
delegate
protected final ComponentAdapter<T> delegate
-
-
Constructor Detail
-
AbstractBehavior
public AbstractBehavior(ComponentAdapter<T> delegate)
-
-
Method Detail
-
getComponentKey
public java.lang.Object getComponentKey()
Description copied from interface:ComponentAdapterRetrieve the key associated with the component.- Specified by:
getComponentKeyin interfaceComponentAdapter<T>- Returns:
- the component's key. Should either be a class type (normally an interface) or an identifier that is unique (within the scope of the current PicoContainer).
-
getComponentImplementation
public java.lang.Class<? extends T> getComponentImplementation()
Description copied from interface:ComponentAdapterRetrieve the class of the component.- Specified by:
getComponentImplementationin interfaceComponentAdapter<T>- Returns:
- the component's implementation class. Should normally be a concrete class (ie, a class that can be instantiated).
-
getComponentInstance
public T getComponentInstance(PicoContainer container) throws PicoCompositionException
Description copied from interface:ComponentAdapterRetrieve the component instance. This method will usually create a new instance each time it is called, but that is not required. For example,Cachedwill always return the same instance.- Specified by:
getComponentInstancein interfaceComponentAdapter<T>- Parameters:
container- thePicoContainer, that is used to resolve any possible dependencies of the instance.- Returns:
- the component instance.
- Throws:
PicoCompositionException- if the component has dependencies which could not be resolved, or instantiation of the component lead to an ambigous situation within the container.
-
getComponentInstance
public T getComponentInstance(PicoContainer container, java.lang.reflect.Type into) throws PicoCompositionException
Description copied from interface:ComponentAdapterRetrieve the component instance. This method will usually create a new instance each time it is called, but that is not required. For example,Cachedwill always return the same instance.- Specified by:
getComponentInstancein interfaceComponentAdapter<T>- Parameters:
container- thePicoContainer, that is used to resolve any possible dependencies of the instance.into- the class that is about to be injected into. Use ComponentAdapter.NOTHING.class if this is not important to you.- Returns:
- the component instance.
- Throws:
PicoCompositionException- if the component has dependencies which could not be resolved, or instantiation of the component lead to an ambiguous situation within the container.
-
verify
public void verify(PicoContainer container) throws PicoCompositionException
Description copied from interface:ComponentAdapterVerify that all dependencies for this adapter can be satisfied. Normally, the adapter should verify this by checking that the associated PicoContainer contains all the needed dependencies.- Specified by:
verifyin interfaceComponentAdapter<T>- Parameters:
container- thePicoContainer, that is used to resolve any possible dependencies of the instance.- Throws:
PicoCompositionException- if one or more dependencies cannot be resolved.
-
getDelegate
public final ComponentAdapter<T> getDelegate()
Description copied from interface:ComponentAdapterComponent adapters may be nested in a chain, and this method is used to grab the next ComponentAdapter in the chain.- Specified by:
getDelegatein interfaceComponentAdapter<T>- Returns:
- the next component adapter in line or null if there is no delegate ComponentAdapter.
-
findAdapterOfType
public final <U extends ComponentAdapter> U findAdapterOfType(java.lang.Class<U> adapterType)
Description copied from interface:ComponentAdapterLocates a component adapter of type componentAdapterType in the ComponentAdapter chain. Will return null if there is no adapter of the given type.- Specified by:
findAdapterOfTypein interfaceComponentAdapter<T>- Type Parameters:
U- the type of ComponentAdapter being located.- Parameters:
adapterType- the class of the adapter type being located. Never null.- Returns:
- the appropriate component adapter of type U. May return null if the component adapter type is not returned.
-
accept
public void accept(PicoVisitor visitor)
Description copied from interface:ComponentAdapterAccepts a visitor for this ComponentAdapter. The method is normally called by visiting aPicoContainer, that cascades the visitor also down to all its ComponentAdapter instances.- Specified by:
acceptin interfaceComponentAdapter<T>- Parameters:
visitor- the visitor.
-
changeMonitor
public void changeMonitor(ComponentMonitor monitor)
Delegates change of monitor if the delegate supports a component monitor strategy. Changes the component monitor used- Specified by:
changeMonitorin interfaceComponentMonitorStrategy- Parameters:
monitor- the new ComponentMonitor to use
-
currentMonitor
public ComponentMonitor currentMonitor()
Returns delegate's current monitor if the delegate supports a component monitor strategy. Returns the monitor currently used- Specified by:
currentMonitorin interfaceComponentMonitorStrategy- Returns:
- The ComponentMonitor currently used
- Throws:
PicoCompositionException- if no component monitor is found in delegate
-
start
public void start(PicoContainer container)
Invokes delegate start method if the delegate is a Behavior Invoke the "start" method on the component.- Specified by:
startin interfaceComponentLifecycle<T>- Parameters:
container- the container to "start" the component
-
stop
public void stop(PicoContainer container)
Invokes delegate stop method if the delegate is a Behavior Invoke the "stop" method on the component.- Specified by:
stopin interfaceComponentLifecycle<T>- Parameters:
container- the container to "stop" the component
-
dispose
public void dispose(PicoContainer container)
Invokes delegate dispose method if the delegate is a Behavior Invoke the "dispose" method on the component.- Specified by:
disposein interfaceComponentLifecycle<T>- Parameters:
container- the container to "dispose" the component
-
componentHasLifecycle
public boolean componentHasLifecycle()
Invokes delegate hasLifecycle method if the delegate is a Behavior Test if a component honors a lifecycle.- Specified by:
componentHasLifecyclein interfaceComponentLifecycle<T>- Returns:
trueif the component has a lifecycle
-
isStarted
public boolean isStarted()
- Specified by:
isStartedin interfaceComponentLifecycle<T>
-
start
public void start(java.lang.Object component)
Invokes delegate start method if the delegate is a LifecycleStrategy Invoke the "start" method on the component instance if this is startable. It is up to the implementation of the strategy what "start" and "startable" means.- Specified by:
startin interfaceLifecycleStrategy- Parameters:
component- the instance of the component to start
-
stop
public void stop(java.lang.Object component)
Invokes delegate stop method if the delegate is a LifecycleStrategy Invoke the "stop" method on the component instance if this is stoppable. It is up to the implementation of the strategy what "stop" and "stoppable" means.- Specified by:
stopin interfaceLifecycleStrategy- Parameters:
component- the instance of the component to stop
-
dispose
public void dispose(java.lang.Object component)
Invokes delegate dispose method if the delegate is a LifecycleStrategy Invoke the "dispose" method on the component instance if this is disposable. It is up to the implementation of the strategy what "dispose" and "disposable" means.- Specified by:
disposein interfaceLifecycleStrategy- Parameters:
component- the instance of the component to dispose
-
hasLifecycle
public boolean hasLifecycle(java.lang.Class<?> type)
Invokes delegate hasLifecycle(Class) method if the delegate is a LifecycleStrategy Test if a component instance has a lifecycle.- Specified by:
hasLifecyclein interfaceLifecycleStrategy- Parameters:
type- the component's type- Returns:
trueif the component has a lifecycle
-
isLazy
public boolean isLazy(ComponentAdapter<?> adapter)
Description copied from interface:LifecycleStrategyIs a component eager (not lazy) in that it should start when start() or equivalent is called, or lazy (it will only start on first getComponent() ). The default is the first of those two.- Specified by:
isLazyin interfaceLifecycleStrategy- Returns:
- true if lazy, false if not lazy
-
toString
public java.lang.String toString()
- Overrides:
toStringin classjava.lang.Object
-
-