Class HandleMethod
java.lang.Object
org.jruby.internal.runtime.methods.DynamicMethod
org.jruby.internal.runtime.methods.HandleMethod
- All Implemented Interfaces:
Cloneable,MethodArgs2
A DynamicMethod backed by one or more java.lang.invoke.MethodHandle objects.
The MethodHandles contained in this method are used by invokedynamic-based
call site binding to bind more directly to the target. Previously, the
handles required for binding were built at the call site by inspecting the
DynamicMethod that came in. With the newer logic, handles are created at
bind time, so they're already ready and so we don't need to generate our
own handle classes that might only get used by the interpreter.
-
Nested Class Summary
Nested classes/interfaces inherited from class org.jruby.internal.runtime.methods.DynamicMethod
DynamicMethod.NativeCall, DynamicMethod.Version -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final booleanprivate booleanprivate booleanprivate booleanprivate booleanprivate booleanprivate Callable<MethodHandle>private Callable<MethodHandle>private Callable<MethodHandle>private Callable<MethodHandle>private Callable<MethodHandle>private final intprivate final intprivate final booleanprivate final Stringprivate final Signatureprivate MethodHandleprivate MethodHandleprivate MethodHandleprivate MethodHandleprivate MethodHandleFields inherited from class org.jruby.internal.runtime.methods.DynamicMethod
definedClass, flags, handle, implementationClass, name, protectedClass, serialNumber -
Constructor Summary
ConstructorsConstructorDescriptionHandleMethod(RubyModule implementationClass, Visibility visibility, String name, long encodedSignature, boolean builtin, boolean notImplemented, String parameterDesc, int min, int max, Callable<MethodHandle> maker0, Callable<MethodHandle> maker1, Callable<MethodHandle> maker2, Callable<MethodHandle> maker3, Callable<MethodHandle> maker4) -
Method Summary
Modifier and TypeMethodDescriptioncall(ThreadContext context, IRubyObject self, RubyModule clazz, String name, Block block) Arity 0, with block; calls through IRubyObject[] pathcall(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject[] args, Block block) The minimum 'call' method required for a dynamic method handle.call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, Block block) Arity 1, with block; calls through IRubyObject[] pathcall(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, Block block) Arity 2, with block; calls through IRubyObject[] pathcall(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2, Block block) Arity 3, with block; calls through IRubyObject[] pathdup()Duplicate this method, returning DynamicMethod referencing the same code and with the same attributes.private MethodHandleprivate MethodHandleprivate MethodHandleprivate MethodHandleprivate MethodHandlegetArity()Deprecated.getHandle(int arity) String[]Retrieve the signature of this method.booleanbooleanisNative()Returns true if this method is backed by native (i.e.booleanWhether this method is "not implemented".private static MethodHandlesafeCall(Callable<MethodHandle> maker) Methods inherited from class org.jruby.internal.runtime.methods.DynamicMethod
calculateProtectedClass, call, call, call, call, call, callRespondTo, getCallConfig, getDefinedClass, getHandle, getImplementationClass, getInstanceVariableNames, getMethodData, getName, getProtectedClass, getRealMethod, getSerialNumber, getVisibility, init, init, isCallableFrom, isImplementedBy, isNull, isRefined, isUndefined, setCallConfig, setDefinedClass, setHandle, setImplementationClass, setIsBuiltin, setNotImplemented, setVisibility
-
Field Details
-
maker0
-
maker1
-
maker2
-
maker3
-
maker4
-
target0
-
target1
-
target2
-
target3
-
target4
-
initialized0
private volatile boolean initialized0 -
initialized1
private volatile boolean initialized1 -
initialized2
private volatile boolean initialized2 -
initialized3
private volatile boolean initialized3 -
initialized4
private volatile boolean initialized4 -
min
private final int min -
max
private final int max -
parameterDesc
-
signature
-
builtin
private final boolean builtin -
notImplemented
private final boolean notImplemented
-
-
Constructor Details
-
HandleMethod
public HandleMethod(RubyModule implementationClass, Visibility visibility, String name, long encodedSignature, boolean builtin, boolean notImplemented, String parameterDesc, int min, int max, Callable<MethodHandle> maker0, Callable<MethodHandle> maker1, Callable<MethodHandle> maker2, Callable<MethodHandle> maker3, Callable<MethodHandle> maker4)
-
-
Method Details
-
getArity
Deprecated.Description copied from class:DynamicMethodRetrieve the arity of this method, used for reporting arity to Ruby code. This arity may or may not reflect the actual specific or variable arities of the referenced method.- Overrides:
getArityin classDynamicMethod- Returns:
- The arity of the method, as reported to Ruby consumers.
-
getSignature
Description copied from class:DynamicMethodRetrieve the signature of this method.- Overrides:
getSignaturein classDynamicMethod- Returns:
- the signature
-
isBuiltin
public boolean isBuiltin()- Overrides:
isBuiltinin classDynamicMethod
-
isNotImplemented
public boolean isNotImplemented()Description copied from class:DynamicMethodWhether this method is "not implemented". This is primarily to support Ruby 1.9's behavior of respond_to? yielding false if the feature in question is unsupported (but still having the method defined).- Overrides:
isNotImplementedin classDynamicMethod
-
isNative
public boolean isNative()Description copied from class:DynamicMethodReturns true if this method is backed by native (i.e. Java) code.- Overrides:
isNativein classDynamicMethod- Returns:
- true If backed by Java code or JVM bytecode; false otherwise
-
ensureTarget0
-
ensureTarget1
-
ensureTarget2
-
ensureTarget3
-
ensureTarget4
-
safeCall
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject[] args, Block block) Description copied from class:DynamicMethodThe minimum 'call' method required for a dynamic method handle. Subclasses must implement this method, but may implement the other signatures to provide faster, non-boxing call paths. Typically subclasses will implement this method to check variable arity calls, then performing a specific-arity invocation to the appropriate method or performing variable-arity logic in-line.- Specified by:
callin classDynamicMethod- Parameters:
context- The thread context for the currently executing threadself- The 'self' or 'receiver' object to use for this callclazz- The Ruby class against which this method is bindingname- The incoming name used to invoke this methodargs- The argument list to this invocationblock- The block passed to this invocation- Returns:
- The result of the call
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, Block block) Description copied from class:DynamicMethodArity 0, with block; calls through IRubyObject[] path- Overrides:
callin classDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, Block block) Description copied from class:DynamicMethodArity 1, with block; calls through IRubyObject[] path- Overrides:
callin classDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, Block block) Description copied from class:DynamicMethodArity 2, with block; calls through IRubyObject[] path- Overrides:
callin classDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2, Block block) Description copied from class:DynamicMethodArity 3, with block; calls through IRubyObject[] path- Overrides:
callin classDynamicMethod
-
dup
Description copied from class:DynamicMethodDuplicate this method, returning DynamicMethod referencing the same code and with the same attributes. It is not required that this method produce a new object if the semantics of the DynamicMethod subtype do not require such.- Specified by:
dupin classDynamicMethod- Returns:
- An identical DynamicMethod object to the target.
-
getParameterList
- Specified by:
getParameterListin interfaceMethodArgs2
-
getHandle
-