|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.instrument.classloading.ReflectiveLoadTimeWeaver
public class ReflectiveLoadTimeWeaver
LoadTimeWeaver
which uses reflection to delegate to an underlying ClassLoader
with well-known transformation hooks. The underlying ClassLoader is expected to
support the following weaving methods (as defined in the LoadTimeWeaver
interface):
public void addTransformer(java.lang.instrument.ClassFileTransformer)
:
for registering the given ClassFileTransformer on this ClassLoader
public ClassLoader getThrowawayClassLoader()
:
for obtaining a throwaway class loader for this ClassLoader (optional;
ReflectiveLoadTimeWeaver will fall back to a SimpleThrowawayClassLoader if
that method isn't available)
Please note that the above methods must reside in a class that is publicly accessible, although the class itself does not have to be visible to the application's class loader.
The reflective nature of this LoadTimeWeaver is particularly useful when the underlying ClassLoader implementation is loaded in a different class loader itself (such as the application server's class loader which is not visible to the web application). There is no direct API dependency between this LoadTimeWeaver adapter and the underlying ClassLoader, just a 'loose' method contract.
This is the LoadTimeWeaver to use in combination with Spring's
TomcatInstrumentableClassLoader
for Tomcat 5.0+ as well as with the Resin application server version 3.1+.
addTransformer(java.lang.instrument.ClassFileTransformer)
,
getThrowawayClassLoader()
,
SimpleThrowawayClassLoader
,
TomcatInstrumentableClassLoader
Field Summary | |
---|---|
private static java.lang.String |
ADD_TRANSFORMER_METHOD_NAME
|
private java.lang.reflect.Method |
addTransformerMethod
|
private java.lang.ClassLoader |
classLoader
|
private static java.lang.String |
GET_THROWAWAY_CLASS_LOADER_METHOD_NAME
|
private java.lang.reflect.Method |
getThrowawayClassLoaderMethod
|
private static Log |
logger
|
Constructor Summary | |
---|---|
ReflectiveLoadTimeWeaver()
Create a new ReflectiveLoadTimeWeaver for the current context class loader, which needs to support the required weaving methods. |
|
ReflectiveLoadTimeWeaver(java.lang.ClassLoader classLoader)
Create a new SimpleLoadTimeWeaver for the given class loader. |
Method Summary | |
---|---|
void |
addTransformer(java.lang.instrument.ClassFileTransformer transformer)
Add a ClassFileTransformer to be applied by this
LoadTimeWeaver . |
java.lang.ClassLoader |
getInstrumentableClassLoader()
Return a ClassLoader that supports instrumentation
through AspectJ-style load-time weaving based on user-defined
ClassFileTransformers . |
java.lang.ClassLoader |
getThrowawayClassLoader()
Return a throwaway ClassLoader , enabling classes to be
loaded and inspected without affecting the parent ClassLoader . |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
private static final java.lang.String ADD_TRANSFORMER_METHOD_NAME
private static final java.lang.String GET_THROWAWAY_CLASS_LOADER_METHOD_NAME
private static final Log logger
private final java.lang.ClassLoader classLoader
private final java.lang.reflect.Method addTransformerMethod
private final java.lang.reflect.Method getThrowawayClassLoaderMethod
Constructor Detail |
---|
public ReflectiveLoadTimeWeaver()
public ReflectiveLoadTimeWeaver(java.lang.ClassLoader classLoader)
classLoader
- the ClassLoader
to delegate to for
weaving (must support the required weaving methods).
java.lang.IllegalStateException
- if the supplied ClassLoader
does not support the required weaving methodsMethod Detail |
---|
public void addTransformer(java.lang.instrument.ClassFileTransformer transformer)
LoadTimeWeaver
ClassFileTransformer
to be applied by this
LoadTimeWeaver
.
addTransformer
in interface LoadTimeWeaver
transformer
- the ClassFileTransformer
to addpublic java.lang.ClassLoader getInstrumentableClassLoader()
LoadTimeWeaver
ClassLoader
that supports instrumentation
through AspectJ-style load-time weaving based on user-defined
ClassFileTransformers
.
May be the current ClassLoader
, or a ClassLoader
created by this LoadTimeWeaver
instance.
getInstrumentableClassLoader
in interface LoadTimeWeaver
ClassLoader
which will expose
instrumented classes according to the registered transformerspublic java.lang.ClassLoader getThrowawayClassLoader()
LoadTimeWeaver
ClassLoader
, enabling classes to be
loaded and inspected without affecting the parent ClassLoader
.
Should not return the same instance of the ClassLoader
returned from an invocation of LoadTimeWeaver.getInstrumentableClassLoader()
.
getThrowawayClassLoader
in interface LoadTimeWeaver
ClassLoader
; should return
a new instance for each call, with no existing state
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |