- java.lang.Object
- 
- jdk.dynalink.SecureLookupSupplier
- 
- jdk.dynalink.CallSiteDescriptor
 
 
- 
 
 public class CallSiteDescriptor extends SecureLookupSupplier Call site descriptors contain all the information necessary for linking a call site. This information is normally passed as parameters to bootstrap methods and consists of theMethodHandles.Lookupobject on the caller class in which the call site occurs, the dynamic operation at the call site, and the method type of the call site.CallSiteDescriptorobjects are used in Dynalink to capture and store these parameters for subsequent use by theDynamicLinker.The constructors of built-in RelinkableCallSiteimplementations all take a call site descriptor.Call site descriptors must be immutable. You can use this class as-is or you can subclass it, especially if you need to add further information to the descriptors (typically, values passed in additional parameters to the bootstrap method. Since the descriptors must be immutable, you can set up a cache for equivalent descriptors to have the call sites share them. The class extends SecureLookupSupplierfor security-checked access to theMethodHandles.Lookupobject it carries. This lookup should be used to find method handles to set as targets of the call site described by this descriptor.
- 
- 
Field Summary- 
Fields inherited from class jdk.dynalink.SecureLookupSupplierGET_LOOKUP_PERMISSION_NAME
 
- 
 - 
Constructor SummaryConstructors Constructor Description CallSiteDescriptor(MethodHandles.Lookup lookup, Operation operation, MethodType methodType)Creates a new call site descriptor.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description CallSiteDescriptorchangeMethodType(MethodType newMethodType)Finds or creates a call site descriptor that only differs in its method type from this descriptor.protected CallSiteDescriptorchangeMethodTypeInternal(MethodType newMethodType)Finds or creates a call site descriptor that only differs in its method type from this descriptor.CallSiteDescriptorchangeOperation(Operation newOperation)Finds or creates a call site descriptor that only differs in its operation from this descriptor.protected CallSiteDescriptorchangeOperationInternal(Operation newOperation)Finds or creates a call site descriptor that only differs in its operation from this descriptor.booleanequals(Object obj)Returns true if this call site descriptor is equal to the passed object.MethodTypegetMethodType()The type of the method at the call site.OperationgetOperation()Returns the operation at the call site.inthashCode()Returns a value-based hash code of this call site descriptor computed from its operation, method type, and lookup object's lookup class and lookup modes.StringtoString()Returns the string representation of this call site descriptor, of the formatname(parameterTypes)returnType@lookup.- 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from class jdk.dynalink.SecureLookupSuppliergetLookup, getLookupPrivileged
 
- 
 
- 
- 
- 
Constructor Detail- 
CallSiteDescriptorpublic CallSiteDescriptor(MethodHandles.Lookup lookup, Operation operation, MethodType methodType) Creates a new call site descriptor.- Parameters:
- lookup- the lookup object describing the class the call site belongs to. When creating descriptors from a- java.lang.invokebootstrap method, it should be the lookup passed to the bootstrap.
- operation- the dynamic operation at the call site.
- methodType- the method type of the call site. When creating descriptors from a- java.lang.invokebootstrap method, it should be the method type passed to the bootstrap.
 
 
- 
 - 
Method Detail- 
getOperationpublic final Operation getOperation() Returns the operation at the call site.- Returns:
- the operation at the call site.
 
 - 
getMethodTypepublic final MethodType getMethodType() The type of the method at the call site.- Returns:
- type of the method at the call site.
 
 - 
changeMethodTypepublic final CallSiteDescriptor changeMethodType(MethodType newMethodType) Finds or creates a call site descriptor that only differs in its method type from this descriptor. InvokeschangeMethodTypeInternal(MethodType).- Parameters:
- newMethodType- the new method type
- Returns:
- a call site descriptor with changed method type.
- Throws:
- NullPointerException- if- newMethodTypeis null.
 
 - 
changeMethodTypeInternalprotected CallSiteDescriptor changeMethodTypeInternal(MethodType newMethodType) Finds or creates a call site descriptor that only differs in its method type from this descriptor. Subclasses must override this method to return an object of their exact class. If an overridden method changes something other than the method type in the descriptor (its class, lookup, or operation), or returns null, anAssertionErrorwill be thrown fromchangeMethodType(MethodType).- Parameters:
- newMethodType- the new method type
- Returns:
- a call site descriptor with the changed method type.
 
 - 
changeOperationpublic final CallSiteDescriptor changeOperation(Operation newOperation) Finds or creates a call site descriptor that only differs in its operation from this descriptor. InvokeschangeOperationInternal(Operation).- Parameters:
- newOperation- the new operation
- Returns:
- a call site descriptor with the changed operation.
- Throws:
- NullPointerException- if- newOperationis null.
- SecurityException- if the descriptor's lookup isn't the- MethodHandles.publicLookup(), and a security manager is present, and a check for- RuntimePermission("dynalink.getLookup")fails. This is necessary as changing the operation in the call site descriptor allows fabrication of descriptors for arbitrary operations with the lookup.
 
 - 
changeOperationInternalprotected CallSiteDescriptor changeOperationInternal(Operation newOperation) Finds or creates a call site descriptor that only differs in its operation from this descriptor. Subclasses must override this method to return an object of their exact class. If an overridden method changes something other than the operation in the descriptor (its class, lookup, or method type), or returns null, anAssertionErrorwill be thrown fromchangeOperation(Operation).- Parameters:
- newOperation- the new operation
- Returns:
- a call site descriptor with the changed operation.
 
 - 
equalspublic boolean equals(Object obj) Returns true if this call site descriptor is equal to the passed object. It is considered equal if the other object is of the exact same class, their operations and method types are equal, and their lookups have the sameMethodHandles.Lookup.lookupClass()andMethodHandles.Lookup.lookupModes().- Overrides:
- equalsin class- Object
- Parameters:
- obj- the reference object with which to compare.
- Returns:
- trueif this object is the same as the obj argument;- falseotherwise.
- See Also:
- Object.hashCode(),- HashMap
 
 - 
hashCodepublic int hashCode() Returns a value-based hash code of this call site descriptor computed from its operation, method type, and lookup object's lookup class and lookup modes.- Overrides:
- hashCodein class- Object
- Returns:
- value-based hash code for this call site descriptor.
- See Also:
- Object.equals(java.lang.Object),- System.identityHashCode(java.lang.Object)
 
 
- 
 
-