public class org.jruby.internal.runtime.methods.MixedModeIRMethod extends org.jruby.internal.runtime.AbstractIRMethod implements org.jruby.compiler.Compilable<org.jruby.internal.runtime.methods.DynamicMethod>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: org.jruby.internal.runtime.methods.MixedModeIRMethod
super_class: org.jruby.internal.runtime.AbstractIRMethod
{
private static final org.jruby.util.log.Logger LOG;
descriptor: Lorg/jruby/util/log/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private boolean displayedCFG;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
private volatile org.jruby.internal.runtime.methods.DynamicMethod actualMethod;
descriptor: Lorg/jruby/internal/runtime/methods/DynamicMethod;
flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
invokestatic org.jruby.util.log.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/jruby/util/log/Logger;
putstatic org.jruby.internal.runtime.methods.MixedModeIRMethod.LOG:Lorg/jruby/util/log/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(org.jruby.ir.IRScope, org.jruby.runtime.Visibility, org.jruby.RubyModule);
descriptor: (Lorg/jruby/ir/IRScope;Lorg/jruby/runtime/Visibility;Lorg/jruby/RubyModule;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 0
aload 1
aload 2
aload 3
invokespecial org.jruby.internal.runtime.AbstractIRMethod.<init>:(Lorg/jruby/ir/IRScope;Lorg/jruby/runtime/Visibility;Lorg/jruby/RubyModule;)V
1: aload 0
iconst_0
putfield org.jruby.internal.runtime.methods.MixedModeIRMethod.displayedCFG:Z
2: aload 3
invokevirtual org.jruby.RubyModule.getRuntime:()Lorg/jruby/Ruby;
invokevirtual org.jruby.Ruby.getInstanceConfig:()Lorg/jruby/RubyInstanceConfig;
invokevirtual org.jruby.RubyInstanceConfig.isJitEnabled:()Z
ifne 3
aload 0
iconst_m1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.setCallCount:(I)V
3: StackMap locals: org.jruby.internal.runtime.methods.MixedModeIRMethod org.jruby.ir.IRScope org.jruby.runtime.Visibility org.jruby.RubyModule
StackMap stack:
aload 1
aload 0
putfield org.jruby.ir.IRScope.compilable:Lorg/jruby/compiler/Compilable;
4: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 5 1 method Lorg/jruby/ir/IRScope;
0 5 2 visibility Lorg/jruby/runtime/Visibility;
0 5 3 implementationClass Lorg/jruby/RubyModule;
MethodParameters:
Name Flags
method
visibility
implementationClass
public org.jruby.internal.runtime.methods.DynamicMethod getActualMethod();
descriptor: ()Lorg/jruby/internal/runtime/methods/DynamicMethod;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
protected void post(org.jruby.ir.interpreter.InterpreterContext, org.jruby.runtime.ThreadContext);
descriptor: (Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=1, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokevirtual org.jruby.runtime.ThreadContext.popFrame:()V
1: aload 1
invokevirtual org.jruby.ir.interpreter.InterpreterContext.popDynScope:()Z
ifeq 3
2: aload 2
invokevirtual org.jruby.runtime.ThreadContext.popScope:()V
3: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 4 1 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 4 2 context Lorg/jruby/runtime/ThreadContext;
MethodParameters:
Name Flags
ic
context
protected void pre(org.jruby.ir.interpreter.InterpreterContext, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.Block, org.jruby.RubyModule);
descriptor: (Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=7, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 2
aload 6
aload 4
aload 3
aload 5
invokevirtual org.jruby.runtime.ThreadContext.preMethodFrameOnly:(Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)V
1: aload 1
invokevirtual org.jruby.ir.interpreter.InterpreterContext.pushNewDynScope:()Z
ifeq 3
2: aload 2
aload 1
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getStaticScope:()Lorg/jruby/parser/StaticScope;
invokestatic org.jruby.runtime.DynamicScope.newDynamicScope:(Lorg/jruby/parser/StaticScope;)Lorg/jruby/runtime/DynamicScope;
invokevirtual org.jruby.runtime.ThreadContext.pushScope:(Lorg/jruby/runtime/DynamicScope;)V
3: StackMap locals:
StackMap stack:
return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 4 1 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 4 2 context Lorg/jruby/runtime/ThreadContext;
0 4 3 self Lorg/jruby/runtime/builtin/IRubyObject;
0 4 4 name Ljava/lang/String;
0 4 5 block Lorg/jruby/runtime/Block;
0 4 6 implClass Lorg/jruby/RubyModule;
MethodParameters:
Name Flags
ic
context
self
name
block
implClass
protected void printMethodIR();
descriptor: ()V
flags: (0x0004) ACC_PROTECTED
Code:
stack=5, locals=2, args_size=1
start local 0 0: aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.method:Lorg/jruby/ir/IRScope;
iconst_0
invokestatic org.jruby.ir.persistence.IRDumper.printIR:(Lorg/jruby/ir/IRScope;Z)Ljava/io/ByteArrayOutputStream;
astore 1
start local 1 1: getstatic org.jruby.internal.runtime.methods.MixedModeIRMethod.LOG:Lorg/jruby/util/log/Logger;
new java.lang.StringBuilder
dup
ldc "Printing simple IR for "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.method:Lorg/jruby/ir/IRScope;
invokevirtual org.jruby.ir.IRScope.getId:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc ":\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
new java.lang.String
dup
aload 1
invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
invokespecial java.lang.String.<init>:([B)V
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
1 3 1 baos Ljava/io/ByteArrayOutputStream;
public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyModule, java.lang.String, org.jruby.runtime.builtin.IRubyObject[], org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=8, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: invokestatic org.jruby.ir.runtime.IRRuntimeHelpers.isDebug:()Z
ifeq 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.doDebug:()V
1: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
iflt 2
aload 1
aload 0
invokestatic org.jruby.internal.runtime.methods.MixedModeIRMethod.tryJit:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/internal/runtime/AbstractIRMethod;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
astore 7
start local 7 3: aload 7
ifnull 5
4: aload 7
aload 1
aload 2
aload 3
aload 4
aload 5
aload 6
invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
5: StackMap locals: org.jruby.internal.runtime.methods.DynamicMethod
StackMap stack:
aload 0
aload 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
aload 3
aload 2
aload 4
aload 5
aload 6
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.INTERPRET_METHOD:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 6 1 context Lorg/jruby/runtime/ThreadContext;
0 6 2 self Lorg/jruby/runtime/builtin/IRubyObject;
0 6 3 clazz Lorg/jruby/RubyModule;
0 6 4 name Ljava/lang/String;
0 6 5 args [Lorg/jruby/runtime/builtin/IRubyObject;
0 6 6 block Lorg/jruby/runtime/Block;
3 6 7 jittedMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
context
self
clazz
name
args
block
private org.jruby.runtime.builtin.IRubyObject INTERPRET_METHOD(org.jruby.runtime.ThreadContext, org.jruby.ir.interpreter.InterpreterContext, org.jruby.RubyModule, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.builtin.IRubyObject[], org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0002) ACC_PRIVATE
Code:
stack=9, locals=12, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 1
aload 5
aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getFileName:()Ljava/lang/String;
aload 1
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokestatic org.jruby.runtime.ThreadContext.pushBacktrace:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;Ljava/lang/String;I)V
1: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.hasExplicitCallProtocol:()Z
ifeq 5
2: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 11
3: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
4: aload 11
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
aload 4
aload 5
aload 7
aload 3
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.pre:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
6: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 9
7: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
8: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
9: aload 9
areturn
10: StackMap locals:
StackMap stack: java.lang.Throwable
astore 8
11: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
12: aload 8
athrow
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 10
14: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
15: aload 10
athrow
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 16 1 context Lorg/jruby/runtime/ThreadContext;
0 16 2 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 16 3 implClass Lorg/jruby/RubyModule;
0 16 4 self Lorg/jruby/runtime/builtin/IRubyObject;
0 16 5 name Ljava/lang/String;
0 16 6 args [Lorg/jruby/runtime/builtin/IRubyObject;
0 16 7 block Lorg/jruby/runtime/Block;
Exception table:
from to target type
5 7 10 any
0 3 13 any
5 8 13 any
10 13 13 any
MethodParameters:
Name Flags
context
ic
implClass
self
name
args
block
public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyModule, java.lang.String, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=7, args_size=6
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 0: invokestatic org.jruby.ir.runtime.IRRuntimeHelpers.isDebug:()Z
ifeq 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.doDebug:()V
1: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
iflt 2
aload 1
aload 0
invokestatic org.jruby.internal.runtime.methods.MixedModeIRMethod.tryJit:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/internal/runtime/AbstractIRMethod;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
astore 6
start local 6 3: aload 6
ifnull 5
4: aload 6
aload 1
aload 2
aload 3
aload 4
aload 5
invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
5: StackMap locals: org.jruby.internal.runtime.methods.DynamicMethod
StackMap stack:
aload 0
aload 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
aload 3
aload 2
aload 4
aload 5
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.INTERPRET_METHOD:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 6 1 context Lorg/jruby/runtime/ThreadContext;
0 6 2 self Lorg/jruby/runtime/builtin/IRubyObject;
0 6 3 clazz Lorg/jruby/RubyModule;
0 6 4 name Ljava/lang/String;
0 6 5 block Lorg/jruby/runtime/Block;
3 6 6 jittedMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
context
self
clazz
name
block
private org.jruby.runtime.builtin.IRubyObject INTERPRET_METHOD(org.jruby.runtime.ThreadContext, org.jruby.ir.interpreter.InterpreterContext, org.jruby.RubyModule, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0002) ACC_PRIVATE
Code:
stack=8, locals=11, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: aload 1
aload 5
aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getFileName:()Ljava/lang/String;
aload 1
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokestatic org.jruby.runtime.ThreadContext.pushBacktrace:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;Ljava/lang/String;I)V
1: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.hasExplicitCallProtocol:()Z
ifeq 5
2: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 10
3: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
4: aload 10
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
aload 4
aload 5
aload 6
aload 3
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.pre:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
6: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 8
7: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
8: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
9: aload 8
areturn
10: StackMap locals:
StackMap stack: java.lang.Throwable
astore 7
11: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
12: aload 7
athrow
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 9
14: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
15: aload 9
athrow
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 16 1 context Lorg/jruby/runtime/ThreadContext;
0 16 2 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 16 3 implClass Lorg/jruby/RubyModule;
0 16 4 self Lorg/jruby/runtime/builtin/IRubyObject;
0 16 5 name Ljava/lang/String;
0 16 6 block Lorg/jruby/runtime/Block;
Exception table:
from to target type
5 7 10 any
0 3 13 any
5 8 13 any
10 13 13 any
MethodParameters:
Name Flags
context
ic
implClass
self
name
block
public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyModule, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=8, args_size=7
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 0: invokestatic org.jruby.ir.runtime.IRRuntimeHelpers.isDebug:()Z
ifeq 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.doDebug:()V
1: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
iflt 2
aload 1
aload 0
invokestatic org.jruby.internal.runtime.methods.MixedModeIRMethod.tryJit:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/internal/runtime/AbstractIRMethod;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
astore 7
start local 7 3: aload 7
ifnull 5
4: aload 7
aload 1
aload 2
aload 3
aload 4
aload 5
aload 6
invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
5: StackMap locals: org.jruby.internal.runtime.methods.DynamicMethod
StackMap stack:
aload 0
aload 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
aload 3
aload 2
aload 4
aload 5
aload 6
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.INTERPRET_METHOD:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 6 1 context Lorg/jruby/runtime/ThreadContext;
0 6 2 self Lorg/jruby/runtime/builtin/IRubyObject;
0 6 3 clazz Lorg/jruby/RubyModule;
0 6 4 name Ljava/lang/String;
0 6 5 arg0 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 6 block Lorg/jruby/runtime/Block;
3 6 7 jittedMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
context
self
clazz
name
arg0
block
private org.jruby.runtime.builtin.IRubyObject INTERPRET_METHOD(org.jruby.runtime.ThreadContext, org.jruby.ir.interpreter.InterpreterContext, org.jruby.RubyModule, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0002) ACC_PRIVATE
Code:
stack=9, locals=12, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: aload 1
aload 5
aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getFileName:()Ljava/lang/String;
aload 1
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokestatic org.jruby.runtime.ThreadContext.pushBacktrace:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;Ljava/lang/String;I)V
1: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.hasExplicitCallProtocol:()Z
ifeq 5
2: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 11
3: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
4: aload 11
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
aload 4
aload 5
aload 7
aload 3
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.pre:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
6: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 9
7: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
8: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
9: aload 9
areturn
10: StackMap locals:
StackMap stack: java.lang.Throwable
astore 8
11: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
12: aload 8
athrow
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 10
14: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
15: aload 10
athrow
end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 16 1 context Lorg/jruby/runtime/ThreadContext;
0 16 2 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 16 3 implClass Lorg/jruby/RubyModule;
0 16 4 self Lorg/jruby/runtime/builtin/IRubyObject;
0 16 5 name Ljava/lang/String;
0 16 6 arg1 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 7 block Lorg/jruby/runtime/Block;
Exception table:
from to target type
5 7 10 any
0 3 13 any
5 8 13 any
10 13 13 any
MethodParameters:
Name Flags
context
ic
implClass
self
name
arg1
block
public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyModule, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0001) ACC_PUBLIC
Code:
stack=9, locals=9, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 0: invokestatic org.jruby.ir.runtime.IRRuntimeHelpers.isDebug:()Z
ifeq 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.doDebug:()V
1: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
iflt 2
aload 1
aload 0
invokestatic org.jruby.internal.runtime.methods.MixedModeIRMethod.tryJit:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/internal/runtime/AbstractIRMethod;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
astore 8
start local 8 3: aload 8
ifnull 5
4: aload 8
aload 1
aload 2
aload 3
aload 4
aload 5
aload 6
aload 7
invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
5: StackMap locals: org.jruby.internal.runtime.methods.DynamicMethod
StackMap stack:
aload 0
aload 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
aload 3
aload 2
aload 4
aload 5
aload 6
aload 7
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.INTERPRET_METHOD:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 6 1 context Lorg/jruby/runtime/ThreadContext;
0 6 2 self Lorg/jruby/runtime/builtin/IRubyObject;
0 6 3 clazz Lorg/jruby/RubyModule;
0 6 4 name Ljava/lang/String;
0 6 5 arg0 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 6 arg1 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 7 block Lorg/jruby/runtime/Block;
3 6 8 jittedMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
context
self
clazz
name
arg0
arg1
block
private org.jruby.runtime.builtin.IRubyObject INTERPRET_METHOD(org.jruby.runtime.ThreadContext, org.jruby.ir.interpreter.InterpreterContext, org.jruby.RubyModule, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0002) ACC_PRIVATE
Code:
stack=10, locals=13, args_size=9
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: aload 1
aload 5
aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getFileName:()Ljava/lang/String;
aload 1
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokestatic org.jruby.runtime.ThreadContext.pushBacktrace:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;Ljava/lang/String;I)V
1: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.hasExplicitCallProtocol:()Z
ifeq 5
2: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
aload 8
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 12
3: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
4: aload 12
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
aload 4
aload 5
aload 8
aload 3
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.pre:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
6: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
aload 8
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 10
7: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
8: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
9: aload 10
areturn
10: StackMap locals:
StackMap stack: java.lang.Throwable
astore 9
11: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
12: aload 9
athrow
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 11
14: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
15: aload 11
athrow
end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 16 1 context Lorg/jruby/runtime/ThreadContext;
0 16 2 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 16 3 implClass Lorg/jruby/RubyModule;
0 16 4 self Lorg/jruby/runtime/builtin/IRubyObject;
0 16 5 name Ljava/lang/String;
0 16 6 arg1 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 7 arg2 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 8 block Lorg/jruby/runtime/Block;
Exception table:
from to target type
5 7 10 any
0 3 13 any
5 8 13 any
10 13 13 any
MethodParameters:
Name Flags
context
ic
implClass
self
name
arg1
arg2
block
public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyModule, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0001) ACC_PUBLIC
Code:
stack=10, locals=10, args_size=9
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 0: invokestatic org.jruby.ir.runtime.IRRuntimeHelpers.isDebug:()Z
ifeq 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.doDebug:()V
1: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
iflt 2
aload 1
aload 0
invokestatic org.jruby.internal.runtime.methods.MixedModeIRMethod.tryJit:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/internal/runtime/AbstractIRMethod;)V
2: StackMap locals:
StackMap stack:
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
astore 9
start local 9 3: aload 9
ifnull 5
4: aload 9
aload 1
aload 2
aload 3
aload 4
aload 5
aload 6
aload 7
aload 8
invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
5: StackMap locals: org.jruby.internal.runtime.methods.DynamicMethod
StackMap stack:
aload 0
aload 1
aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
aload 3
aload 2
aload 4
aload 5
aload 6
aload 7
aload 8
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.INTERPRET_METHOD:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
areturn
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 6 1 context Lorg/jruby/runtime/ThreadContext;
0 6 2 self Lorg/jruby/runtime/builtin/IRubyObject;
0 6 3 clazz Lorg/jruby/RubyModule;
0 6 4 name Ljava/lang/String;
0 6 5 arg0 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 6 arg1 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 7 arg2 Lorg/jruby/runtime/builtin/IRubyObject;
0 6 8 block Lorg/jruby/runtime/Block;
3 6 9 jittedMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
context
self
clazz
name
arg0
arg1
arg2
block
private org.jruby.runtime.builtin.IRubyObject INTERPRET_METHOD(org.jruby.runtime.ThreadContext, org.jruby.ir.interpreter.InterpreterContext, org.jruby.RubyModule, org.jruby.runtime.builtin.IRubyObject, java.lang.String, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.Block);
descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
flags: (0x0002) ACC_PRIVATE
Code:
stack=11, locals=14, args_size=10
start local 0 start local 1 start local 2 start local 3 start local 4 start local 5 start local 6 start local 7 start local 8 start local 9 0: aload 1
aload 5
aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getFileName:()Ljava/lang/String;
aload 1
invokevirtual org.jruby.runtime.ThreadContext.getLine:()I
invokestatic org.jruby.runtime.ThreadContext.pushBacktrace:(Lorg/jruby/runtime/ThreadContext;Ljava/lang/String;Ljava/lang/String;I)V
1: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.hasExplicitCallProtocol:()Z
ifeq 5
2: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
aload 8
aload 9
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 13
3: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
4: aload 13
areturn
5: StackMap locals:
StackMap stack:
aload 0
aload 2
aload 1
aload 4
aload 5
aload 9
aload 3
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.pre:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;Lorg/jruby/runtime/Block;Lorg/jruby/RubyModule;)V
6: aload 2
invokevirtual org.jruby.ir.interpreter.InterpreterContext.getEngine:()Lorg/jruby/ir/interpreter/InterpreterEngine;
aload 1
aconst_null
aload 4
aload 2
aload 3
aload 5
aload 6
aload 7
aload 8
aload 9
invokevirtual org.jruby.ir.interpreter.InterpreterEngine.interpret:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/RubyModule;Ljava/lang/String;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
astore 11
7: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
8: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
9: aload 11
areturn
10: StackMap locals:
StackMap stack: java.lang.Throwable
astore 10
11: aload 0
aload 2
aload 1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.post:(Lorg/jruby/ir/interpreter/InterpreterContext;Lorg/jruby/runtime/ThreadContext;)V
12: aload 10
athrow
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 12
14: aload 1
invokestatic org.jruby.runtime.ThreadContext.popBacktrace:(Lorg/jruby/runtime/ThreadContext;)V
15: aload 12
athrow
end local 9 end local 8 end local 7 end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 16 1 context Lorg/jruby/runtime/ThreadContext;
0 16 2 ic Lorg/jruby/ir/interpreter/InterpreterContext;
0 16 3 implClass Lorg/jruby/RubyModule;
0 16 4 self Lorg/jruby/runtime/builtin/IRubyObject;
0 16 5 name Ljava/lang/String;
0 16 6 arg1 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 7 arg2 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 8 arg3 Lorg/jruby/runtime/builtin/IRubyObject;
0 16 9 block Lorg/jruby/runtime/Block;
Exception table:
from to target type
5 7 10 any
0 3 13 any
5 8 13 any
10 13 13 any
MethodParameters:
Name Flags
context
ic
implClass
self
name
arg1
arg2
arg3
block
private void doDebug();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.ensureInstrsReady:()Lorg/jruby/ir/interpreter/InterpreterContext;
pop
1: getstatic org.jruby.internal.runtime.methods.MixedModeIRMethod.LOG:Lorg/jruby/util/log/Logger;
new java.lang.StringBuilder
dup
ldc "Executing '"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.method:Lorg/jruby/ir/IRScope;
invokevirtual org.jruby.ir.IRScope.getId:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "'"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
2: aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.displayedCFG:Z
ifne 5
3: getstatic org.jruby.internal.runtime.methods.MixedModeIRMethod.LOG:Lorg/jruby/util/log/Logger;
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.method:Lorg/jruby/ir/IRScope;
invokevirtual org.jruby.ir.IRScope.debugOutput:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
invokeinterface org.jruby.util.log.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
4: aload 0
iconst_1
putfield org.jruby.internal.runtime.methods.MixedModeIRMethod.displayedCFG:Z
5: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
public void completeBuild(org.jruby.internal.runtime.methods.DynamicMethod);
descriptor: (Lorg/jruby/internal/runtime/methods/DynamicMethod;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
iconst_m1
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.setCallCount:(I)V
1: aload 1
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.serialNumber:J
putfield org.jruby.internal.runtime.methods.DynamicMethod.serialNumber:J
2: aload 0
aload 1
putfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
3: aload 0
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.getImplementationClass:()Lorg/jruby/RubyModule;
invokevirtual org.jruby.RubyModule.invalidateCacheDescendants:()V
4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
0 5 1 newMethod Lorg/jruby/internal/runtime/methods/DynamicMethod;
MethodParameters:
Name Flags
newMethod
public org.jruby.internal.runtime.methods.DynamicMethod dup();
descriptor: ()Lorg/jruby/internal/runtime/methods/DynamicMethod;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokespecial org.jruby.internal.runtime.AbstractIRMethod.dup:()Lorg/jruby/internal/runtime/methods/DynamicMethod;
checkcast org.jruby.internal.runtime.methods.MixedModeIRMethod
astore 1
start local 1 1: aload 1
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
putfield org.jruby.internal.runtime.methods.MixedModeIRMethod.callCount:I
2: aload 1
aload 0
getfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
putfield org.jruby.internal.runtime.methods.MixedModeIRMethod.actualMethod:Lorg/jruby/internal/runtime/methods/DynamicMethod;
3: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
1 4 1 x Lorg/jruby/internal/runtime/methods/MixedModeIRMethod;
public void completeBuild(java.lang.Object);
descriptor: (Ljava/lang/Object;)V
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=2, locals=2, args_size=2
0: aload 0
aload 1
checkcast org.jruby.internal.runtime.methods.DynamicMethod
invokevirtual org.jruby.internal.runtime.methods.MixedModeIRMethod.completeBuild:(Lorg/jruby/internal/runtime/methods/DynamicMethod;)V
return
LocalVariableTable:
Start End Slot Name Signature
}
Signature: Lorg/jruby/internal/runtime/AbstractIRMethod;Lorg/jruby/compiler/Compilable<Lorg/jruby/internal/runtime/methods/DynamicMethod;>;
SourceFile: "MixedModeIRMethod.java"