Class ProfilingDynamicMethod
java.lang.Object
org.jruby.internal.runtime.methods.DynamicMethod
org.jruby.internal.runtime.methods.DelegatingDynamicMethod
org.jruby.internal.runtime.methods.ProfilingDynamicMethod
- All Implemented Interfaces:
IRMethodArgs
A DynamicMethod wrapper that performs timed profiling for each call.
-
Nested Class Summary
Nested classes/interfaces inherited from class org.jruby.internal.runtime.methods.DynamicMethod
DynamicMethod.NativeCall, DynamicMethod.Version
-
Field Summary
Fields inherited from class org.jruby.internal.runtime.methods.DelegatingDynamicMethod
delegate
Fields inherited from class org.jruby.internal.runtime.methods.DynamicMethod
aliasCount, definedClass, flags, handle, implementationClass, name, protectedClass, serialNumber
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptioncall
(ThreadContext context, IRubyObject self, RubyModule clazz, String name) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, Block block) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject[] args) A default implementation of n-arity, non-block 'call' method, which simply calls the n-arity, block-receiving version with the arg list and Block.NULL_BLOCK.call
(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) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, Block block) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2) call
(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2, Block block) dup()
Duplicate this method, returning DynamicMethod referencing the same code and with the same attributes.Get the array of ArgumentDescriptors that represent the arguments to this method.Retrieve the signature of this method.void
Indicates the method will behave like a ruby2 keywords accepting method.Methods inherited from class org.jruby.internal.runtime.methods.DelegatingDynamicMethod
equals, getArity, getDelegate, getHandle, getImplementationClass, getInstanceVariableNames, getMethodData, getName, getProtectedClass, getRealMethod, getSerialNumber, getVisibility, hashCode, isBuiltin, isCallableFrom, isImplementedBy, isNative, isNotImplemented, isRefined, setHandle, setImplementationClass, setIsBuiltin, setNotImplemented, setVisibility
Methods inherited from class org.jruby.internal.runtime.methods.DynamicMethod
adjustAliasCount, calculateProtectedClass, callRespondTo, getAliasCount, getCallConfig, getDefinedClass, init, init, isNull, isUndefined, setCallConfig, setDefinedClass
-
Constructor Details
-
ProfilingDynamicMethod
-
-
Method Details
-
call
- Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject[] args) Description copied from class:DynamicMethod
A default implementation of n-arity, non-block 'call' method, which simply calls the n-arity, block-receiving version with the arg list and Block.NULL_BLOCK.- Overrides:
call
in classDelegatingDynamicMethod
- 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 first argument to this invocation- Returns:
- The result of the call
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, Block block) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, Block block) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, Block block) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject arg0, IRubyObject arg1, IRubyObject arg2, Block block) - Overrides:
call
in classDelegatingDynamicMethod
-
call
public IRubyObject call(ThreadContext context, IRubyObject self, RubyModule clazz, String name, IRubyObject[] args, Block block) Description copied from class:DynamicMethod
The 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.- Overrides:
call
in classDelegatingDynamicMethod
- 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
-
dup
Description copied from class:DynamicMethod
Duplicate 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:
dup
in classDelegatingDynamicMethod
- Returns:
- An identical DynamicMethod object to the target.
-
getSignature
Description copied from class:DynamicMethod
Retrieve the signature of this method.- Specified by:
getSignature
in interfaceIRMethodArgs
- Overrides:
getSignature
in classDelegatingDynamicMethod
- Returns:
- the signature
-
getArgumentDescriptors
Description copied from interface:IRMethodArgs
Get the array of ArgumentDescriptors that represent the arguments to this method.- Specified by:
getArgumentDescriptors
in interfaceIRMethodArgs
- Returns:
- this methods argument descriptors
-
setRuby2Keywords
public void setRuby2Keywords()Description copied from class:DynamicMethod
Indicates the method will behave like a ruby2 keywords accepting method. This must be a Ruby implementation to work. See Module#ruby2_keywords for information on the semantics of a method which is marked this way.- Specified by:
setRuby2Keywords
in interfaceIRMethodArgs
- Overrides:
setRuby2Keywords
in classDynamicMethod
-