Class ResettableClassFileTransformer.WithDelegation.Substitutable
java.lang.Object
net.bytebuddy.agent.builder.ResettableClassFileTransformer.AbstractBase
net.bytebuddy.agent.builder.ResettableClassFileTransformer.WithDelegation.Substitutable
- All Implemented Interfaces:
ClassFileTransformer, ResettableClassFileTransformer, ResettableClassFileTransformer.Substitutable
- Enclosing class:
ResettableClassFileTransformer.WithDelegation
@Enhance
protected static class ResettableClassFileTransformer.WithDelegation.Substitutable
extends ResettableClassFileTransformer.AbstractBase
implements ResettableClassFileTransformer.Substitutable
A standard implementation of a substitutable
ResettableClassFileTransformer.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescription(package private) static interfaceA factory for creating a subclass ofResettableClassFileTransformer.WithDelegation.Substitutablethat supports the module system, if available.Nested classes/interfaces inherited from interface ResettableClassFileTransformer
ResettableClassFileTransformer.AbstractBase, ResettableClassFileTransformer.Substitutable, ResettableClassFileTransformer.WithDelegation -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected ResettableClassFileTransformerThe class file transformer to delegate to.private static final ResettableClassFileTransformer.WithDelegation.Substitutable.FactoryA dispatcher for invoking the correct transformer method. -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedSubstitutable(ResettableClassFileTransformer classFileTransformer) Creates a new delegating resettable class file transformer. -
Method Summary
Modifier and TypeMethodDescriptioniterator(TypeDescription typeDescription, ClassLoader classLoader, JavaModule module, Class<?> classBeingRedefined, ProtectionDomain protectionDomain) Creates an iterator over the transformers that are applied for a given type.of(ResettableClassFileTransformer classFileTransformer) Creates a new substitutable class file transformer of another class file transformer.booleanreset(Instrumentation instrumentation, ResettableClassFileTransformer classFileTransformer, AgentBuilder.RedefinitionStrategy redefinitionStrategy, AgentBuilder.RedefinitionStrategy.DiscoveryStrategy redefinitionDiscoveryStrategy, AgentBuilder.RedefinitionStrategy.BatchAllocator redefinitionBatchAllocator, AgentBuilder.RedefinitionStrategy.Listener redefinitionListener) Deregisters this class file transformer and redefines any transformed class to its state without this class file transformer applied, if the supplied redefinition strategy is enabled.voidsubstitute(ResettableClassFileTransformer classFileTransformer) Substitutes the current class file transformer.byte[]transform(ClassLoader classLoader, String internalName, Class<?> classBeingRedefined, ProtectionDomain protectionDomain, byte[] binaryRepresentation) unwrap()Returns the underlying non-substitutable class file transformer.Methods inherited from class ResettableClassFileTransformer.AbstractBase
reset, reset, reset, reset, reset, reset, resetMethods inherited from class Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface ClassFileTransformer
transform
-
Field Details
-
DISPATCHER
A dispatcher for invoking the correct transformer method. -
classFileTransformer
The class file transformer to delegate to.
-
-
Constructor Details
-
Substitutable
Creates a new delegating resettable class file transformer.- Parameters:
classFileTransformer- The class file transformer to delegate to.
-
-
Method Details
-
of
public static ResettableClassFileTransformer.Substitutable of(ResettableClassFileTransformer classFileTransformer) Creates a new substitutable class file transformer of another class file transformer.- Parameters:
classFileTransformer- The class file transformer to wrap.- Returns:
- A substitutable version of the supplied class file transformer.
-
substitute
Substitutes the current class file transformer.- Specified by:
substitutein interfaceResettableClassFileTransformer.Substitutable- Parameters:
classFileTransformer- The class file transformer to use.
-
unwrap
Returns the underlying non-substitutable class file transformer.- Specified by:
unwrapin interfaceResettableClassFileTransformer.Substitutable- Returns:
- The underlying non-substitutable class file transformer.
-
iterator
public Iterator<AgentBuilder.Transformer> iterator(TypeDescription typeDescription, @MaybeNull ClassLoader classLoader, @MaybeNull JavaModule module, @MaybeNull Class<?> classBeingRedefined, @MaybeNull ProtectionDomain protectionDomain) Creates an iterator over the transformers that are applied for a given type.- Specified by:
iteratorin interfaceResettableClassFileTransformer- Parameters:
typeDescription- A description of a type.classLoader- The type's class loader ornullif the boot loader.module- The type's module ornullif the module system is not supported by the current VM.classBeingRedefined- The class being redefined ornullif the type is not yet loaded.protectionDomain- The type's protection domain ornullif not available.- Returns:
- An iterator over the transformers that are applied by this class file transformer if the given type is discovered.
-
reset
public boolean reset(Instrumentation instrumentation, ResettableClassFileTransformer classFileTransformer, AgentBuilder.RedefinitionStrategy redefinitionStrategy, AgentBuilder.RedefinitionStrategy.DiscoveryStrategy redefinitionDiscoveryStrategy, AgentBuilder.RedefinitionStrategy.BatchAllocator redefinitionBatchAllocator, AgentBuilder.RedefinitionStrategy.Listener redefinitionListener) Deregisters this class file transformer and redefines any transformed class to its state without this class file transformer applied, if the supplied redefinition strategy is enabled. If it is not enabled, only the
AgentBuilder.InstallationListeneris informed about the resetting without undoing any code changes.Note: A reset class file transformer should not be reinstalled. Instead, the
AgentBuilderwhich built the transformer should be asked to install a new transformer.Important: Most JVMs do not support changes of a class's structure after a class was already loaded. Therefore, it is typically required that this class file transformer was built while enabling
AgentBuilder.disableClassFormatChanges().- Specified by:
resetin interfaceResettableClassFileTransformer- Parameters:
instrumentation- The instrumentation instance from which to deregister the transformer.classFileTransformer- The actual class file transformer to deregister which might bethisinstance or any wrapper.redefinitionStrategy- The redefinition to apply.redefinitionDiscoveryStrategy- The discovery strategy for the types to reset.redefinitionBatchAllocator- The batch allocator to use.redefinitionListener- The redefinition listener to apply.- Returns:
trueif a reset was applied and this transformer was not previously removed.
-
transform
public byte[] transform(@MaybeNull ClassLoader classLoader, @MaybeNull String internalName, @MaybeNull Class<?> classBeingRedefined, @MaybeNull ProtectionDomain protectionDomain, byte[] binaryRepresentation) throws IllegalClassFormatException - Specified by:
transformin interfaceClassFileTransformer- Throws:
IllegalClassFormatException
-