Lookup
From APIDesign
Line 1: | Line 1: | ||
- | [[Lookup]] is | + | [[Lookup]] is a library that provides [[API]] that unifies [[Injection|component injection]] with adaptable pattern. It is based on long time [[JDK]] standard for registering instances of services in [[JAR]] files which has been formalized as [[ServiceLoader]] in [[JDK]] 6. [[Lookup]] extends this area and allows ''local pools'' of objects that can be queries for certain capability. [[Lookup]] is also suited for dynamic environment as it supports notification of changes. [[Lookup]] bridges the classical [[Injection|injection]] pattern with local adaptable pattern. |
- | * See [http://hudson.apidesign.org/hudson/job/lookup/org.apidesign$lookup/javadoc/ | + | * See [http://hudson.apidesign.org/hudson/job/lookup/org.apidesign$lookup/javadoc/ Javadoc] |
* [http://hudson.apidesign.org/hudson/job/lookup/org.apidesign$lookup/ Download page] | * [http://hudson.apidesign.org/hudson/job/lookup/org.apidesign$lookup/ Download page] | ||
Revision as of 05:38, 21 April 2009
Lookup is a library that provides API that unifies component injection with adaptable pattern. It is based on long time JDK standard for registering instances of services in JAR files which has been formalized as ServiceLoader in JDK 6. Lookup extends this area and allows local pools of objects that can be queries for certain capability. Lookup is also suited for dynamic environment as it supports notification of changes. Lookup bridges the classical injection pattern with local adaptable pattern.
- See Javadoc
- Download page
The basic idea, in its ServiceLoader incarnation is that it is enough to compose an application from various JAR files and let these JAR files communicate. This is achieved by defining well-known location inside the JAR file META-INF/services/nameoftype that is read from all available libraries JARs on the classpath.
This greatly simplifies final assembly and deployment of the application. It is enough to drop the JARs with an implementation available in the system and all the pieces can work suddenly cooperate by mutually discovering themselves via Lookup.getDefault().lookup(...).
On the other hand, looking from a local point of view, there can be many pools to fish for an interface. Almost any object can implement Lookup.Provider interface and thus give access to its adaptable features to everyone.
Using the same interface to play two different roles (component injection and Adaptable pattern) shows the common properties of both.