@HashCodeAndEqualsPlugin.Enhance public static class ClassInjector.UsingReflection.Dispatcher.UsingUnsafeInjection extends Object implements ClassInjector.UsingReflection.Dispatcher, ClassInjector.UsingReflection.Dispatcher.Initializable
ClassInjector.UsingReflection.Dispatcher.CreationAction, ClassInjector.UsingReflection.Dispatcher.Direct, ClassInjector.UsingReflection.Dispatcher.Initializable, ClassInjector.UsingReflection.Dispatcher.Unavailable, ClassInjector.UsingReflection.Dispatcher.UsingUnsafeInjection, ClassInjector.UsingReflection.Dispatcher.UsingUnsafeOverrideClassInjector.UsingReflection.Dispatcher.Initializable.UnavailableUNDEFINED| Modifier | Constructor and Description |
|---|---|
protected |
UsingUnsafeInjection(Object accessor,
Method findLoadedClass,
Method defineClass,
Method getDefinedPackage,
Method getPackage,
Method definePackage,
Method getClassLoadingLock)
Creates a new class loading injection dispatcher using an unsafe injected dispatcher.
|
| Modifier and Type | Method and Description |
|---|---|
Class<?> |
defineClass(ClassLoader classLoader,
String name,
byte[] binaryRepresentation,
ProtectionDomain protectionDomain)
Defines a class for the given class loader.
|
Package |
definePackage(ClassLoader classLoader,
String name,
String specificationTitle,
String specificationVersion,
String specificationVendor,
String implementationTitle,
String implementationVersion,
String implementationVendor,
URL sealBase)
Defines a package for the given class loader.
|
Class<?> |
findClass(ClassLoader classLoader,
String name)
Looks up a class from the given class loader.
|
Object |
getClassLoadingLock(ClassLoader classLoader,
String name)
Returns the lock for loading the specified class.
|
Package |
getDefinedPackage(ClassLoader classLoader,
String name)
Looks up a package from a class loader.
|
Package |
getPackage(ClassLoader classLoader,
String name)
Looks up a package from a class loader or its ancestor.
|
ClassInjector.UsingReflection.Dispatcher |
initialize()
Initializes this dispatcher.
|
boolean |
isAvailable()
Indicates if this dispatcher is available.
|
protected static ClassInjector.UsingReflection.Dispatcher.Initializable |
make()
Creates an indirect dispatcher.
|
protected UsingUnsafeInjection(Object accessor, Method findLoadedClass, Method defineClass, @MaybeNull Method getDefinedPackage, Method getPackage, Method definePackage, Method getClassLoadingLock)
accessor - An instance of the accessor class that is required for using it's intentionally non-static methods.findLoadedClass - An instance of ClassLoader.findLoadedClass(String).defineClass - An instance of ClassLoader.defineClass(String, byte[], int, int, ProtectionDomain).getDefinedPackage - An instance of java.lang.ClassLoader#getDefinedPackage(String). May be null.getPackage - An instance of ClassLoader.getPackage(String).definePackage - An instance of ClassLoader.definePackage(String, String, String, String, String, String, String, URL).getClassLoadingLock - The accessor method for using ClassLoader#getClassLoadingLock(String) or returning the
supplied ClassLoader if this method does not exist on the current VM.protected static ClassInjector.UsingReflection.Dispatcher.Initializable make() throws Exception
Exception - If the dispatcher cannot be created.public boolean isAvailable()
isAvailable in interface ClassInjector.UsingReflection.Dispatcher.Initializabletrue if this dispatcher is available.public ClassInjector.UsingReflection.Dispatcher initialize()
initialize in interface ClassInjector.UsingReflection.Dispatcher.Initializablepublic Object getClassLoadingLock(ClassLoader classLoader, String name)
getClassLoadingLock in interface ClassInjector.UsingReflection.DispatcherclassLoader - the class loader to inject the class into.name - The name of the class.public Class<?> findClass(ClassLoader classLoader, String name)
findClass in interface ClassInjector.UsingReflection.DispatcherclassLoader - The class loader for which a class should be located.name - The binary name of the class that should be located.null if no such class is defined for the provided class loader.public Class<?> defineClass(ClassLoader classLoader, String name, byte[] binaryRepresentation, @MaybeNull ProtectionDomain protectionDomain)
defineClass in interface ClassInjector.UsingReflection.DispatcherclassLoader - The class loader for which a new class should be defined.name - The binary name of the class that should be defined.binaryRepresentation - The binary representation of the class.protectionDomain - The protection domain for the defined class.@MaybeNull public Package getDefinedPackage(ClassLoader classLoader, String name)
ClassInjector.UsingReflection.Dispatcher.getPackage(ClassLoader, String)getDefinedPackage in interface ClassInjector.UsingReflection.DispatcherclassLoader - The class loader to query.name - The binary name of the package.null if no such package exists.public Package getPackage(ClassLoader classLoader, String name)
getPackage in interface ClassInjector.UsingReflection.DispatcherclassLoader - The class loader to query.name - The binary name of the package.null if no such package exists.public Package definePackage(ClassLoader classLoader, String name, @MaybeNull String specificationTitle, @MaybeNull String specificationVersion, @MaybeNull String specificationVendor, @MaybeNull String implementationTitle, @MaybeNull String implementationVersion, @MaybeNull String implementationVendor, @MaybeNull URL sealBase)
definePackage in interface ClassInjector.UsingReflection.DispatcherclassLoader - The class loader for which a package is to be defined.name - The binary name of the package.specificationTitle - The specification title of the package or null if no specification title exists.specificationVersion - The specification version of the package or null if no specification version exists.specificationVendor - The specification vendor of the package or null if no specification vendor exists.implementationTitle - The implementation title of the package or null if no implementation title exists.implementationVersion - The implementation version of the package or null if no implementation version exists.implementationVendor - The implementation vendor of the package or null if no implementation vendor exists.sealBase - The seal base URL or null if the package should not be sealed.Copyright © 2014–2023. All rights reserved.