Class ResolverUtil
ResolverUtil is used to locate classes that are available in the/a class path and meet arbitrary conditions. The two
most common conditions are that a class implements/extends another class, or that is it annotated with a specific
annotation. However, through the use of the ResolverUtil.Test
class it is possible to search using arbitrary conditions.
A ClassLoader is used to locate all locations (directories and jar files) in the class path that contain classes
within certain packages, and then to load those classes and check them. By default the ClassLoader returned by
Thread.currentThread().getContextClassLoader()
is used, but this can be overridden by calling
setClassLoader(ClassLoader)
prior to invoking any of the find()
methods.
General searches are initiated by calling the find(ResolverUtil.Test, String...)
method and supplying a
package name and a Test instance. This will cause the named package and all sub-packages to be scanned for
classes that meet the test. There are also utility methods for the common use cases of scanning multiple packages for
extensions of particular classes, or classes annotated with a specific annotation.
The standard usage pattern for the ResolverUtil class is as follows:
ResolverUtil resolver = new ResolverUtil(); resolver.findInPackage(new CustomTest(), pkg1); resolver.find(new CustomTest(), pkg1); resolver.find(new CustomTest(), pkg1, pkg2); Set<Class<?>> beans = resolver.getClasses();
This class was copied and modified from Stripes.
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic interface
A simple interface that specifies how to test classes to determine if they are to be included in the results produced by the ResolverUtil. -
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionprotected void
addIfMatching
(ResolverUtil.Test test, String fqn) Add the class designated by the fully qualified class name provided to the set of resolved classes if and only if it is approved by the Test supplied.void
find
(ResolverUtil.Test test, String... packageNames) Attempts to discover classes that pass the test.void
findInPackage
(ResolverUtil.Test test, String packageName) Scans for classes starting at the package provided and descending into subpackages.Provides access to the classes discovered so far.Returns the ClassLoader that will be used for scanning for classes.Returns the matching resources.void
setClassLoader
(ClassLoader aClassloader) Sets an explicit ClassLoader that should be used when scanning for classes.
-
Constructor Details
-
ResolverUtil
public ResolverUtil()
-
-
Method Details
-
getClasses
Provides access to the classes discovered so far. If no calls have been made to any of thefind()
methods, this set will be empty.- Returns:
- the set of classes that have been discovered.
-
getResources
Returns the matching resources.- Returns:
- A Set of URIs that match the criteria.
-
getClassLoader
Returns the ClassLoader that will be used for scanning for classes. If no explicit ClassLoader has been set by the calling, the context class loader will be used.- Returns:
- the ClassLoader that will be used to scan for classes
-
setClassLoader
Sets an explicit ClassLoader that should be used when scanning for classes. If none is set then the context ClassLoader will be used.- Parameters:
aClassloader
- a ClassLoader to use when scanning for classes
-
find
Attempts to discover classes that pass the test. Accumulated classes can be accessed by callinggetClasses()
.- Parameters:
test
- the test to determine matching classespackageNames
- one or more package names to scan (including subpackages) for classes
-
findInPackage
Scans for classes starting at the package provided and descending into subpackages. Each class is offered up to the Test as it is discovered, and if the Test returns true the class is retained. Accumulated classes can be fetched by callinggetClasses()
.- Parameters:
test
- an instance ofResolverUtil.Test
that will be used to filter classespackageName
- the name of the package from which to start scanning for classes, e.g.net.sourceforge.stripes
-
addIfMatching
Add the class designated by the fully qualified class name provided to the set of resolved classes if and only if it is approved by the Test supplied.- Parameters:
test
- the test used to determine if the class matchesfqn
- the fully qualified name of a class
-