public class org.jruby.runtime.callsite.ProfilingCachingCallSite extends org.jruby.runtime.callsite.CachingCallSite
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.jruby.runtime.callsite.ProfilingCachingCallSite
  super_class: org.jruby.runtime.callsite.CachingCallSite
{
  public static final org.jruby.util.log.Logger LOG;
    descriptor: Lorg/jruby/util/log/Logger;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private volatile int totalMonomorphicCalls;
    descriptor: I
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final org.jruby.ir.IRScope hostScope;
    descriptor: Lorg/jruby/ir/IRScope;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final long callSiteId;
    descriptor: J
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 31
            ldc Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            invokestatic org.jruby.util.log.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/jruby/util/log/Logger;
            putstatic org.jruby.runtime.callsite.ProfilingCachingCallSite.LOG:Lorg/jruby/util/log/Logger;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(java.lang.String, org.jruby.ir.IRScope, long);
    descriptor: (Ljava/lang/String;Lorg/jruby/ir/IRScope;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // java.lang.String methodName
        start local 2 // org.jruby.ir.IRScope scope
        start local 3 // long callSiteId
         0: .line 37
            aload 0 /* this */
            aload 1 /* methodName */
            getstatic org.jruby.runtime.CallType.NORMAL:Lorg/jruby/runtime/CallType;
            invokespecial org.jruby.runtime.callsite.CachingCallSite.<init>:(Ljava/lang/String;Lorg/jruby/runtime/CallType;)V
         1: .line 32
            aload 0 /* this */
            iconst_0
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         2: .line 39
            aload 0 /* this */
            aload 2 /* scope */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
         3: .line 40
            aload 0 /* this */
            lload 3 /* callSiteId */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.callSiteId:J
         4: .line 41
            return
        end local 3 // long callSiteId
        end local 2 // org.jruby.ir.IRScope scope
        end local 1 // java.lang.String methodName
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    5     0        this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    5     1  methodName  Ljava/lang/String;
            0    5     2       scope  Lorg/jruby/ir/IRScope;
            0    5     3  callSiteId  J
    MethodParameters:
            Name  Flags
      methodName  
      scope       
      callSiteId  

  private void inlineCheck(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.callsite.CacheEntry);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=9, args_size=4
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject self
        start local 3 // org.jruby.runtime.callsite.CacheEntry cache
         0: .line 45
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            invokevirtual org.jruby.ir.IRScope.inliningAllowed:()Z
            ifne 1
            return
         1: .line 48
      StackMap locals:
      StackMap stack:
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            instanceof org.jruby.internal.runtime.AbstractIRMethod
            istore 4 /* targetIsIR */
        start local 4 // boolean targetIsIR
         2: .line 49
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            getfield org.jruby.ir.IRScope.compilable:Lorg/jruby/compiler/Compilable;
            ifnull 3
            iconst_1
            goto 4
      StackMap locals: int
      StackMap stack:
         3: iconst_0
      StackMap locals:
      StackMap stack: int
         4: istore 5 /* siteIsIR */
        start local 5 // boolean siteIsIR
         5: .line 52
            iload 4 /* targetIsIR */
            ifne 12
         6: .line 54
            aload 2 /* self */
            instanceof org.jruby.RubyFixnum
            ifeq 10
            ldc "times"
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 10
         7: .line 55
            iconst_1
            istore 4 /* targetIsIR */
         8: .line 56
            new org.jruby.internal.runtime.methods.MixedModeIRMethod
            dup
            aload 1 /* context */
            getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
            invokevirtual org.jruby.Ruby.getIRManager:()Lorg/jruby/ir/IRManager;
            aload 1 /* context */
            aload 2 /* self */
            ldc "times"
            invokevirtual org.jruby.ir.IRManager.loadInternalMethod:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Ljava/lang/String;)Lorg/jruby/ir/IRMethod;
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.getVisibility:()Lorg/jruby/runtime/Visibility;
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.getImplementationClass:()Lorg/jruby/RubyModule;
            invokespecial org.jruby.internal.runtime.methods.MixedModeIRMethod.<init>:(Lorg/jruby/ir/IRScope;Lorg/jruby/runtime/Visibility;Lorg/jruby/RubyModule;)V
            astore 6 /* targetMethod */
        start local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
         9: .line 57
            goto 13
        end local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
        10: .line 58
      StackMap locals: int
      StackMap stack:
            aconst_null
            astore 6 /* targetMethod */
        start local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
        11: .line 60
            goto 13
        end local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
        12: .line 61
      StackMap locals:
      StackMap stack:
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            checkcast org.jruby.internal.runtime.AbstractIRMethod
            astore 6 /* targetMethod */
        start local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
        13: .line 64
      StackMap locals: org.jruby.internal.runtime.AbstractIRMethod
      StackMap stack:
            iload 4 /* targetIsIR */
            ifeq 24
            iload 5 /* siteIsIR */
            ifeq 24
        14: .line 65
            aload 6 /* targetMethod */
            invokevirtual org.jruby.internal.runtime.AbstractIRMethod.getIRScope:()Lorg/jruby/ir/IRScope;
            checkcast org.jruby.ir.IRMethod
            astore 7 /* scopeToInline */
        start local 7 // org.jruby.ir.IRMethod scopeToInline
        15: .line 67
            getstatic org.jruby.ir.IRManager.IR_INLINER_VERBOSE:Z
            ifeq 16
            getstatic org.jruby.runtime.callsite.ProfilingCachingCallSite.LOG:Lorg/jruby/util/log/Logger;
            new java.lang.StringBuilder
            dup
            ldc "PROFILE: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " -> "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 7 /* scopeToInline */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " - "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            invokevirtual java.lang.StringBuilder.append:(I)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
        16: .line 69
      StackMap locals: org.jruby.ir.IRMethod
      StackMap stack:
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            getfield org.jruby.ir.IRScope.compilable:Lorg/jruby/compiler/Compilable;
            checkcast org.jruby.internal.runtime.AbstractIRMethod
            astore 8 /* hostMethod */
        start local 8 // org.jruby.internal.runtime.AbstractIRMethod hostMethod
        17: .line 70
            aload 8 /* hostMethod */
            instanceof org.jruby.internal.runtime.methods.InterpretedIRMethod
            ifeq 20
        18: .line 71
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            aload 7 /* scopeToInline */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.callSiteId:J
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.token:I
            iconst_0
            invokevirtual org.jruby.ir.IRScope.inlineMethod:(Lorg/jruby/ir/IRMethod;JIZ)V
        19: .line 72
            goto 24
      StackMap locals: org.jruby.internal.runtime.AbstractIRMethod
      StackMap stack:
        20: aload 8 /* hostMethod */
            instanceof org.jruby.internal.runtime.methods.MixedModeIRMethod
            ifeq 23
        21: .line 73
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            aload 7 /* scopeToInline */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.callSiteId:J
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.token:I
            iconst_0
            invokevirtual org.jruby.ir.IRScope.inlineMethodJIT:(Lorg/jruby/ir/IRMethod;JIZ)V
        22: .line 74
            goto 24
        23: .line 75
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.hostScope:Lorg/jruby/ir/IRScope;
            aload 7 /* scopeToInline */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.callSiteId:J
            aload 3 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.token:I
            iconst_0
            invokevirtual org.jruby.ir.IRScope.inlineMethodCompiled:(Lorg/jruby/ir/IRMethod;JIZ)V
        end local 8 // org.jruby.internal.runtime.AbstractIRMethod hostMethod
        end local 7 // org.jruby.ir.IRMethod scopeToInline
        24: .line 78
      StackMap locals:
      StackMap stack:
            return
        end local 6 // org.jruby.internal.runtime.AbstractIRMethod targetMethod
        end local 5 // boolean siteIsIR
        end local 4 // boolean targetIsIR
        end local 3 // org.jruby.runtime.callsite.CacheEntry cache
        end local 2 // org.jruby.runtime.builtin.IRubyObject self
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   25     0           this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0   25     1        context  Lorg/jruby/runtime/ThreadContext;
            0   25     2           self  Lorg/jruby/runtime/builtin/IRubyObject;
            0   25     3          cache  Lorg/jruby/runtime/callsite/CacheEntry;
            2   25     4     targetIsIR  Z
            5   25     5       siteIsIR  Z
            9   10     6   targetMethod  Lorg/jruby/internal/runtime/AbstractIRMethod;
           11   12     6   targetMethod  Lorg/jruby/internal/runtime/AbstractIRMethod;
           13   25     6   targetMethod  Lorg/jruby/internal/runtime/AbstractIRMethod;
           15   24     7  scopeToInline  Lorg/jruby/ir/IRMethod;
           17   24     8     hostMethod  Lorg/jruby/internal/runtime/AbstractIRMethod;
    MethodParameters:
         Name  Flags
      context  
      self     
      cache    

  protected boolean methodMissing(org.jruby.internal.runtime.methods.DynamicMethod, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.internal.runtime.methods.DynamicMethod method
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
         0: .line 81
            aload 1 /* method */
            invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.isUndefined:()Z
            ifne 2
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            ldc "method_missing"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 1
            aload 1 /* method */
            aload 2 /* caller */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.callType:Lorg/jruby/runtime/CallType;
            invokevirtual org.jruby.internal.runtime.methods.DynamicMethod.isCallableFrom:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/CallType;)Z
            ifeq 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         2: iconst_1
            ireturn
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    3     1  method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
            0    3     2  caller  Lorg/jruby/runtime/builtin/IRubyObject;
    MethodParameters:
        Name  Flags
      method  
      caller  

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, long);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;J)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // long fixnum
         0: .line 86
            aload 0 /* this */
            aload 1 /* context */
            aload 2 /* caller */
            aload 3 /* self */
            aload 1 /* context */
            getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
            lload 4 /* fixnum */
            invokestatic org.jruby.RubyFixnum.newFixnum:(Lorg/jruby/Ruby;J)Lorg/jruby/RubyFixnum;
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 4 // long fixnum
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    1     1  context  Lorg/jruby/runtime/ThreadContext;
            0    1     2   caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    1     3     self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    1     4   fixnum  J
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      fixnum   

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, double);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;D)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // double flote
         0: .line 91
            aload 0 /* this */
            aload 1 /* context */
            aload 2 /* caller */
            aload 3 /* self */
            aload 1 /* context */
            getfield org.jruby.runtime.ThreadContext.runtime:Lorg/jruby/Ruby;
            dload 4 /* flote */
            invokestatic org.jruby.RubyFloat.newFloat:(Lorg/jruby/Ruby;D)Lorg/jruby/RubyFloat;
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.call:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 4 // double flote
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0     this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    1     1  context  Lorg/jruby/runtime/ThreadContext;
            0    1     2   caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    1     3     self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    1     4    flote  D
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      flote    

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject[]);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;[Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject[] args
         0: .line 96
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 5 /* selfType */
        start local 5 // org.jruby.RubyClass selfType
         1: .line 97
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* cache */
        start local 6 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 99
            aload 6 /* cache */
            aload 5 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 100
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 101
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* args */
            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;
            areturn
         5: .line 103
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 104
            aload 0 /* this */
            aload 2 /* caller */
            aload 5 /* selfType */
            aload 4 /* args */
            aload 1 /* context */
            aload 3 /* self */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 6 // org.jruby.runtime.callsite.CacheEntry cache
        end local 5 // org.jruby.RubyClass selfType
        end local 4 // org.jruby.runtime.builtin.IRubyObject[] args
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      args  [Lorg/jruby/runtime/builtin/IRubyObject;
            1    7     5  selfType  Lorg/jruby/RubyClass;
            2    7     6     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      args     

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, 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/runtime/builtin/IRubyObject;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject[] args
        start local 5 // org.jruby.runtime.Block block
         0: .line 109
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 6 /* selfType */
        start local 6 // org.jruby.RubyClass selfType
         1: .line 110
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* cache */
        start local 7 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 112
            aload 7 /* cache */
            aload 6 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 113
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 114
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* args */
            aload 5 /* block */
            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: .line 116
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 117
            aload 0 /* this */
            aload 2 /* caller */
            aload 6 /* selfType */
            aload 5 /* block */
            aload 4 /* args */
            aload 1 /* context */
            aload 3 /* self */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 7 // org.jruby.runtime.callsite.CacheEntry cache
        end local 6 // org.jruby.RubyClass selfType
        end local 5 // org.jruby.runtime.Block block
        end local 4 // org.jruby.runtime.builtin.IRubyObject[] args
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      args  [Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5     block  Lorg/jruby/runtime/Block;
            1    7     6  selfType  Lorg/jruby/RubyClass;
            2    7     7     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      args     
      block    

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=4
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
         0: .line 123
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 4 /* selfType */
        start local 4 // org.jruby.RubyClass selfType
         1: .line 125
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 5 /* cache */
        start local 5 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 126
            aload 5 /* cache */
            aload 4 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 127
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 5 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 128
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 5 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 5 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            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;
            areturn
         5: .line 130
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 131
            aload 0 /* this */
            aload 2 /* caller */
            aload 4 /* selfType */
            aload 1 /* context */
            aload 3 /* self */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 5 // org.jruby.runtime.callsite.CacheEntry cache
        end local 4 // org.jruby.RubyClass selfType
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            1    7     4  selfType  Lorg/jruby/RubyClass;
            2    7     5     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, 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/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.Block block
         0: .line 136
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 5 /* selfType */
        start local 5 // org.jruby.RubyClass selfType
         1: .line 138
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* cache */
        start local 6 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 139
            aload 6 /* cache */
            aload 5 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 140
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 141
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* block */
            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: .line 143
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 144
            aload 0 /* this */
            aload 2 /* caller */
            aload 5 /* selfType */
            aload 4 /* block */
            aload 1 /* context */
            aload 3 /* self */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 6 // org.jruby.runtime.callsite.CacheEntry cache
        end local 5 // org.jruby.RubyClass selfType
        end local 4 // org.jruby.runtime.Block block
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4     block  Lorg/jruby/runtime/Block;
            1    7     5  selfType  Lorg/jruby/RubyClass;
            2    7     6     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      block    

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
         0: .line 150
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 5 /* selfType */
        start local 5 // org.jruby.RubyClass selfType
         1: .line 152
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* cache */
        start local 6 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 153
            aload 6 /* cache */
            aload 5 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 154
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 155
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 6 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            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;
            areturn
         5: .line 157
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 158
            aload 0 /* this */
            aload 2 /* caller */
            aload 5 /* selfType */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 6 // org.jruby.runtime.callsite.CacheEntry cache
        end local 5 // org.jruby.RubyClass selfType
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            1    7     5  selfType  Lorg/jruby/RubyClass;
            2    7     6     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, 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/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 5 // org.jruby.runtime.Block block
         0: .line 163
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 6 /* selfType */
        start local 6 // org.jruby.RubyClass selfType
         1: .line 165
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* cache */
        start local 7 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 166
            aload 7 /* cache */
            aload 6 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 167
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 168
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            aload 5 /* block */
            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: .line 170
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 171
            aload 0 /* this */
            aload 2 /* caller */
            aload 6 /* selfType */
            aload 5 /* block */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 7 // org.jruby.runtime.callsite.CacheEntry cache
        end local 6 // org.jruby.RubyClass selfType
        end local 5 // org.jruby.runtime.Block block
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5     block  Lorg/jruby/runtime/Block;
            1    7     6  selfType  Lorg/jruby/RubyClass;
            2    7     7     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     
      block    

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg2
         0: .line 177
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 6 /* selfType */
        start local 6 // org.jruby.RubyClass selfType
         1: .line 179
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* cache */
        start local 7 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 180
            aload 7 /* cache */
            aload 6 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 181
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 182
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 7 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            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;
            areturn
         5: .line 184
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 185
            aload 0 /* this */
            aload 2 /* caller */
            aload 6 /* selfType */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 7 // org.jruby.runtime.callsite.CacheEntry cache
        end local 6 // org.jruby.RubyClass selfType
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            1    7     6  selfType  Lorg/jruby/RubyClass;
            2    7     7     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     
      arg2     

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, 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/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=8, locals=9, args_size=7
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        start local 6 // org.jruby.runtime.Block block
         0: .line 190
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 7 /* selfType */
        start local 7 // org.jruby.RubyClass selfType
         1: .line 192
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 8 /* cache */
        start local 8 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 193
            aload 8 /* cache */
            aload 7 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 194
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 8 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 195
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 8 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 8 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            aload 6 /* block */
            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: .line 197
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 198
            aload 0 /* this */
            aload 2 /* caller */
            aload 7 /* selfType */
            aload 6 /* block */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 8 // org.jruby.runtime.callsite.CacheEntry cache
        end local 7 // org.jruby.RubyClass selfType
        end local 6 // org.jruby.runtime.Block block
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     6     block  Lorg/jruby/runtime/Block;
            1    7     7  selfType  Lorg/jruby/RubyClass;
            2    7     8     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     
      arg2     
      block    

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=9, args_size=7
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg3
         0: .line 204
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 7 /* selfType */
        start local 7 // org.jruby.RubyClass selfType
         1: .line 206
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 8 /* cache */
        start local 8 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 207
            aload 8 /* cache */
            aload 7 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 208
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 8 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 209
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 8 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 8 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            aload 6 /* arg3 */
            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/builtin/IRubyObject;
            areturn
         5: .line 211
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 212
            aload 0 /* this */
            aload 2 /* caller */
            aload 7 /* selfType */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            aload 6 /* arg3 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 8 // org.jruby.runtime.callsite.CacheEntry cache
        end local 7 // org.jruby.RubyClass selfType
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg3
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     6      arg3  Lorg/jruby/runtime/builtin/IRubyObject;
            1    7     7  selfType  Lorg/jruby/RubyClass;
            2    7     8     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     
      arg2     
      arg3     

  public org.jruby.runtime.builtin.IRubyObject call(org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, 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/runtime/builtin/IRubyObject;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=9, locals=10, args_size=8
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.ThreadContext context
        start local 2 // org.jruby.runtime.builtin.IRubyObject caller
        start local 3 // org.jruby.runtime.builtin.IRubyObject self
        start local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg3
        start local 7 // org.jruby.runtime.Block block
         0: .line 217
            aload 3 /* self */
            invokestatic org.jruby.runtime.callsite.ProfilingCachingCallSite.getClass:(Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/RubyClass;
            astore 8 /* selfType */
        start local 8 // org.jruby.RubyClass selfType
         1: .line 219
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
            astore 9 /* cache */
        start local 9 // org.jruby.runtime.callsite.CacheEntry cache
         2: .line 220
            aload 9 /* cache */
            aload 8 /* selfType */
            invokevirtual org.jruby.runtime.callsite.CacheEntry.typeOk:(Lorg/jruby/RubyClass;)Z
            ifeq 5
         3: .line 221
            aload 0 /* this */
            dup
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            dup_x1
            iconst_1
            iadd
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
            getstatic org.jruby.ir.IRManager.IR_INLINER_THRESHOLD:I
            irem
            ifne 4
            aload 0 /* this */
            aload 1 /* context */
            aload 3 /* self */
            aload 9 /* cache */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.inlineCheck:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/callsite/CacheEntry;)V
         4: .line 222
      StackMap locals: org.jruby.RubyClass org.jruby.runtime.callsite.CacheEntry
      StackMap stack:
            aload 9 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            aload 1 /* context */
            aload 3 /* self */
            aload 9 /* cache */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            aload 6 /* arg3 */
            aload 7 /* block */
            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: .line 224
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.totalMonomorphicCalls:I
         6: .line 225
            aload 0 /* this */
            aload 2 /* caller */
            aload 8 /* selfType */
            aload 7 /* block */
            aload 1 /* context */
            aload 3 /* self */
            aload 4 /* arg1 */
            aload 5 /* arg2 */
            aload 6 /* arg3 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.cacheAndCall:(Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
        end local 9 // org.jruby.runtime.callsite.CacheEntry cache
        end local 8 // org.jruby.RubyClass selfType
        end local 7 // org.jruby.runtime.Block block
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg3
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 4 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 3 // org.jruby.runtime.builtin.IRubyObject self
        end local 2 // org.jruby.runtime.builtin.IRubyObject caller
        end local 1 // org.jruby.runtime.ThreadContext context
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    7     1   context  Lorg/jruby/runtime/ThreadContext;
            0    7     2    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     3      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     4      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     5      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     6      arg3  Lorg/jruby/runtime/builtin/IRubyObject;
            0    7     7     block  Lorg/jruby/runtime/Block;
            1    7     8  selfType  Lorg/jruby/RubyClass;
            2    7     9     cache  Lorg/jruby/runtime/callsite/CacheEntry;
    MethodParameters:
         Name  Flags
      context  
      caller   
      self     
      arg1     
      arg2     
      arg3     
      block    

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.Block, org.jruby.runtime.builtin.IRubyObject[], org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=9, args_size=7
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.Block block
        start local 4 // org.jruby.runtime.builtin.IRubyObject[] args
        start local 5 // org.jruby.runtime.ThreadContext context
        start local 6 // org.jruby.runtime.builtin.IRubyObject self
         0: .line 231
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* entry */
        start local 7 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 232
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 8 /* method */
        start local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 233
            aload 0 /* this */
            aload 8 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 234
            aload 0 /* this */
            aload 5 /* context */
            aload 6 /* self */
            aload 2 /* selfType */
            aload 8 /* method */
            aload 4 /* args */
            aload 3 /* block */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 236
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 7 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 237
            aload 8 /* method */
            aload 5 /* context */
            aload 6 /* self */
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 4 /* args */
            aload 3 /* block */
            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
        end local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 7 // org.jruby.runtime.callsite.CacheEntry entry
        end local 6 // org.jruby.runtime.builtin.IRubyObject self
        end local 5 // org.jruby.runtime.ThreadContext context
        end local 4 // org.jruby.runtime.builtin.IRubyObject[] args
        end local 3 // org.jruby.runtime.Block block
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3     block  Lorg/jruby/runtime/Block;
            0    6     4      args  [Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     5   context  Lorg/jruby/runtime/ThreadContext;
            0    6     6      self  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     7     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     8    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      block     
      args      
      context   
      self      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.builtin.IRubyObject[], org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;[Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.builtin.IRubyObject[] args
        start local 4 // org.jruby.runtime.ThreadContext context
        start local 5 // org.jruby.runtime.builtin.IRubyObject self
         0: .line 243
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* entry */
        start local 6 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 244
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 7 /* method */
        start local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 245
            aload 0 /* this */
            aload 7 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 246
            aload 0 /* this */
            aload 4 /* context */
            aload 5 /* self */
            aload 2 /* selfType */
            aload 7 /* method */
            aload 3 /* args */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;[Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 248
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 6 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 249
            aload 7 /* method */
            aload 4 /* context */
            aload 5 /* self */
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 3 /* args */
            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;
            areturn
        end local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 6 // org.jruby.runtime.callsite.CacheEntry entry
        end local 5 // org.jruby.runtime.builtin.IRubyObject self
        end local 4 // org.jruby.runtime.ThreadContext context
        end local 3 // org.jruby.runtime.builtin.IRubyObject[] args
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3      args  [Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     4   context  Lorg/jruby/runtime/ThreadContext;
            0    6     5      self  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     6     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     7    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      args      
      context   
      self      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=7, args_size=5
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.ThreadContext context
        start local 4 // org.jruby.runtime.builtin.IRubyObject self
         0: .line 255
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 5 /* entry */
        start local 5 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 256
            aload 5 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 6 /* method */
        start local 6 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 257
            aload 0 /* this */
            aload 6 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 258
            aload 0 /* this */
            aload 3 /* context */
            aload 4 /* self */
            aload 2 /* selfType */
            aload 6 /* method */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 260
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 5 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 261
            aload 6 /* method */
            aload 3 /* context */
            aload 4 /* self */
            aload 5 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            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;
            areturn
        end local 6 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 5 // org.jruby.runtime.callsite.CacheEntry entry
        end local 4 // org.jruby.runtime.builtin.IRubyObject self
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3   context  Lorg/jruby/runtime/ThreadContext;
            0    6     4      self  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     5     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     6    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      context   
      self      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.Block, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.Block block
        start local 4 // org.jruby.runtime.ThreadContext context
        start local 5 // org.jruby.runtime.builtin.IRubyObject self
         0: .line 267
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* entry */
        start local 6 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 268
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 7 /* method */
        start local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 269
            aload 0 /* this */
            aload 7 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 270
            aload 0 /* this */
            aload 4 /* context */
            aload 5 /* self */
            aload 2 /* selfType */
            aload 7 /* method */
            aload 3 /* block */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 272
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 6 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 273
            aload 7 /* method */
            aload 4 /* context */
            aload 5 /* self */
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 3 /* block */
            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
        end local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 6 // org.jruby.runtime.callsite.CacheEntry entry
        end local 5 // org.jruby.runtime.builtin.IRubyObject self
        end local 4 // org.jruby.runtime.ThreadContext context
        end local 3 // org.jruby.runtime.Block block
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3     block  Lorg/jruby/runtime/Block;
            0    6     4   context  Lorg/jruby/runtime/ThreadContext;
            0    6     5      self  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     6     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     7    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      block     
      context   
      self      

  protected org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=6, locals=8, args_size=6
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.ThreadContext context
        start local 4 // org.jruby.runtime.builtin.IRubyObject self
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg
         0: .line 278
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 6 /* entry */
        start local 6 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 279
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 7 /* method */
        start local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 280
            aload 0 /* this */
            aload 7 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 281
            aload 0 /* this */
            aload 3 /* context */
            aload 4 /* self */
            aload 2 /* selfType */
            aload 7 /* method */
            aload 5 /* arg */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 283
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 6 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 284
            aload 7 /* method */
            aload 3 /* context */
            aload 4 /* self */
            aload 6 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 5 /* arg */
            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;
            areturn
        end local 7 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 6 // org.jruby.runtime.callsite.CacheEntry entry
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg
        end local 4 // org.jruby.runtime.builtin.IRubyObject self
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3   context  Lorg/jruby/runtime/ThreadContext;
            0    6     4      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     5       arg  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     6     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     7    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      context   
      self      
      arg       

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.Block, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=9, args_size=7
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.Block block
        start local 4 // org.jruby.runtime.ThreadContext context
        start local 5 // org.jruby.runtime.builtin.IRubyObject self
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg
         0: .line 290
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* entry */
        start local 7 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 291
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 8 /* method */
        start local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 292
            aload 0 /* this */
            aload 8 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 293
            aload 0 /* this */
            aload 4 /* context */
            aload 5 /* self */
            aload 2 /* selfType */
            aload 8 /* method */
            aload 6 /* arg */
            aload 3 /* block */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 295
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 7 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 296
            aload 8 /* method */
            aload 4 /* context */
            aload 5 /* self */
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 6 /* arg */
            aload 3 /* block */
            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
        end local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 7 // org.jruby.runtime.callsite.CacheEntry entry
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg
        end local 5 // org.jruby.runtime.builtin.IRubyObject self
        end local 4 // org.jruby.runtime.ThreadContext context
        end local 3 // org.jruby.runtime.Block block
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3     block  Lorg/jruby/runtime/Block;
            0    6     4   context  Lorg/jruby/runtime/ThreadContext;
            0    6     5      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     6       arg  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     7     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     8    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      block     
      context   
      self      
      arg       

  protected org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=7, locals=9, args_size=7
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.ThreadContext context
        start local 4 // org.jruby.runtime.builtin.IRubyObject self
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg2
         0: .line 301
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 7 /* entry */
        start local 7 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 302
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 8 /* method */
        start local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 303
            aload 0 /* this */
            aload 8 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 304
            aload 0 /* this */
            aload 3 /* context */
            aload 4 /* self */
            aload 2 /* selfType */
            aload 8 /* method */
            aload 5 /* arg1 */
            aload 6 /* arg2 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 306
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 7 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 307
            aload 8 /* method */
            aload 3 /* context */
            aload 4 /* self */
            aload 7 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 5 /* arg1 */
            aload 6 /* arg2 */
            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;
            areturn
        end local 8 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 7 // org.jruby.runtime.callsite.CacheEntry entry
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 4 // org.jruby.runtime.builtin.IRubyObject self
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3   context  Lorg/jruby/runtime/ThreadContext;
            0    6     4      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     5      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     6      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     7     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     8    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      context   
      self      
      arg1      
      arg2      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.Block, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=10, args_size=8
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.Block block
        start local 4 // org.jruby.runtime.ThreadContext context
        start local 5 // org.jruby.runtime.builtin.IRubyObject self
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 7 // org.jruby.runtime.builtin.IRubyObject arg2
         0: .line 313
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 8 /* entry */
        start local 8 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 314
            aload 8 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 9 /* method */
        start local 9 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 315
            aload 0 /* this */
            aload 9 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 316
            aload 0 /* this */
            aload 4 /* context */
            aload 5 /* self */
            aload 2 /* selfType */
            aload 9 /* method */
            aload 6 /* arg1 */
            aload 7 /* arg2 */
            aload 3 /* block */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/Block;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 318
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 8 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 319
            aload 9 /* method */
            aload 4 /* context */
            aload 5 /* self */
            aload 8 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 6 /* arg1 */
            aload 7 /* arg2 */
            aload 3 /* block */
            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
        end local 9 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 8 // org.jruby.runtime.callsite.CacheEntry entry
        end local 7 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 5 // org.jruby.runtime.builtin.IRubyObject self
        end local 4 // org.jruby.runtime.ThreadContext context
        end local 3 // org.jruby.runtime.Block block
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3     block  Lorg/jruby/runtime/Block;
            0    6     4   context  Lorg/jruby/runtime/ThreadContext;
            0    6     5      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     6      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     7      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     8     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     9    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      block     
      context   
      self      
      arg1      
      arg2      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=10, args_size=8
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.ThreadContext context
        start local 4 // org.jruby.runtime.builtin.IRubyObject self
        start local 5 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg2
        start local 7 // org.jruby.runtime.builtin.IRubyObject arg3
         0: .line 326
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 8 /* entry */
        start local 8 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 327
            aload 8 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 9 /* method */
        start local 9 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 328
            aload 0 /* this */
            aload 9 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 329
            aload 0 /* this */
            aload 3 /* context */
            aload 4 /* self */
            aload 2 /* selfType */
            aload 9 /* method */
            aload 5 /* arg1 */
            aload 6 /* arg2 */
            aload 7 /* arg3 */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
            areturn
         4: .line 331
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 8 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 332
            aload 9 /* method */
            aload 3 /* context */
            aload 4 /* self */
            aload 8 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 5 /* arg1 */
            aload 6 /* arg2 */
            aload 7 /* arg3 */
            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/builtin/IRubyObject;
            areturn
        end local 9 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 8 // org.jruby.runtime.callsite.CacheEntry entry
        end local 7 // org.jruby.runtime.builtin.IRubyObject arg3
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 5 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 4 // org.jruby.runtime.builtin.IRubyObject self
        end local 3 // org.jruby.runtime.ThreadContext context
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3   context  Lorg/jruby/runtime/ThreadContext;
            0    6     4      self  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     5      arg1  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     6      arg2  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     7      arg3  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     8     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6     9    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      context   
      self      
      arg1      
      arg2      
      arg3      

  private org.jruby.runtime.builtin.IRubyObject cacheAndCall(org.jruby.runtime.builtin.IRubyObject, org.jruby.RubyClass, org.jruby.runtime.Block, org.jruby.runtime.ThreadContext, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject, org.jruby.runtime.builtin.IRubyObject);
    descriptor: (Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/runtime/Block;Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/runtime/builtin/IRubyObject;)Lorg/jruby/runtime/builtin/IRubyObject;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=11, args_size=9
        start local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
        start local 1 // org.jruby.runtime.builtin.IRubyObject caller
        start local 2 // org.jruby.RubyClass selfType
        start local 3 // org.jruby.runtime.Block block
        start local 4 // org.jruby.runtime.ThreadContext context
        start local 5 // org.jruby.runtime.builtin.IRubyObject self
        start local 6 // org.jruby.runtime.builtin.IRubyObject arg1
        start local 7 // org.jruby.runtime.builtin.IRubyObject arg2
        start local 8 // org.jruby.runtime.builtin.IRubyObject arg3
         0: .line 339
            aload 2 /* selfType */
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            invokevirtual org.jruby.RubyClass.searchWithCache:(Ljava/lang/String;)Lorg/jruby/runtime/callsite/CacheEntry;
            astore 9 /* entry */
        start local 9 // org.jruby.runtime.callsite.CacheEntry entry
         1: .line 340
            aload 9 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.method:Lorg/jruby/internal/runtime/methods/DynamicMethod;
            astore 10 /* method */
        start local 10 // org.jruby.internal.runtime.methods.DynamicMethod method
         2: .line 341
            aload 0 /* this */
            aload 10 /* method */
            aload 1 /* caller */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.methodMissing:(Lorg/jruby/internal/runtime/methods/DynamicMethod;Lorg/jruby/runtime/builtin/IRubyObject;)Z
            ifeq 4
         3: .line 342
            aload 0 /* this */
            aload 4 /* context */
            aload 5 /* self */
            aload 2 /* selfType */
            aload 10 /* method */
            aload 6 /* arg1 */
            aload 7 /* arg2 */
            aload 8 /* arg3 */
            aload 3 /* block */
            invokevirtual org.jruby.runtime.callsite.ProfilingCachingCallSite.callMethodMissing:(Lorg/jruby/runtime/ThreadContext;Lorg/jruby/runtime/builtin/IRubyObject;Lorg/jruby/RubyClass;Lorg/jruby/internal/runtime/methods/DynamicMethod;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
         4: .line 344
      StackMap locals: org.jruby.runtime.callsite.CacheEntry org.jruby.internal.runtime.methods.DynamicMethod
      StackMap stack:
            aload 0 /* this */
            aload 9 /* entry */
            putfield org.jruby.runtime.callsite.ProfilingCachingCallSite.cache:Lorg/jruby/runtime/callsite/CacheEntry;
         5: .line 345
            aload 10 /* method */
            aload 4 /* context */
            aload 5 /* self */
            aload 9 /* entry */
            getfield org.jruby.runtime.callsite.CacheEntry.sourceModule:Lorg/jruby/RubyModule;
            aload 0 /* this */
            getfield org.jruby.runtime.callsite.ProfilingCachingCallSite.methodName:Ljava/lang/String;
            aload 6 /* arg1 */
            aload 7 /* arg2 */
            aload 8 /* arg3 */
            aload 3 /* block */
            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
        end local 10 // org.jruby.internal.runtime.methods.DynamicMethod method
        end local 9 // org.jruby.runtime.callsite.CacheEntry entry
        end local 8 // org.jruby.runtime.builtin.IRubyObject arg3
        end local 7 // org.jruby.runtime.builtin.IRubyObject arg2
        end local 6 // org.jruby.runtime.builtin.IRubyObject arg1
        end local 5 // org.jruby.runtime.builtin.IRubyObject self
        end local 4 // org.jruby.runtime.ThreadContext context
        end local 3 // org.jruby.runtime.Block block
        end local 2 // org.jruby.RubyClass selfType
        end local 1 // org.jruby.runtime.builtin.IRubyObject caller
        end local 0 // org.jruby.runtime.callsite.ProfilingCachingCallSite this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lorg/jruby/runtime/callsite/ProfilingCachingCallSite;
            0    6     1    caller  Lorg/jruby/runtime/builtin/IRubyObject;
            0    6     2  selfType  Lorg/jruby/RubyClass;
            0    6     3     block  Lorg/jruby/runtime/Block;
            0    6     4   context  Lorg/jruby/runtime/ThreadContext;
            0    6     5      self  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      arg3  Lorg/jruby/runtime/builtin/IRubyObject;
            1    6     9     entry  Lorg/jruby/runtime/callsite/CacheEntry;
            2    6    10    method  Lorg/jruby/internal/runtime/methods/DynamicMethod;
    MethodParameters:
          Name  Flags
      caller    
      selfType  
      block     
      context   
      self      
      arg1      
      arg2      
      arg3      
}
SourceFile: "ProfilingCachingCallSite.java"