| 
 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectorg.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| Constructor Summary | |
|---|---|
| ReflectiveLoadTimeWeaver()Create a new ReflectiveLoadTimeWeaver for the current context class loader, which needs to support the required weaving methods. | |
| ReflectiveLoadTimeWeaver(ClassLoader classLoader)Create a new SimpleLoadTimeWeaver for the given class loader. | |
| Method Summary | |
|---|---|
|  void | addTransformer(ClassFileTransformer transformer)Add a ClassFileTransformerto be applied by thisLoadTimeWeaver. | 
|  ClassLoader | getInstrumentableClassLoader()Return a ClassLoaderthat supports instrumentation
 through AspectJ-style load-time weaving based on user-definedClassFileTransformers. | 
|  ClassLoader | getThrowawayClassLoader()Return a throwaway ClassLoader, enabling classes to be
 loaded and inspected without affecting the parentClassLoader. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Constructor Detail | 
|---|
public ReflectiveLoadTimeWeaver()
public ReflectiveLoadTimeWeaver(ClassLoader classLoader)
classLoader - the ClassLoader to delegate to for
 weaving (must support the required weaving methods).
IllegalStateException - if the supplied ClassLoader
 does not support the required weaving methods| Method Detail | 
|---|
public void addTransformer(ClassFileTransformer transformer)
LoadTimeWeaverClassFileTransformer to be applied by this
 LoadTimeWeaver.
addTransformer in interface LoadTimeWeavertransformer - the ClassFileTransformer to addpublic ClassLoader getInstrumentableClassLoader()
LoadTimeWeaverClassLoader 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 LoadTimeWeaverClassLoader which will expose
 instrumented classes according to the registered transformerspublic ClassLoader getThrowawayClassLoader()
LoadTimeWeaverClassLoader, 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 LoadTimeWeaverClassLoader; 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 | ||||||||