|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.infinispan.factories.AbstractComponentRegistry
public abstract class AbstractComponentRegistry
A registry where components which have been created are stored. Components are stored as singletons, registered under a specific name.
Components can be retrieved from the registry usinggetComponent(Class)
.
Components can be registered using registerComponent(Object, Class)
, which will cause any dependencies to be
wired in as well. Components that need to be created as a result of wiring will be done using getOrCreateComponent(Class)
, which will look up the default factory for the component type (factories annotated
with the appropriate DefaultFactoryFor
annotation.
Default factories are treated as components too and will need to be wired before being used.
The registry can exist in one of several states, as defined by the ComponentStatus
enumeration. In terms of the cache, state changes in the following manner: Lifecycle.start()
is calledLifecycle.stop()
is calledComponentStatus.RUNNING
state.
Nested Class Summary | |
---|---|
class |
AbstractComponentRegistry.Component
A wrapper representing a component in the registry |
Field Summary | |
---|---|
static boolean |
DEBUG_DEPENDENCIES
|
protected static List<ModuleLifecycle> |
moduleLifecycles
|
protected static Object |
NULL_COMPONENT
|
Constructor Summary | |
---|---|
AbstractComponentRegistry()
|
Method Summary | ||
---|---|---|
protected void |
addComponentDependencies(AbstractComponentRegistry.Component c)
Adds component dependencies for a given component, by populating AbstractComponentRegistry.Component.injectionMethods . |
|
protected void |
addShutdownHook()
|
|
AbstractComponentRegistry |
clone()
|
|
|
getComponent(Class<T> type)
Retrieves a component of a specified type from the registry, or null if it cannot be found. |
|
|
getComponent(Class<T> type,
String name)
|
|
protected Configuration |
getConfiguration()
Retrieves the configuration component. |
|
protected Map<Class,Class<? extends AbstractComponentFactory>> |
getDefaultFactoryMap()
|
|
protected AbstractComponentFactory |
getFactory(Class componentClass)
Retrieves a component factory instance capable of constructing components of a specified type. |
|
protected
|
getFromConfiguration(Class<T> componentClass)
Retrieves a component from the Configuration |
|
protected abstract Log |
getLog()
|
|
protected
|
getOrCreateComponent(Class<T> componentClass)
Retrieves a component if one exists, and if not, attempts to find a factory capable of constructing the component (factories annotated with the DefaultFactoryFor annotation that is capable of creating the component
class). |
|
protected
|
getOrCreateComponent(Class<T> componentClass,
String name)
|
|
Set<AbstractComponentRegistry.Component> |
getRegisteredComponents()
Returns an immutable set containing all the components that exists in the repository at this moment. |
|
ComponentStatus |
getStatus()
Retrieves the state of the registry |
|
boolean |
invocationsAllowed(boolean originLocal)
Asserts whether invocations are allowed on the cache or not. |
|
protected void |
invokeInjectionMethod(Object o,
Method m)
|
|
protected AbstractComponentRegistry.Component |
lookupComponent(Class type,
String componentName)
|
|
void |
registerComponent(Object component,
Class type)
Registers a component in the registry under the given type, and injects any dependencies needed. |
|
void |
registerComponent(Object component,
String name)
|
|
void |
registerDefaultClassLoader(ClassLoader loader)
Registers the default class loader. |
|
protected void |
removeShutdownHook()
|
|
void |
resetNonVolatile()
Removes any components not annotated as @NonVolatile. |
|
void |
rewire()
Rewires components. |
|
void |
start()
This starts the components in the cache, connecting to channels, starting service threads, etc. |
|
void |
stop()
Stops the cache and sets the cache status to ComponentStatus.TERMINATED once it
is done. |
|
void |
wireDependencies(Object target)
Wires an object instance with dependencies annotated with the Inject annotation, creating more components
as needed based on the Configuration passed in if these additional components don't exist in the ComponentRegistry . |
Methods inherited from class java.lang.Object |
---|
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final boolean DEBUG_DEPENDENCIES
protected static final Object NULL_COMPONENT
protected static List<ModuleLifecycle> moduleLifecycles
Constructor Detail |
---|
public AbstractComponentRegistry()
Method Detail |
---|
public ComponentStatus getStatus()
protected abstract Log getLog()
public void wireDependencies(Object target) throws ConfigurationException
Inject
annotation, creating more components
as needed based on the Configuration passed in if these additional components don't exist in the ComponentRegistry
. Strictly for components that don't otherwise live in the registry and have a lifecycle, such
as Commands.
target
- object to wire
ConfigurationException
- if there is a problem wiring the instancepublic void registerComponent(Object component, Class type)
component
- component to registertype
- type of componentpublic void registerComponent(Object component, String name)
protected void addComponentDependencies(AbstractComponentRegistry.Component c)
AbstractComponentRegistry.Component.injectionMethods
.
c
- component to add dependencies toprotected void invokeInjectionMethod(Object o, Method m)
protected <T> T getOrCreateComponent(Class<T> componentClass)
DefaultFactoryFor
annotation that is capable of creating the component
class).
If an instance needs to be constructed, dependencies are then automatically wired into the instance, based on
methods on the component type annotated with Inject
.
Summing it up, component retrieval happens in the following order:Configuration
that
may be injected from an external system. 3. Look for a class definition passed in to the Configuration
-
such as an EvictionPolicy implementation 4. Attempt to create it by looking for an appropriate factory (annotated
with DefaultFactoryFor
)
componentClass
- type of component to be retrieved. Should not be null.
ConfigurationException
- if there is a problem with constructing or wiring the instance.protected <T> T getOrCreateComponent(Class<T> componentClass, String name)
protected AbstractComponentFactory getFactory(Class componentClass)
componentClass
- type of component to construct
protected AbstractComponentRegistry.Component lookupComponent(Class type, String componentName)
protected Map<Class,Class<? extends AbstractComponentFactory>> getDefaultFactoryMap()
protected <T> T getFromConfiguration(Class<T> componentClass)
Configuration
componentClass
- component type
protected Configuration getConfiguration()
public <T> T getComponent(Class<T> type)
type
- type to find
public <T> T getComponent(Class<T> type, String name)
public void registerDefaultClassLoader(ClassLoader loader)
loader
- a class loader to use by default. If this is null, the class loader used to load this instance of
ComponentRegistry is used.public void rewire()
public void resetNonVolatile()
public void start()
ComponentStatus.INITIALIZING
state, it will be initialized first.
start
in interface Lifecycle
public void stop()
ComponentStatus.TERMINATED
once it
is done. If the cache is not in the ComponentStatus.RUNNING
state, this is a
no-op.
stop
in interface Lifecycle
protected void addShutdownHook()
protected void removeShutdownHook()
public boolean invocationsAllowed(boolean originLocal)
ComponentStatus.INITIALIZING
, this method will block for up to Configuration.getStateRetrievalTimeout()
millis, checking for a valid state.
originLocal
- true if the call originates locally (i.e., from the CacheDelegate
or
false if it originates remotely, i.e., from the InboundInvocationHandler
.
public Set<AbstractComponentRegistry.Component> getRegisteredComponents()
public AbstractComponentRegistry clone() throws CloneNotSupportedException
clone
in class Object
CloneNotSupportedException
|
Google Analytics | |||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |