class jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite extends jdk.nashorn.internal.runtime.linker.LinkerCallSite
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite
  super_class: jdk.nashorn.internal.runtime.linker.LinkerCallSite
{
  private static final java.lang.invoke.MethodHandles$Lookup LOOKUP;
    descriptor: Ljava/lang/invoke/MethodHandles$Lookup;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.invoke.MethodHandle TRACEOBJECT;
    descriptor: Ljava/lang/invoke/MethodHandle;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.invoke.MethodHandle TRACEVOID;
    descriptor: Ljava/lang/invoke/MethodHandle;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.invoke.MethodHandle TRACEMISS;
    descriptor: Ljava/lang/invoke/MethodHandle;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=10, locals=0, args_size=0
         0: .line 316
            invokestatic java.lang.invoke.MethodHandles.lookup:()Ljava/lang/invoke/MethodHandles$Lookup;
            putstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.LOOKUP:Ljava/lang/invoke/MethodHandles$Lookup;
         1: .line 318
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.LOOKUP:Ljava/lang/invoke/MethodHandles$Lookup;
            ldc Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            ldc "traceObject"
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            ldc Ljava/lang/Object;
            iconst_2
            anewarray java.lang.Class
            dup
            iconst_0
            ldc Ljava/lang/invoke/MethodHandle;
            aastore
            dup
            iconst_1
            ldc [Ljava/lang/Object;
            aastore
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.type:(Ljava/lang/Class;[Ljava/lang/Class;)Ljava/lang/invoke/MethodType;
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.findVirtual:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
            putstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEOBJECT:Ljava/lang/invoke/MethodHandle;
         2: .line 319
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.LOOKUP:Ljava/lang/invoke/MethodHandles$Lookup;
            ldc Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            ldc "traceVoid"
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic java.lang.Void.TYPE:Ljava/lang/Class;
            iconst_2
            anewarray java.lang.Class
            dup
            iconst_0
            ldc Ljava/lang/invoke/MethodHandle;
            aastore
            dup
            iconst_1
            ldc [Ljava/lang/Object;
            aastore
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.type:(Ljava/lang/Class;[Ljava/lang/Class;)Ljava/lang/invoke/MethodType;
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.findVirtual:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
            putstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEVOID:Ljava/lang/invoke/MethodHandle;
         3: .line 320
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.LOOKUP:Ljava/lang/invoke/MethodHandles$Lookup;
            ldc Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            ldc "traceMiss"
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic java.lang.Void.TYPE:Ljava/lang/Class;
            iconst_2
            anewarray java.lang.Class
            dup
            iconst_0
            ldc Ljava/lang/String;
            aastore
            dup
            iconst_1
            ldc [Ljava/lang/Object;
            aastore
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.type:(Ljava/lang/Class;[Ljava/lang/Class;)Ljava/lang/invoke/MethodType;
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.findVirtual:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/Class;Ljava/lang/String;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
            putstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEMISS:Ljava/lang/invoke/MethodHandle;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor);
    descriptor: (Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor desc
         0: .line 323
            aload 0 /* this */
            aload 1 /* desc */
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.<init>:(Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;)V
         1: .line 324
            return
        end local 1 // jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor desc
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    2     1  desc  Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;
    MethodParameters:
      Name  Flags
      desc  final

  public void setTarget(java.lang.invoke.MethodHandle);
    descriptor: (Ljava/lang/invoke/MethodHandle;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.invoke.MethodHandle newTarget
         0: .line 328
            aload 0 /* this */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getNashornDescriptor:()Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;
            invokevirtual jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor.isTraceEnterExit:()Z
            ifne 3
         1: .line 329
            aload 0 /* this */
            aload 1 /* newTarget */
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.setTarget:(Ljava/lang/invoke/MethodHandle;)V
         2: .line 330
            return
         3: .line 333
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.type:()Ljava/lang/invoke/MethodType;
            astore 2 /* type */
        start local 2 // java.lang.invoke.MethodType type
         4: .line 334
            aload 2 /* type */
            invokevirtual java.lang.invoke.MethodType.returnType:()Ljava/lang/Class;
            getstatic java.lang.Void.TYPE:Ljava/lang/Class;
            if_acmpne 5
            iconst_1
            goto 6
      StackMap locals: java.lang.invoke.MethodType
      StackMap stack:
         5: iconst_0
      StackMap locals:
      StackMap stack: int
         6: istore 3 /* isVoid */
        start local 3 // boolean isVoid
         7: .line 336
            iload 3 /* isVoid */
            ifeq 8
            getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEVOID:Ljava/lang/invoke/MethodHandle;
            goto 9
      StackMap locals: int
      StackMap stack:
         8: getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEOBJECT:Ljava/lang/invoke/MethodHandle;
      StackMap locals:
      StackMap stack: java.lang.invoke.MethodHandle
         9: astore 4 /* traceMethodHandle */
        start local 4 // java.lang.invoke.MethodHandle traceMethodHandle
        10: .line 337
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            aload 4 /* traceMethodHandle */
            aload 0 /* this */
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.bindTo:(Ljava/lang/invoke/MethodHandle;Ljava/lang/Object;)Ljava/lang/invoke/MethodHandle;
            astore 4 /* traceMethodHandle */
        11: .line 338
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            aload 4 /* traceMethodHandle */
            aload 1 /* newTarget */
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.bindTo:(Ljava/lang/invoke/MethodHandle;Ljava/lang/Object;)Ljava/lang/invoke/MethodHandle;
            astore 4 /* traceMethodHandle */
        12: .line 339
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            aload 4 /* traceMethodHandle */
            ldc [Ljava/lang/Object;
            aload 2 /* type */
            invokevirtual java.lang.invoke.MethodType.parameterCount:()I
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.asCollector:(Ljava/lang/invoke/MethodHandle;Ljava/lang/Class;I)Ljava/lang/invoke/MethodHandle;
            astore 4 /* traceMethodHandle */
        13: .line 340
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            aload 4 /* traceMethodHandle */
            aload 2 /* type */
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.asType:(Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
            astore 4 /* traceMethodHandle */
        14: .line 342
            aload 0 /* this */
            aload 4 /* traceMethodHandle */
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.setTarget:(Ljava/lang/invoke/MethodHandle;)V
        15: .line 343
            return
        end local 4 // java.lang.invoke.MethodHandle traceMethodHandle
        end local 3 // boolean isVoid
        end local 2 // java.lang.invoke.MethodType type
        end local 1 // java.lang.invoke.MethodHandle newTarget
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   16     0               this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0   16     1          newTarget  Ljava/lang/invoke/MethodHandle;
            4   16     2               type  Ljava/lang/invoke/MethodType;
            7   16     3             isVoid  Z
           10   16     4  traceMethodHandle  Ljava/lang/invoke/MethodHandle;
    MethodParameters:
           Name  Flags
      newTarget  final

  public void initialize(java.lang.invoke.MethodHandle);
    descriptor: (Ljava/lang/invoke/MethodHandle;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.invoke.MethodHandle relinkAndInvoke
         0: .line 347
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* relinkAndInvoke */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getFallbackLoggingRelink:(Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.initialize:(Ljava/lang/invoke/MethodHandle;)V
         1: .line 348
            return
        end local 1 // java.lang.invoke.MethodHandle relinkAndInvoke
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    2     0             this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    2     1  relinkAndInvoke  Ljava/lang/invoke/MethodHandle;
    MethodParameters:
                 Name  Flags
      relinkAndInvoke  final

  public void relink(jdk.dynalink.linker.GuardedInvocation, java.lang.invoke.MethodHandle);
    descriptor: (Ljdk/dynalink/linker/GuardedInvocation;Ljava/lang/invoke/MethodHandle;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // jdk.dynalink.linker.GuardedInvocation invocation
        start local 2 // java.lang.invoke.MethodHandle relink
         0: .line 352
            aload 0 /* this */
            aload 1 /* invocation */
            aload 0 /* this */
            aload 2 /* relink */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getFallbackLoggingRelink:(Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.relink:(Ljdk/dynalink/linker/GuardedInvocation;Ljava/lang/invoke/MethodHandle;)V
         1: .line 353
            return
        end local 2 // java.lang.invoke.MethodHandle relink
        end local 1 // jdk.dynalink.linker.GuardedInvocation invocation
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    2     1  invocation  Ljdk/dynalink/linker/GuardedInvocation;
            0    2     2      relink  Ljava/lang/invoke/MethodHandle;
    MethodParameters:
            Name  Flags
      invocation  final
      relink      final

  public void resetAndRelink(jdk.dynalink.linker.GuardedInvocation, java.lang.invoke.MethodHandle);
    descriptor: (Ljdk/dynalink/linker/GuardedInvocation;Ljava/lang/invoke/MethodHandle;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // jdk.dynalink.linker.GuardedInvocation invocation
        start local 2 // java.lang.invoke.MethodHandle relink
         0: .line 357
            aload 0 /* this */
            aload 1 /* invocation */
            aload 0 /* this */
            aload 2 /* relink */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getFallbackLoggingRelink:(Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;
            invokespecial jdk.nashorn.internal.runtime.linker.LinkerCallSite.resetAndRelink:(Ljdk/dynalink/linker/GuardedInvocation;Ljava/lang/invoke/MethodHandle;)V
         1: .line 358
            return
        end local 2 // java.lang.invoke.MethodHandle relink
        end local 1 // jdk.dynalink.linker.GuardedInvocation invocation
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    2     1  invocation  Ljdk/dynalink/linker/GuardedInvocation;
            0    2     2      relink  Ljava/lang/invoke/MethodHandle;
    MethodParameters:
            Name  Flags
      invocation  final
      relink      final

  private java.lang.invoke.MethodHandle getFallbackLoggingRelink(java.lang.invoke.MethodHandle);
    descriptor: (Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=13, locals=3, args_size=2
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.invoke.MethodHandle relink
         0: .line 361
            aload 0 /* this */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getNashornDescriptor:()Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;
            invokevirtual jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor.isTraceMisses:()Z
            ifne 2
         1: .line 363
            aload 1 /* relink */
            areturn
         2: .line 365
      StackMap locals:
      StackMap stack:
            aload 1 /* relink */
            invokevirtual java.lang.invoke.MethodHandle.type:()Ljava/lang/invoke/MethodType;
            astore 2 /* type */
        start local 2 // java.lang.invoke.MethodType type
         3: .line 366
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            aload 1 /* relink */
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.lookup.Lookup.MH:Ljdk/nashorn/internal/lookup/MethodHandleFunctionality;
            getstatic jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.TRACEMISS:Ljava/lang/invoke/MethodHandle;
            iconst_0
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            aastore
            dup
            iconst_1
            new java.lang.StringBuilder
            dup
            ldc "MISS "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            invokestatic jdk.nashorn.internal.runtime.linker.LinkerCallSite.getScriptLocation:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aastore
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.insertArguments:(Ljava/lang/invoke/MethodHandle;I[Ljava/lang/Object;)Ljava/lang/invoke/MethodHandle;
            ldc [Ljava/lang/Object;
            aload 2 /* type */
            invokevirtual java.lang.invoke.MethodType.parameterCount:()I
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.asCollector:(Ljava/lang/invoke/MethodHandle;Ljava/lang/Class;I)Ljava/lang/invoke/MethodHandle;
            aload 2 /* type */
            getstatic java.lang.Void.TYPE:Ljava/lang/Class;
            invokevirtual java.lang.invoke.MethodType.changeReturnType:(Ljava/lang/Class;)Ljava/lang/invoke/MethodType;
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.asType:(Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/MethodHandle;
            invokeinterface jdk.nashorn.internal.lookup.MethodHandleFunctionality.foldArguments:(Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;
            areturn
        end local 2 // java.lang.invoke.MethodType type
        end local 1 // java.lang.invoke.MethodHandle relink
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    4     1  relink  Ljava/lang/invoke/MethodHandle;
            3    4     2    type  Ljava/lang/invoke/MethodType;
    MethodParameters:
        Name  Flags
      relink  final

  private void printObject(java.io.PrintWriter, java.lang.Object);
    descriptor: (Ljava/io/PrintWriter;Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=9, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.io.PrintWriter out
        start local 2 // java.lang.Object arg
         0: .line 370
            aload 0 /* this */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getNashornDescriptor:()Ljdk/nashorn/internal/runtime/linker/NashornCallSiteDescriptor;
            invokevirtual jdk.nashorn.internal.runtime.linker.NashornCallSiteDescriptor.isTraceObjects:()Z
            ifne 5
         1: .line 371
            aload 1 /* out */
            aload 2 /* arg */
            instanceof jdk.nashorn.internal.runtime.ScriptObject
            ifeq 2
            ldc "ScriptObject"
            goto 3
      StackMap locals:
      StackMap stack: java.io.PrintWriter
         2: aload 2 /* arg */
      StackMap locals: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite java.io.PrintWriter java.lang.Object
      StackMap stack: java.io.PrintWriter java.lang.Object
         3: invokevirtual java.io.PrintWriter.print:(Ljava/lang/Object;)V
         4: .line 372
            return
         5: .line 375
      StackMap locals:
      StackMap stack:
            aload 2 /* arg */
            instanceof jdk.nashorn.internal.runtime.ScriptObject
            ifeq 28
         6: .line 376
            aload 2 /* arg */
            checkcast jdk.nashorn.internal.runtime.ScriptObject
            astore 3 /* object */
        start local 3 // jdk.nashorn.internal.runtime.ScriptObject object
         7: .line 378
            iconst_1
            istore 4 /* isFirst */
        start local 4 // boolean isFirst
         8: .line 379
            aload 3 /* object */
            invokevirtual jdk.nashorn.internal.runtime.ScriptObject.keySet:()Ljava/util/Set;
            astore 5 /* keySet */
        start local 5 // java.util.Set keySet
         9: .line 381
            aload 5 /* keySet */
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 12
        10: .line 382
            aload 1 /* out */
            aload 2 /* arg */
            invokestatic jdk.nashorn.internal.runtime.ScriptRuntime.safeToString:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        11: .line 383
            goto 29
        12: .line 384
      StackMap locals: jdk.nashorn.internal.runtime.ScriptObject int java.util.Set
      StackMap stack:
            aload 1 /* out */
            ldc "{ "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        13: .line 386
            aload 5 /* keySet */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 7
            goto 25
      StackMap locals: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite java.io.PrintWriter java.lang.Object jdk.nashorn.internal.runtime.ScriptObject int java.util.Set top java.util.Iterator
      StackMap stack:
        14: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            astore 6 /* key */
        start local 6 // java.lang.Object key
        15: .line 387
            iload 4 /* isFirst */
            ifne 17
        16: .line 388
            aload 1 /* out */
            ldc ", "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        17: .line 391
      StackMap locals: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite java.io.PrintWriter java.lang.Object jdk.nashorn.internal.runtime.ScriptObject int java.util.Set java.lang.Object java.util.Iterator
      StackMap stack:
            aload 1 /* out */
            aload 6 /* key */
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/Object;)V
        18: .line 392
            aload 1 /* out */
            ldc ":"
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        19: .line 394
            aload 3 /* object */
            aload 6 /* key */
            invokevirtual jdk.nashorn.internal.runtime.ScriptObject.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 8 /* value */
        start local 8 // java.lang.Object value
        20: .line 396
            aload 8 /* value */
            instanceof jdk.nashorn.internal.runtime.ScriptObject
            ifeq 23
        21: .line 397
            aload 1 /* out */
            ldc "..."
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        22: .line 398
            goto 24
        23: .line 399
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            aload 1 /* out */
            aload 8 /* value */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.printObject:(Ljava/io/PrintWriter;Ljava/lang/Object;)V
        24: .line 402
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 4 /* isFirst */
        end local 8 // java.lang.Object value
        end local 6 // java.lang.Object key
        25: .line 386
      StackMap locals: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite java.io.PrintWriter java.lang.Object jdk.nashorn.internal.runtime.ScriptObject int java.util.Set top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        26: .line 405
            aload 1 /* out */
            ldc " }"
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        end local 5 // java.util.Set keySet
        end local 4 // boolean isFirst
        end local 3 // jdk.nashorn.internal.runtime.ScriptObject object
        27: .line 407
            goto 29
        28: .line 408
      StackMap locals: jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite java.io.PrintWriter java.lang.Object
      StackMap stack:
            aload 1 /* out */
            aload 2 /* arg */
            invokestatic jdk.nashorn.internal.runtime.ScriptRuntime.safeToString:(Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        29: .line 410
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.lang.Object arg
        end local 1 // java.io.PrintWriter out
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   30     0     this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0   30     1      out  Ljava/io/PrintWriter;
            0   30     2      arg  Ljava/lang/Object;
            7   27     3   object  Ljdk/nashorn/internal/runtime/ScriptObject;
            8   27     4  isFirst  Z
            9   27     5   keySet  Ljava/util/Set<Ljava/lang/Object;>;
           15   25     6      key  Ljava/lang/Object;
           20   25     8    value  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      out   final
      arg   final

  private void tracePrint(java.io.PrintWriter, java.lang.String, java.lang.Object[], java.lang.Object);
    descriptor: (Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=5
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.io.PrintWriter out
        start local 2 // java.lang.String tag
        start local 3 // java.lang.Object[] args
        start local 4 // java.lang.Object result
         0: .line 414
            aload 1 /* out */
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            invokestatic jdk.nashorn.internal.runtime.Debug.id:(Ljava/lang/Object;)Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " TAG "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 2 /* tag */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
         1: .line 415
            aload 1 /* out */
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            aload 0 /* this */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.getDescriptor:()Ljdk/dynalink/CallSiteDescriptor;
            invokevirtual jdk.dynalink.CallSiteDescriptor.getOperation:()Ljdk/dynalink/Operation;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc "("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
         2: .line 417
            aload 3 /* args */
            arraylength
            ifle 14
         3: .line 418
            aload 0 /* this */
            aload 1 /* out */
            aload 3 /* args */
            iconst_0
            aaload
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.printObject:(Ljava/io/PrintWriter;Ljava/lang/Object;)V
         4: .line 419
            iconst_1
            istore 5 /* i */
        start local 5 // int i
         5: goto 13
         6: .line 420
      StackMap locals: int
      StackMap stack:
            aload 3 /* args */
            iload 5 /* i */
            aaload
            astore 6 /* arg */
        start local 6 // java.lang.Object arg
         7: .line 421
            aload 1 /* out */
            ldc ", "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
         8: .line 423
            aload 6 /* arg */
            instanceof jdk.nashorn.internal.runtime.ScriptObject
            ifeq 9
            aload 6 /* arg */
            checkcast jdk.nashorn.internal.runtime.ScriptObject
            invokevirtual jdk.nashorn.internal.runtime.ScriptObject.isScope:()Z
            ifne 11
         9: .line 424
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            aload 1 /* out */
            aload 6 /* arg */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.printObject:(Ljava/io/PrintWriter;Ljava/lang/Object;)V
        10: .line 425
            goto 12
        11: .line 426
      StackMap locals:
      StackMap stack:
            aload 1 /* out */
            ldc "SCOPE"
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        end local 6 // java.lang.Object arg
        12: .line 419
      StackMap locals:
      StackMap stack:
            iinc 5 /* i */ 1
      StackMap locals:
      StackMap stack:
        13: iload 5 /* i */
            aload 3 /* args */
            arraylength
            if_icmplt 6
        end local 5 // int i
        14: .line 431
      StackMap locals:
      StackMap stack:
            aload 1 /* out */
            ldc ")"
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        15: .line 433
            aload 2 /* tag */
            ldc "EXIT  "
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 18
        16: .line 434
            aload 1 /* out */
            ldc " --> "
            invokevirtual java.io.PrintWriter.print:(Ljava/lang/String;)V
        17: .line 435
            aload 0 /* this */
            aload 1 /* out */
            aload 4 /* result */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.printObject:(Ljava/io/PrintWriter;Ljava/lang/Object;)V
        18: .line 438
      StackMap locals:
      StackMap stack:
            aload 1 /* out */
            invokevirtual java.io.PrintWriter.println:()V
        19: .line 439
            return
        end local 4 // java.lang.Object result
        end local 3 // java.lang.Object[] args
        end local 2 // java.lang.String tag
        end local 1 // java.io.PrintWriter out
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   20     0    this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0   20     1     out  Ljava/io/PrintWriter;
            0   20     2     tag  Ljava/lang/String;
            0   20     3    args  [Ljava/lang/Object;
            0   20     4  result  Ljava/lang/Object;
            5   14     5       i  I
            7   12     6     arg  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      out     final
      tag     final
      args    final
      result  final

  public java.lang.Object traceObject(java.lang.invoke.MethodHandle, java.lang.Object[]);
    descriptor: (Ljava/lang/invoke/MethodHandle;[Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=5, locals=5, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.invoke.MethodHandle mh
        start local 2 // java.lang.Object[] args
         0: .line 453
            invokestatic jdk.nashorn.internal.runtime.Context.getCurrentErr:()Ljava/io/PrintWriter;
            astore 3 /* out */
        start local 3 // java.io.PrintWriter out
         1: .line 454
            aload 0 /* this */
            aload 3 /* out */
            ldc "ENTER "
            aload 2 /* args */
            aconst_null
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.tracePrint:(Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
         2: .line 455
            aload 1 /* mh */
            aload 2 /* args */
            invokevirtual java.lang.invoke.MethodHandle.invokeWithArguments:([Ljava/lang/Object;)Ljava/lang/Object;
            astore 4 /* result */
        start local 4 // java.lang.Object result
         3: .line 456
            aload 0 /* this */
            aload 3 /* out */
            ldc "EXIT  "
            aload 2 /* args */
            aload 4 /* result */
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.tracePrint:(Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
         4: .line 458
            aload 4 /* result */
            areturn
        end local 4 // java.lang.Object result
        end local 3 // java.io.PrintWriter out
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.invoke.MethodHandle mh
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    5     1      mh  Ljava/lang/invoke/MethodHandle;
            0    5     2    args  [Ljava/lang/Object;
            1    5     3     out  Ljava/io/PrintWriter;
            3    5     4  result  Ljava/lang/Object;
    Exceptions:
      throws java.lang.Throwable
    MethodParameters:
      Name  Flags
      mh    final
      args  final

  public void traceVoid(java.lang.invoke.MethodHandle, java.lang.Object[]);
    descriptor: (Ljava/lang/invoke/MethodHandle;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.invoke.MethodHandle mh
        start local 2 // java.lang.Object[] args
         0: .line 471
            invokestatic jdk.nashorn.internal.runtime.Context.getCurrentErr:()Ljava/io/PrintWriter;
            astore 3 /* out */
        start local 3 // java.io.PrintWriter out
         1: .line 472
            aload 0 /* this */
            aload 3 /* out */
            ldc "ENTER "
            aload 2 /* args */
            aconst_null
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.tracePrint:(Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
         2: .line 473
            aload 1 /* mh */
            aload 2 /* args */
            invokevirtual java.lang.invoke.MethodHandle.invokeWithArguments:([Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 474
            aload 0 /* this */
            aload 3 /* out */
            ldc "EXIT  "
            aload 2 /* args */
            aconst_null
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.tracePrint:(Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
         4: .line 475
            return
        end local 3 // java.io.PrintWriter out
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.invoke.MethodHandle mh
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    5     1    mh  Ljava/lang/invoke/MethodHandle;
            0    5     2  args  [Ljava/lang/Object;
            1    5     3   out  Ljava/io/PrintWriter;
    Exceptions:
      throws java.lang.Throwable
    MethodParameters:
      Name  Flags
      mh    final
      args  final

  public void traceMiss(java.lang.String, java.lang.Object[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=5, locals=3, args_size=3
        start local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
        start local 1 // java.lang.String desc
        start local 2 // java.lang.Object[] args
         0: .line 487
            aload 0 /* this */
            invokestatic jdk.nashorn.internal.runtime.Context.getCurrentErr:()Ljava/io/PrintWriter;
            aload 1 /* desc */
            aload 2 /* args */
            aconst_null
            invokevirtual jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite.tracePrint:(Ljava/io/PrintWriter;Ljava/lang/String;[Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 488
            return
        end local 2 // java.lang.Object[] args
        end local 1 // java.lang.String desc
        end local 0 // jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Ljdk/nashorn/internal/runtime/linker/LinkerCallSite$TracingLinkerCallSite;
            0    2     1  desc  Ljava/lang/String;
            0    2     2  args  [Ljava/lang/Object;
    Exceptions:
      throws java.lang.Throwable
    MethodParameters:
      Name  Flags
      desc  final
      args  final
}
SourceFile: "LinkerCallSite.java"
NestHost: jdk.nashorn.internal.runtime.linker.LinkerCallSite
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  private TracingLinkerCallSite = jdk.nashorn.internal.runtime.linker.LinkerCallSite$TracingLinkerCallSite of jdk.nashorn.internal.runtime.linker.LinkerCallSite