class com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI extends com.oracle.truffle.tools.profiler.impl.ProfilerCLI
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI
  super_class: com.oracle.truffle.tools.profiler.impl.ProfilerCLI
{
  static final org.graalvm.options.OptionType<com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output> CLI_OUTPUT_TYPE;
    descriptor: Lorg/graalvm/options/OptionType;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionType<Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;>;

  static final org.graalvm.options.OptionType<com.oracle.truffle.tools.profiler.CPUSampler$Mode> CLI_MODE_TYPE;
    descriptor: Lorg/graalvm/options/OptionType;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionType<Lcom/oracle/truffle/tools/profiler/CPUSampler$Mode;>;

  static final org.graalvm.options.OptionKey<java.lang.Boolean> ENABLED;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Boolean;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "", help = "Enable the CPU sampler.", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<com.oracle.truffle.tools.profiler.CPUSampler$Mode> MODE;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Lcom/oracle/truffle/tools/profiler/CPUSampler$Mode;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "Mode", help = "Describe level of sampling detail. NOTE: Increased detail can lead to reduced accuracy. Modes: 'exclude_inlined_roots' - sample roots excluding inlined functions (default), 'roots' - sample roots including inlined functions, 'statements' - sample all statements.", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Long> SAMPLE_PERIOD;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Long;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "Period", help = "Period in milliseconds to sample the stack.", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Long> DELAY_PERIOD;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Long;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "Delay", help = "Delay the sampling for this many milliseconds (default: 0).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Integer> STACK_LIMIT;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Integer;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "StackLimit", help = "Maximum number of maximum stack elements.", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output> OUTPUT;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "Output", help = "Print a 'histogram', 'calltree' or 'json' as output (default:HISTOGRAM).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Object[]> FILTER_ROOT;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<[Ljava/lang/Object;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "FilterRootName", help = "Wildcard filter for program roots. (eg. Math.*, default:*).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Object[]> FILTER_FILE;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<[Ljava/lang/Object;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "FilterFile", help = "Wildcard filter for source file paths. (eg. *program*.sl, default:*).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.String> FILTER_MIME_TYPE;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/String;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "FilterMimeType", help = "Only profile languages with mime-type. (eg. +, default:no filter).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.String> FILTER_LANGUAGE;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/String;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "FilterLanguage", help = "Only profile languages with given ID. (eg. js, default:no filter).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Boolean> SAMPLE_INTERNAL;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Boolean;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "SampleInternal", help = "Capture internal elements (default:false).", category = org.graalvm.options.OptionCategory.INTERNAL:Lorg/graalvm/options/OptionCategory;)

  static final org.graalvm.options.OptionKey<java.lang.Boolean> SUMMARISE_THREADS;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Boolean;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "SummariseThreads", help = "Print output as a summary of all 'per thread' profiles. (default: false)", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Boolean> GATHER_HIT_TIMES;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Boolean;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "GatherHitTimes", help = "Save a timestamp for each taken sample (default:false).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.String> OUTPUT_FILE;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/String;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "OutputFile", help = "Save output to the given file. Output is printed to output stream by default.", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  static final org.graalvm.options.OptionKey<java.lang.Integer> MIN_SAMPLES;
    descriptor: Lorg/graalvm/options/OptionKey;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Lorg/graalvm/options/OptionKey<Ljava/lang/Integer;>;
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option(name = "MinSamples", help = "Remove elements from output if they have less samples than this value (default: 0).", category = org.graalvm.options.OptionCategory.USER:Lorg/graalvm/options/OptionCategory;, stability = org.graalvm.options.OptionStability.STABLE:Lorg/graalvm/options/OptionStability;)

  private static volatile int[] $SWITCH_TABLE$com$oracle$truffle$tools$profiler$impl$CPUSamplerCLI$Output;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=0, args_size=0
         0: .line 53
            ldc Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$assertionsDisabled:Z
         3: .line 61
            new org.graalvm.options.OptionType
            dup
            ldc "Output"
         4: .line 62
            new com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$1
            dup
            invokespecial com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$1.<init>:()V
         5: .line 61
            invokespecial org.graalvm.options.OptionType.<init>:(Ljava/lang/String;Ljava/util/function/Function;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.CLI_OUTPUT_TYPE:Lorg/graalvm/options/OptionType;
         6: .line 73
            new org.graalvm.options.OptionType
            dup
            ldc "Mode"
         7: .line 74
            new com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$2
            dup
            invokespecial com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$2.<init>:()V
         8: .line 73
            invokespecial org.graalvm.options.OptionType.<init>:(Ljava/lang/String;Ljava/util/function/Function;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.CLI_MODE_TYPE:Lorg/graalvm/options/OptionType;
         9: .line 86
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.ENABLED:Lorg/graalvm/options/OptionKey;
        10: .line 92
            new org.graalvm.options.OptionKey
            dup
            getstatic com.oracle.truffle.tools.profiler.CPUSampler$Mode.EXCLUDE_INLINED_ROOTS:Lcom/oracle/truffle/tools/profiler/CPUSampler$Mode;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.CLI_MODE_TYPE:Lorg/graalvm/options/OptionType;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;Lorg/graalvm/options/OptionType;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.MODE:Lorg/graalvm/options/OptionKey;
        11: .line 95
            new org.graalvm.options.OptionKey
            dup
            lconst_1
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.SAMPLE_PERIOD:Lorg/graalvm/options/OptionKey;
        12: .line 98
            new org.graalvm.options.OptionKey
            dup
            lconst_0
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.DELAY_PERIOD:Lorg/graalvm/options/OptionKey;
        13: .line 101
            new org.graalvm.options.OptionKey
            dup
            sipush 10000
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.STACK_LIMIT:Lorg/graalvm/options/OptionKey;
        14: .line 104
            new org.graalvm.options.OptionKey
            dup
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.HISTOGRAM:Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.CLI_OUTPUT_TYPE:Lorg/graalvm/options/OptionType;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;Lorg/graalvm/options/OptionType;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.OUTPUT:Lorg/graalvm/options/OptionKey;
        15: .line 107
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            anewarray java.lang.Object
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.WILDCARD_FILTER_TYPE:Lorg/graalvm/options/OptionType;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;Lorg/graalvm/options/OptionType;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.FILTER_ROOT:Lorg/graalvm/options/OptionKey;
        16: .line 110
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            anewarray java.lang.Object
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.WILDCARD_FILTER_TYPE:Lorg/graalvm/options/OptionType;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;Lorg/graalvm/options/OptionType;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.FILTER_FILE:Lorg/graalvm/options/OptionKey;
        17: .line 113
            new org.graalvm.options.OptionKey
            dup
            ldc ""
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.FILTER_MIME_TYPE:Lorg/graalvm/options/OptionKey;
        18: .line 116
            new org.graalvm.options.OptionKey
            dup
            ldc ""
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.FILTER_LANGUAGE:Lorg/graalvm/options/OptionKey;
        19: .line 119
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.SAMPLE_INTERNAL:Lorg/graalvm/options/OptionKey;
        20: .line 122
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.SUMMARISE_THREADS:Lorg/graalvm/options/OptionKey;
        21: .line 125
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.GATHER_HIT_TIMES:Lorg/graalvm/options/OptionKey;
        22: .line 128
            new org.graalvm.options.OptionKey
            dup
            ldc ""
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.OUTPUT_FILE:Lorg/graalvm/options/OptionKey;
        23: .line 131
            new org.graalvm.options.OptionKey
            dup
            iconst_0
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokespecial org.graalvm.options.OptionKey.<init>:(Ljava/lang/Object;)V
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.MIN_SAMPLES:Lorg/graalvm/options/OptionKey;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI this
         0: .line 53
            aload 0 /* this */
            invokespecial com.oracle.truffle.tools.profiler.impl.ProfilerCLI.<init>:()V
            return
        end local 0 // com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI;

  static void handleOutput(com.oracle.truffle.api.instrumentation.TruffleInstrument$Env, com.oracle.truffle.tools.profiler.CPUSampler);
    descriptor: (Lcom/oracle/truffle/api/instrumentation/TruffleInstrument$Env;Lcom/oracle/truffle/tools/profiler/CPUSampler;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=7, args_size=2
        start local 0 // com.oracle.truffle.api.instrumentation.TruffleInstrument$Env env
        start local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
         0: .line 134
            aconst_null
            astore 2
            aconst_null
            astore 3
         1: aload 0 /* env */
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.OUTPUT_FILE:Lorg/graalvm/options/OptionKey;
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.chooseOutputStream:(Lcom/oracle/truffle/api/instrumentation/TruffleInstrument$Env;Lorg/graalvm/options/OptionKey;)Ljava/io/PrintStream;
            astore 4 /* out */
        start local 4 // java.io.PrintStream out
         2: .line 135
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.hasStackOverflowed:()Z
            ifeq 10
         3: .line 136
            aload 4 /* out */
            ldc "-------------------------------------------------------------------------------- "
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         4: .line 137
            aload 4 /* out */
            new java.lang.StringBuilder
            dup
            ldc "ERROR: Shadow stack has overflowed its capacity of "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* env */
            invokevirtual com.oracle.truffle.api.instrumentation.TruffleInstrument$Env.getOptions:()Lorg/graalvm/options/OptionValues;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.STACK_LIMIT:Lorg/graalvm/options/OptionKey;
            invokeinterface org.graalvm.options.OptionValues.get:(Lorg/graalvm/options/OptionKey;)Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            ldc " during execution!"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         5: .line 138
            aload 4 /* out */
            ldc "The gathered data is incomplete and incorrect!"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 139
            aload 4 /* out */
            new java.lang.StringBuilder
            dup
            ldc "Use --cpusampler.StackLimit=<"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.STACK_LIMIT:Lorg/graalvm/options/OptionKey;
            invokevirtual org.graalvm.options.OptionKey.getType:()Lorg/graalvm/options/OptionType;
            invokevirtual org.graalvm.options.OptionType.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "> to set stack capacity."
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         7: .line 140
            aload 4 /* out */
            ldc "-------------------------------------------------------------------------------- "
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 155
            aload 4 /* out */
            ifnull 9
            aload 4 /* out */
            invokevirtual java.io.PrintStream.close:()V
         9: .line 141
      StackMap locals: java.lang.Throwable java.lang.Throwable java.io.PrintStream
      StackMap stack:
            return
        10: .line 143
      StackMap locals:
      StackMap stack:
            aload 0 /* env */
            invokevirtual com.oracle.truffle.api.instrumentation.TruffleInstrument$Env.getOptions:()Lorg/graalvm/options/OptionValues;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.SUMMARISE_THREADS:Lorg/graalvm/options/OptionKey;
            invokeinterface org.graalvm.options.OptionValues.get:(Lorg/graalvm/options/OptionKey;)Ljava/lang/Object;
            checkcast java.lang.Boolean
            astore 5 /* summariseThreads */
        start local 5 // java.lang.Boolean summariseThreads
        11: .line 144
            aload 0 /* env */
            invokevirtual com.oracle.truffle.api.instrumentation.TruffleInstrument$Env.getOptions:()Lorg/graalvm/options/OptionValues;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.MIN_SAMPLES:Lorg/graalvm/options/OptionKey;
            invokeinterface org.graalvm.options.OptionValues.get:(Lorg/graalvm/options/OptionKey;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 6 /* minSamples */
        start local 6 // java.lang.Integer minSamples
        12: .line 145
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$SWITCH_TABLE$com$oracle$truffle$tools$profiler$impl$CPUSamplerCLI$Output:()[I
            aload 0 /* env */
            invokevirtual com.oracle.truffle.api.instrumentation.TruffleInstrument$Env.getOptions:()Lorg/graalvm/options/OptionValues;
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.OUTPUT:Lorg/graalvm/options/OptionKey;
            invokeinterface org.graalvm.options.OptionValues.get:(Lorg/graalvm/options/OptionKey;)Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output
            invokevirtual com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.ordinal:()I
            iaload
            tableswitch { // 1 - 3
                    1: 13
                    2: 15
                    3: 17
              default: 18
          }
        13: .line 147
      StackMap locals: java.lang.Boolean java.lang.Integer
      StackMap stack:
            aload 4 /* out */
            aload 1 /* sampler */
            aload 5 /* summariseThreads */
            invokevirtual java.lang.Boolean.booleanValue:()Z
            aload 6 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printSamplingHistogram:(Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;ZLjava/lang/Integer;)V
        14: .line 148
            goto 18
        15: .line 150
      StackMap locals:
      StackMap stack:
            aload 4 /* out */
            aload 1 /* sampler */
            aload 5 /* summariseThreads */
            aload 6 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printSamplingCallTree:(Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/Boolean;Ljava/lang/Integer;)V
        16: .line 151
            goto 18
        17: .line 153
      StackMap locals:
      StackMap stack:
            aload 4 /* out */
            aload 1 /* sampler */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printSamplingJson:(Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;)V
        end local 6 // java.lang.Integer minSamples
        end local 5 // java.lang.Boolean summariseThreads
        18: .line 155
      StackMap locals:
      StackMap stack:
            aload 4 /* out */
            ifnull 24
            aload 4 /* out */
            invokevirtual java.io.PrintStream.close:()V
            goto 24
      StackMap locals:
      StackMap stack: java.lang.Throwable
        19: astore 2
            aload 4 /* out */
            ifnull 20
            aload 4 /* out */
            invokevirtual java.io.PrintStream.close:()V
        end local 4 // java.io.PrintStream out
      StackMap locals:
      StackMap stack:
        20: aload 2
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        21: astore 3
            aload 2
            ifnonnull 22
            aload 3
            astore 2
            goto 23
      StackMap locals:
      StackMap stack:
        22: aload 2
            aload 3
            if_acmpeq 23
            aload 2
            aload 3
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        23: aload 2
            athrow
        24: .line 156
      StackMap locals:
      StackMap stack:
            return
        end local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        end local 0 // com.oracle.truffle.api.instrumentation.TruffleInstrument$Env env
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   25     0               env  Lcom/oracle/truffle/api/instrumentation/TruffleInstrument$Env;
            0   25     1           sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            2   20     4               out  Ljava/io/PrintStream;
           11   18     5  summariseThreads  Ljava/lang/Boolean;
           12   18     6        minSamples  Ljava/lang/Integer;
      Exception table:
        from    to  target  type
           2     8      19  any
          10    18      19  any
           1     9      21  any
          10    21      21  any
    MethodParameters:
         Name  Flags
      env      
      sampler  

  private static void printSamplingJson(java.io.PrintStream, com.oracle.truffle.tools.profiler.CPUSampler);
    descriptor: (Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=8, args_size=2
        start local 0 // java.io.PrintStream out
        start local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
         0: .line 159
            new com.oracle.truffle.tools.utils.json.JSONObject
            dup
            invokespecial com.oracle.truffle.tools.utils.json.JSONObject.<init>:()V
            astore 2 /* output */
        start local 2 // com.oracle.truffle.tools.utils.json.JSONObject output
         1: .line 160
            aload 2 /* output */
            ldc "tool"
            ldc "cpusampler"
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         2: .line 161
            aload 2 /* output */
            ldc "version"
            ldc "0.4.0"
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         3: .line 162
            aload 2 /* output */
            ldc "sample_count"
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getSampleCount:()J
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;J)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         4: .line 163
            aload 2 /* output */
            ldc "period"
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getPeriod:()J
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;J)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         5: .line 164
            aload 2 /* output */
            ldc "gathered_hit_times"
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.isGatherSelfHitTimes:()Z
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Z)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         6: .line 165
            new com.oracle.truffle.tools.utils.json.JSONArray
            dup
            invokespecial com.oracle.truffle.tools.utils.json.JSONArray.<init>:()V
            astore 3 /* profile */
        start local 3 // com.oracle.truffle.tools.utils.json.JSONArray profile
         7: .line 166
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getThreadToNodesMap:()Ljava/util/Map;
            astore 4 /* threadToNodesMap */
        start local 4 // java.util.Map threadToNodesMap
         8: .line 167
            aload 4 /* threadToNodesMap */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 14
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler com.oracle.truffle.tools.utils.json.JSONObject com.oracle.truffle.tools.utils.json.JSONArray java.util.Map top java.util.Iterator
      StackMap stack:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 5 /* entry */
        start local 5 // java.util.Map$Entry entry
        10: .line 168
            new com.oracle.truffle.tools.utils.json.JSONObject
            dup
            invokespecial com.oracle.truffle.tools.utils.json.JSONObject.<init>:()V
            astore 7 /* perThreadProfile */
        start local 7 // com.oracle.truffle.tools.utils.json.JSONObject perThreadProfile
        11: .line 169
            aload 7 /* perThreadProfile */
            ldc "thread"
            aload 5 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Thread
            invokevirtual java.lang.Thread.toString:()Ljava/lang/String;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        12: .line 170
            aload 7 /* perThreadProfile */
            ldc "samples"
            aload 5 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Collection
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getSamplesRec:(Ljava/util/Collection;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        13: .line 171
            aload 3 /* profile */
            aload 7 /* perThreadProfile */
            invokevirtual com.oracle.truffle.tools.utils.json.JSONArray.put:(Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
            pop
        end local 7 // com.oracle.truffle.tools.utils.json.JSONObject perThreadProfile
        end local 5 // java.util.Map$Entry entry
        14: .line 167
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        15: .line 173
            aload 2 /* output */
            ldc "profile"
            aload 3 /* profile */
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        16: .line 174
            aload 0 /* out */
            aload 2 /* output */
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        17: .line 175
            return
        end local 4 // java.util.Map threadToNodesMap
        end local 3 // com.oracle.truffle.tools.utils.json.JSONArray profile
        end local 2 // com.oracle.truffle.tools.utils.json.JSONObject output
        end local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        end local 0 // java.io.PrintStream out
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   18     0               out  Ljava/io/PrintStream;
            0   18     1           sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            1   18     2            output  Lcom/oracle/truffle/tools/utils/json/JSONObject;
            7   18     3           profile  Lcom/oracle/truffle/tools/utils/json/JSONArray;
            8   18     4  threadToNodesMap  Ljava/util/Map<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
           10   14     5             entry  Ljava/util/Map$Entry<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
           11   14     7  perThreadProfile  Lcom/oracle/truffle/tools/utils/json/JSONObject;
    MethodParameters:
         Name  Flags
      out      
      sampler  

  private static com.oracle.truffle.tools.utils.json.JSONArray getSamplesRec(java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>);
    descriptor: (Ljava/util/Collection;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=6, args_size=1
        start local 0 // java.util.Collection nodes
         0: .line 178
            new com.oracle.truffle.tools.utils.json.JSONArray
            dup
            invokespecial com.oracle.truffle.tools.utils.json.JSONArray.<init>:()V
            astore 1 /* samples */
        start local 1 // com.oracle.truffle.tools.utils.json.JSONArray samples
         1: .line 179
            aload 0 /* nodes */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 16
      StackMap locals: java.util.Collection com.oracle.truffle.tools.utils.json.JSONArray top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 2 /* node */
        start local 2 // com.oracle.truffle.tools.profiler.ProfilerNode node
         3: .line 180
            new com.oracle.truffle.tools.utils.json.JSONObject
            dup
            invokespecial com.oracle.truffle.tools.utils.json.JSONObject.<init>:()V
            astore 4 /* sample */
        start local 4 // com.oracle.truffle.tools.utils.json.JSONObject sample
         4: .line 181
            aload 4 /* sample */
            ldc "root_name"
            aload 2 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         5: .line 182
            aload 4 /* sample */
            ldc "source_section"
            aload 2 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.sourceSectionToJSON:(Lcom/oracle/truffle/api/source/SourceSection;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         6: .line 183
            aload 2 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getPayload:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.CPUSampler$Payload
            astore 5 /* payload */
        start local 5 // com.oracle.truffle.tools.profiler.CPUSampler$Payload payload
         7: .line 184
            aload 4 /* sample */
            ldc "hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         8: .line 185
            aload 4 /* sample */
            ldc "interpreted_hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getInterpretedHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
         9: .line 186
            aload 4 /* sample */
            ldc "compiled_hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getCompiledHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        10: .line 187
            aload 4 /* sample */
            ldc "self_hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        11: .line 188
            aload 4 /* sample */
            ldc "self_interpreted_hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfInterpretedHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        12: .line 189
            aload 4 /* sample */
            ldc "self_compiled_hit_count"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfCompiledHitCount:()I
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;I)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        13: .line 190
            aload 4 /* sample */
            ldc "self_hit_times"
            aload 5 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfHitTimes:()Ljava/util/List;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/util/Collection;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        14: .line 191
            aload 4 /* sample */
            ldc "children"
            aload 2 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getSamplesRec:(Ljava/util/Collection;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
            invokevirtual com.oracle.truffle.tools.utils.json.JSONObject.put:(Ljava/lang/String;Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONObject;
            pop
        15: .line 192
            aload 1 /* samples */
            aload 4 /* sample */
            invokevirtual com.oracle.truffle.tools.utils.json.JSONArray.put:(Ljava/lang/Object;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
            pop
        end local 5 // com.oracle.truffle.tools.profiler.CPUSampler$Payload payload
        end local 4 // com.oracle.truffle.tools.utils.json.JSONObject sample
        end local 2 // com.oracle.truffle.tools.profiler.ProfilerNode node
        16: .line 179
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        17: .line 194
            aload 1 /* samples */
            areturn
        end local 1 // com.oracle.truffle.tools.utils.json.JSONArray samples
        end local 0 // java.util.Collection nodes
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   18     0    nodes  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            1   18     1  samples  Lcom/oracle/truffle/tools/utils/json/JSONArray;
            3   16     2     node  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            4   16     4   sample  Lcom/oracle/truffle/tools/utils/json/JSONObject;
            7   16     5  payload  Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;
    Signature: (Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;)Lcom/oracle/truffle/tools/utils/json/JSONArray;
    MethodParameters:
       Name  Flags
      nodes  

  private static java.util.Map<com.oracle.truffle.tools.profiler.impl.ProfilerCLI$SourceLocation, java.util.List<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>> computeHistogram(java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>);
    descriptor: (Ljava/util/Collection;)Ljava/util/Map;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // java.util.Collection profilerNodes
         0: .line 198
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 1 /* histogram */
        start local 1 // java.util.Map histogram
         1: .line 199
            aload 0 /* profilerNodes */
            aload 1 /* histogram */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeHistogramImpl:(Ljava/util/Collection;Ljava/util/Map;)V
         2: .line 200
            aload 1 /* histogram */
            areturn
        end local 1 // java.util.Map histogram
        end local 0 // java.util.Collection profilerNodes
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0  profilerNodes  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            1    3     1      histogram  Ljava/util/Map<Lcom/oracle/truffle/tools/profiler/impl/ProfilerCLI$SourceLocation;Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
    Signature: (Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;)Ljava/util/Map<Lcom/oracle/truffle/tools/profiler/impl/ProfilerCLI$SourceLocation;Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
    MethodParameters:
               Name  Flags
      profilerNodes  

  private static void computeHistogramImpl(java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>, java.util.Map<com.oracle.truffle.tools.profiler.impl.ProfilerCLI$SourceLocation, java.util.List<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>>);
    descriptor: (Ljava/util/Collection;Ljava/util/Map;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // java.util.Collection children
        start local 1 // java.util.Map histogram
         0: .line 204
            aload 0 /* children */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: java.util.Collection java.util.Map top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 2 /* treeNode */
        start local 2 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         2: .line 205
            aload 1 /* histogram */
            new com.oracle.truffle.tools.profiler.impl.ProfilerCLI$SourceLocation
            dup
            aload 2 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            aload 2 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            invokespecial com.oracle.truffle.tools.profiler.impl.ProfilerCLI$SourceLocation.<init>:(Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;)V
         3: .line 206
            new com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$3
            dup
            invokespecial com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$3.<init>:()V
         4: .line 205
            invokeinterface java.util.Map.computeIfAbsent:(Ljava/lang/Object;Ljava/util/function/Function;)Ljava/lang/Object;
            checkcast java.util.List
            astore 4 /* nodes */
        start local 4 // java.util.List nodes
         5: .line 212
            aload 4 /* nodes */
            aload 2 /* treeNode */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         6: .line 213
            aload 2 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            aload 1 /* histogram */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeHistogramImpl:(Ljava/util/Collection;Ljava/util/Map;)V
        end local 4 // java.util.List nodes
        end local 2 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         7: .line 204
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         8: .line 215
            return
        end local 1 // java.util.Map histogram
        end local 0 // java.util.Collection children
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0   children  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            0    9     1  histogram  Ljava/util/Map<Lcom/oracle/truffle/tools/profiler/impl/ProfilerCLI$SourceLocation;Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
            2    7     2   treeNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            5    7     4      nodes  Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
    Signature: (Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;Ljava/util/Map<Lcom/oracle/truffle/tools/profiler/impl/ProfilerCLI$SourceLocation;Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;)V
    MethodParameters:
           Name  Flags
      children   
      histogram  

  private static void printSamplingHistogram(java.io.PrintStream, com.oracle.truffle.tools.profiler.CPUSampler, boolean, java.lang.Integer);
    descriptor: (Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;ZLjava/lang/Integer;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=15, args_size=4
        start local 0 // java.io.PrintStream out
        start local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        start local 2 // boolean summariseThreads
        start local 3 // java.lang.Integer minSamples
         0: .line 218
            bipush 10
            istore 4 /* maxLength */
        start local 4 // int maxLength
         1: .line 219
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            astore 5 /* linesPerThread */
        start local 5 // java.util.Map linesPerThread
         2: .line 220
            iload 2 /* summariseThreads */
            ifeq 3
            aload 1 /* sampler */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.makeOneEntryMap:(Lcom/oracle/truffle/tools/profiler/CPUSampler;)Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            goto 4
      StackMap locals: int java.util.Map
      StackMap stack:
         3: aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getThreadToNodesMap:()Ljava/util/Map;
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
      StackMap locals:
      StackMap stack: java.util.Set
         4: astore 6 /* entrySet */
        start local 6 // java.util.Set entrySet
         5: .line 221
            aload 6 /* entrySet */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 8
            goto 14
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set top java.util.Iterator
      StackMap stack:
         6: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 7 /* node */
        start local 7 // java.util.Map$Entry node
         7: .line 222
            new java.util.ArrayList
            dup
            aload 7 /* node */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Collection
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeHistogram:(Ljava/util/Collection;)Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            astore 9 /* lines */
        start local 9 // java.util.List lines
         8: .line 223
            aload 9 /* lines */
            new com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$4
            dup
            invokespecial com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$4.<init>:()V
            invokestatic java.util.Collections.sort:(Ljava/util/List;Ljava/util/Comparator;)V
         9: .line 239
            aload 9 /* lines */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 11
            goto 12
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set java.util.Map$Entry java.util.Iterator java.util.List top java.util.Iterator
      StackMap stack:
        10: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.List
            astore 10 /* line */
        start local 10 // java.util.List line
        11: .line 240
            aload 10 /* line */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeRootNameMaxLength:(Lcom/oracle/truffle/tools/profiler/ProfilerNode;)I
            iload 4 /* maxLength */
            invokestatic java.lang.Math.max:(II)I
            istore 4 /* maxLength */
        end local 10 // java.util.List line
        12: .line 239
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        13: .line 242
            aload 5 /* linesPerThread */
            aload 7 /* node */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Thread
            aload 9 /* lines */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 9 // java.util.List lines
        end local 7 // java.util.Map$Entry node
        14: .line 221
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        15: .line 245
            new java.lang.StringBuilder
            dup
            ldc " %-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 4 /* maxLength */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "s |      Total Time     |  Opt %% ||       Self Time     |  Opt %% | Location             "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            ldc "Name"
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 7 /* title */
        start local 7 // java.lang.String title
        16: .line 246
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getSampleCount:()J
            lstore 8 /* samples */
        start local 8 // long samples
        17: .line 247
            ldc "-"
            aload 7 /* title */
            invokevirtual java.lang.String.length:()I
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.repeat:(Ljava/lang/String;I)Ljava/lang/String;
            astore 10 /* sep */
        start local 10 // java.lang.String sep
        18: .line 248
            aload 0 /* out */
            aload 10 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        19: .line 249
            aload 0 /* out */
            ldc "Histogram"
            lload 8 /* samples */
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getPeriod:()J
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printLegend:(Ljava/io/PrintStream;Ljava/lang/String;JJ)V
        20: .line 250
            aload 0 /* out */
            aload 10 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        21: .line 251
            aload 5 /* linesPerThread */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 12
            goto 32
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set java.lang.String long java.lang.String top java.util.Iterator
      StackMap stack:
        22: aload 12
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 11 /* entry */
        start local 11 // java.util.Map$Entry entry
        23: .line 252
            iload 2 /* summariseThreads */
            ifne 25
        24: .line 253
            aload 0 /* out */
            new java.lang.StringBuilder
            dup
            ldc " Thread: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 11 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        25: .line 255
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set java.lang.String long java.lang.String java.util.Map$Entry java.util.Iterator
      StackMap stack:
            aload 0 /* out */
            aload 7 /* title */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        26: .line 256
            aload 0 /* out */
            aload 10 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        27: .line 257
            aload 11 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.List
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 14
            goto 30
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set java.lang.String long java.lang.String java.util.Map$Entry java.util.Iterator top java.util.Iterator
      StackMap stack:
        28: aload 14
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.List
            astore 13 /* line */
        start local 13 // java.util.List line
        29: .line 258
            aload 0 /* out */
            aload 1 /* sampler */
            ldc ""
            aload 13 /* line */
            iload 4 /* maxLength */
            iconst_0
            aload 3 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printAttributes:(Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/String;Ljava/util/List;IZLjava/lang/Integer;)Z
            pop
        end local 13 // java.util.List line
        30: .line 257
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 28
        31: .line 260
            aload 0 /* out */
            aload 10 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 11 // java.util.Map$Entry entry
        32: .line 251
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler int java.lang.Integer int java.util.Map java.util.Set java.lang.String long java.lang.String top java.util.Iterator
      StackMap stack:
            aload 12
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 22
        33: .line 262
            return
        end local 10 // java.lang.String sep
        end local 8 // long samples
        end local 7 // java.lang.String title
        end local 6 // java.util.Set entrySet
        end local 5 // java.util.Map linesPerThread
        end local 4 // int maxLength
        end local 3 // java.lang.Integer minSamples
        end local 2 // boolean summariseThreads
        end local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        end local 0 // java.io.PrintStream out
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   34     0               out  Ljava/io/PrintStream;
            0   34     1           sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            0   34     2  summariseThreads  Z
            0   34     3        minSamples  Ljava/lang/Integer;
            1   34     4         maxLength  I
            2   34     5    linesPerThread  Ljava/util/Map<Ljava/lang/Thread;Ljava/util/List<Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;>;
            5   34     6          entrySet  Ljava/util/Set<Ljava/util/Map$Entry<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;>;
            7   14     7              node  Ljava/util/Map$Entry<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
            8   14     9             lines  Ljava/util/List<Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
           11   12    10              line  Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
           16   34     7             title  Ljava/lang/String;
           17   34     8           samples  J
           18   34    10               sep  Ljava/lang/String;
           23   32    11             entry  Ljava/util/Map$Entry<Ljava/lang/Thread;Ljava/util/List<Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;>;
           29   30    13              line  Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
    MethodParameters:
                  Name  Flags
      out               
      sampler           
      summariseThreads  
      minSamples        

  private static java.util.Map<java.lang.Thread, java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>> makeOneEntryMap(com.oracle.truffle.tools.profiler.CPUSampler);
    descriptor: (Lcom/oracle/truffle/tools/profiler/CPUSampler;)Ljava/util/Map;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // com.oracle.truffle.tools.profiler.CPUSampler sampler
         0: .line 265
            new java.util.HashMap
            dup
            iconst_1
            invokespecial java.util.HashMap.<init>:(I)V
            astore 1 /* oneElementMap */
        start local 1 // java.util.Map oneElementMap
         1: .line 266
            aload 1 /* oneElementMap */
            new java.lang.Thread
            dup
            ldc "Summary"
            invokespecial java.lang.Thread.<init>:(Ljava/lang/String;)V
            aload 0 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getRootNodes:()Ljava/util/Collection;
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 267
            aload 1 /* oneElementMap */
            areturn
        end local 1 // java.util.Map oneElementMap
        end local 0 // com.oracle.truffle.tools.profiler.CPUSampler sampler
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0        sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            1    3     1  oneElementMap  Ljava/util/Map<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
    Signature: (Lcom/oracle/truffle/tools/profiler/CPUSampler;)Ljava/util/Map<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
    MethodParameters:
         Name  Flags
      sampler  

  private static void printSamplingCallTree(java.io.PrintStream, com.oracle.truffle.tools.profiler.CPUSampler, java.lang.Boolean, java.lang.Integer);
    descriptor: (Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/Boolean;Ljava/lang/Integer;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=11, args_size=4
        start local 0 // java.io.PrintStream out
        start local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        start local 2 // java.lang.Boolean summariseThreads
        start local 3 // java.lang.Integer minSamples
         0: .line 271
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 4 /* actualRoots */
        start local 4 // java.util.Collection actualRoots
         1: .line 272
            aload 2 /* summariseThreads */
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifeq 2
            aload 1 /* sampler */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.makeOneEntryMap:(Lcom/oracle/truffle/tools/profiler/CPUSampler;)Ljava/util/Map;
            goto 3
      StackMap locals: java.util.Collection
      StackMap stack:
         2: aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getThreadToNodesMap:()Ljava/util/Map;
      StackMap locals:
      StackMap stack: java.util.Map
         3: astore 5 /* threadToNodesMap */
        start local 5 // java.util.Map threadToNodesMap
         4: .line 273
            aload 5 /* threadToNodesMap */
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 7
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.Boolean java.lang.Integer java.util.Collection java.util.Map top java.util.Iterator
      StackMap stack:
         5: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Collection
            astore 6 /* node */
        start local 6 // java.util.Collection node
         6: .line 274
            aload 4 /* actualRoots */
            aload 6 /* node */
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
        end local 6 // java.util.Collection node
         7: .line 273
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 276
            bipush 10
            aload 4 /* actualRoots */
            iconst_0
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeTitleMaxLength:(Ljava/util/Collection;I)I
            invokestatic java.lang.Math.max:(II)I
            istore 6 /* maxLength */
        start local 6 // int maxLength
         9: .line 277
            new java.lang.StringBuilder
            dup
            ldc " %-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 6 /* maxLength */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "s |      Total Time     |  Opt %% ||       Self Time     |  Opt %% | Location             "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            ldc "Name"
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 7 /* title */
        start local 7 // java.lang.String title
        10: .line 278
            ldc "-"
            aload 7 /* title */
            invokevirtual java.lang.String.length:()I
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.repeat:(Ljava/lang/String;I)Ljava/lang/String;
            astore 8 /* sep */
        start local 8 // java.lang.String sep
        11: .line 279
            aload 0 /* out */
            aload 8 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        12: .line 280
            aload 0 /* out */
            ldc "CallTree"
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getSampleCount:()J
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getPeriod:()J
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printLegend:(Ljava/io/PrintStream;Ljava/lang/String;JJ)V
        13: .line 281
            aload 0 /* out */
            aload 8 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        14: .line 282
            aload 5 /* threadToNodesMap */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 10
            goto 22
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.Boolean java.lang.Integer java.util.Collection java.util.Map int java.lang.String java.lang.String top java.util.Iterator
      StackMap stack:
        15: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 9 /* node */
        start local 9 // java.util.Map$Entry node
        16: .line 283
            aload 2 /* summariseThreads */
            invokevirtual java.lang.Boolean.booleanValue:()Z
            ifne 18
        17: .line 284
            aload 0 /* out */
            new java.lang.StringBuilder
            dup
            ldc " Thread: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* node */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        18: .line 286
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.Boolean java.lang.Integer java.util.Collection java.util.Map int java.lang.String java.lang.String java.util.Map$Entry java.util.Iterator
      StackMap stack:
            aload 0 /* out */
            aload 7 /* title */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        19: .line 287
            aload 0 /* out */
            aload 8 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        20: .line 288
            aload 1 /* sampler */
            iload 6 /* maxLength */
            ldc ""
            aload 9 /* node */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.util.Collection
            aload 0 /* out */
            aload 3 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printSamplingCallTreeRec:(Lcom/oracle/truffle/tools/profiler/CPUSampler;ILjava/lang/String;Ljava/util/Collection;Ljava/io/PrintStream;Ljava/lang/Integer;)V
        21: .line 289
            aload 0 /* out */
            aload 8 /* sep */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 9 // java.util.Map$Entry node
        22: .line 282
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.Boolean java.lang.Integer java.util.Collection java.util.Map int java.lang.String java.lang.String top java.util.Iterator
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        23: .line 291
            return
        end local 8 // java.lang.String sep
        end local 7 // java.lang.String title
        end local 6 // int maxLength
        end local 5 // java.util.Map threadToNodesMap
        end local 4 // java.util.Collection actualRoots
        end local 3 // java.lang.Integer minSamples
        end local 2 // java.lang.Boolean summariseThreads
        end local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        end local 0 // java.io.PrintStream out
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   24     0               out  Ljava/io/PrintStream;
            0   24     1           sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            0   24     2  summariseThreads  Ljava/lang/Boolean;
            0   24     3        minSamples  Ljava/lang/Integer;
            1   24     4       actualRoots  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            4   24     5  threadToNodesMap  Ljava/util/Map<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
            6    7     6              node  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            9   24     6         maxLength  I
           10   24     7             title  Ljava/lang/String;
           11   24     8               sep  Ljava/lang/String;
           16   22     9              node  Ljava/util/Map$Entry<Ljava/lang/Thread;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;>;
    MethodParameters:
                  Name  Flags
      out               
      sampler           
      summariseThreads  
      minSamples        

  private static void printSamplingCallTreeRec(com.oracle.truffle.tools.profiler.CPUSampler, int, java.lang.String, java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>, java.io.PrintStream, java.lang.Integer);
    descriptor: (Lcom/oracle/truffle/tools/profiler/CPUSampler;ILjava/lang/String;Ljava/util/Collection;Ljava/io/PrintStream;Ljava/lang/Integer;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=10, args_size=6
        start local 0 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        start local 1 // int maxRootLength
        start local 2 // java.lang.String prefix
        start local 3 // java.util.Collection children
        start local 4 // java.io.PrintStream out
        start local 5 // java.lang.Integer minSamples
         0: .line 294
            new java.util.ArrayList
            dup
            aload 3 /* children */
            invokespecial java.util.ArrayList.<init>:(Ljava/util/Collection;)V
            astore 6 /* sortedChildren */
        start local 6 // java.util.List sortedChildren
         1: .line 295
            aload 6 /* sortedChildren */
            new com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$5
            dup
            invokespecial com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$5.<init>:()V
            invokestatic java.util.Collections.sort:(Ljava/util/List;Ljava/util/Comparator;)V
         2: .line 302
            aload 6 /* sortedChildren */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 10
      StackMap locals: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String java.util.Collection java.io.PrintStream java.lang.Integer java.util.List top java.util.Iterator
      StackMap stack:
         3: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 7 /* treeNode */
        start local 7 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         4: .line 303
            aload 7 /* treeNode */
            ifnonnull 6
         5: .line 304
            goto 10
         6: .line 306
      StackMap locals: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String java.util.Collection java.io.PrintStream java.lang.Integer java.util.List com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator
      StackMap stack:
            aload 4 /* out */
            aload 0 /* sampler */
            aload 2 /* prefix */
            iconst_1
            anewarray com.oracle.truffle.tools.profiler.ProfilerNode
            dup
            iconst_0
            aload 7 /* treeNode */
            aastore
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            iload 1 /* maxRootLength */
            iconst_1
            aload 5 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printAttributes:(Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/String;Ljava/util/List;IZLjava/lang/Integer;)Z
            istore 9 /* printed */
        start local 9 // boolean printed
         7: .line 307
            aload 0 /* sampler */
            iload 1 /* maxRootLength */
            iload 9 /* printed */
            ifeq 8
            new java.lang.StringBuilder
            dup
            aload 2 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            goto 9
      StackMap locals: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String java.util.Collection java.io.PrintStream java.lang.Integer java.util.List com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator int
      StackMap stack: com.oracle.truffle.tools.profiler.CPUSampler int
         8: aload 2 /* prefix */
      StackMap locals: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String java.util.Collection java.io.PrintStream java.lang.Integer java.util.List com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator int
      StackMap stack: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String
         9: aload 7 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            aload 4 /* out */
            aload 5 /* minSamples */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.printSamplingCallTreeRec:(Lcom/oracle/truffle/tools/profiler/CPUSampler;ILjava/lang/String;Ljava/util/Collection;Ljava/io/PrintStream;Ljava/lang/Integer;)V
        end local 9 // boolean printed
        end local 7 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
        10: .line 302
      StackMap locals: com.oracle.truffle.tools.profiler.CPUSampler int java.lang.String java.util.Collection java.io.PrintStream java.lang.Integer java.util.List top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        11: .line 310
            return
        end local 6 // java.util.List sortedChildren
        end local 5 // java.lang.Integer minSamples
        end local 4 // java.io.PrintStream out
        end local 3 // java.util.Collection children
        end local 2 // java.lang.String prefix
        end local 1 // int maxRootLength
        end local 0 // com.oracle.truffle.tools.profiler.CPUSampler sampler
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0         sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            0   12     1   maxRootLength  I
            0   12     2          prefix  Ljava/lang/String;
            0   12     3        children  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            0   12     4             out  Ljava/io/PrintStream;
            0   12     5      minSamples  Ljava/lang/Integer;
            1   12     6  sortedChildren  Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            4   10     7        treeNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            7   10     9         printed  Z
    Signature: (Lcom/oracle/truffle/tools/profiler/CPUSampler;ILjava/lang/String;Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;Ljava/io/PrintStream;Ljava/lang/Integer;)V
    MethodParameters:
               Name  Flags
      sampler        
      maxRootLength  
      prefix         
      children       
      out            
      minSamples     

  private static void printLegend(java.io.PrintStream, java.lang.String, long, long);
    descriptor: (Ljava/io/PrintStream;Ljava/lang/String;JJ)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=7, locals=6, args_size=4
        start local 0 // java.io.PrintStream out
        start local 1 // java.lang.String type
        start local 2 // long samples
        start local 4 // long period
         0: .line 313
            aload 0 /* out */
            ldc "Sampling %s. Recorded %s samples with period %dms."
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 1 /* type */
            aastore
            dup
            iconst_1
            lload 2 /* samples */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_2
            lload 4 /* period */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         1: .line 314
            aload 0 /* out */
            ldc "  Self Time: Time spent on the top of the stack."
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 315
            aload 0 /* out */
            ldc "  Total Time: Time spent somewhere on the stack."
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         3: .line 316
            aload 0 /* out */
            ldc "  Opt %: Percent of time spent in compiled and therefore non-interpreted code."
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         4: .line 317
            return
        end local 4 // long period
        end local 2 // long samples
        end local 1 // java.lang.String type
        end local 0 // java.io.PrintStream out
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    5     0      out  Ljava/io/PrintStream;
            0    5     1     type  Ljava/lang/String;
            0    5     2  samples  J
            0    5     4   period  J
    MethodParameters:
         Name  Flags
      out      
      type     
      samples  
      period   

  private static int computeTitleMaxLength(java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>, );
    descriptor: (Ljava/util/Collection;I)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=2
        start local 0 // java.util.Collection children
        start local 1 // int baseLength
         0: .line 320
            iload 1 /* baseLength */
            istore 2 /* maxLength */
        start local 2 // int maxLength
         1: .line 321
            aload 0 /* children */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 6
      StackMap locals: java.util.Collection int int top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 3 /* treeNode */
        start local 3 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         3: .line 322
            aload 3 /* treeNode */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeRootNameMaxLength:(Lcom/oracle/truffle/tools/profiler/ProfilerNode;)I
            istore 5 /* rootNameLength */
        start local 5 // int rootNameLength
         4: .line 323
            iload 1 /* baseLength */
            iload 5 /* rootNameLength */
            iadd
            iload 2 /* maxLength */
            invokestatic java.lang.Math.max:(II)I
            istore 2 /* maxLength */
         5: .line 324
            iload 2 /* maxLength */
            aload 3 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            iload 1 /* baseLength */
            iconst_1
            iadd
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.computeTitleMaxLength:(Ljava/util/Collection;I)I
            invokestatic java.lang.Math.max:(II)I
            istore 2 /* maxLength */
        end local 5 // int rootNameLength
        end local 3 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         6: .line 321
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         7: .line 326
            iload 2 /* maxLength */
            ireturn
        end local 2 // int maxLength
        end local 1 // int baseLength
        end local 0 // java.util.Collection children
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    8     0        children  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            0    8     1      baseLength  I
            1    8     2       maxLength  I
            3    6     3        treeNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            4    6     5  rootNameLength  I
    Signature: (Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;I)I
    MethodParameters:
            Name  Flags
      children    
      baseLength  

  private static boolean intersectsLines(com.oracle.truffle.api.source.SourceSection, com.oracle.truffle.api.source.SourceSection);
    descriptor: (Lcom/oracle/truffle/api/source/SourceSection;Lcom/oracle/truffle/api/source/SourceSection;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // com.oracle.truffle.api.source.SourceSection section1
        start local 1 // com.oracle.truffle.api.source.SourceSection section2
         0: .line 330
            aload 0 /* section1 */
            invokevirtual com.oracle.truffle.api.source.SourceSection.getStartLine:()I
            istore 2 /* x1 */
        start local 2 // int x1
         1: .line 331
            aload 0 /* section1 */
            invokevirtual com.oracle.truffle.api.source.SourceSection.getEndLine:()I
            istore 3 /* x2 */
        start local 3 // int x2
         2: .line 332
            aload 1 /* section2 */
            invokevirtual com.oracle.truffle.api.source.SourceSection.getStartLine:()I
            istore 4 /* y1 */
        start local 4 // int y1
         3: .line 333
            aload 1 /* section2 */
            invokevirtual com.oracle.truffle.api.source.SourceSection.getEndLine:()I
            istore 5 /* y2 */
        start local 5 // int y2
         4: .line 334
            iload 3 /* x2 */
            iload 4 /* y1 */
            if_icmplt 5
            iload 5 /* y2 */
            iload 2 /* x1 */
            if_icmplt 5
            iconst_1
            ireturn
      StackMap locals: com.oracle.truffle.api.source.SourceSection com.oracle.truffle.api.source.SourceSection int int int int
      StackMap stack:
         5: iconst_0
            ireturn
        end local 5 // int y2
        end local 4 // int y1
        end local 3 // int x2
        end local 2 // int x1
        end local 1 // com.oracle.truffle.api.source.SourceSection section2
        end local 0 // com.oracle.truffle.api.source.SourceSection section1
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0  section1  Lcom/oracle/truffle/api/source/SourceSection;
            0    6     1  section2  Lcom/oracle/truffle/api/source/SourceSection;
            1    6     2        x1  I
            2    6     3        x2  I
            3    6     4        y1  I
            4    6     5        y2  I
    MethodParameters:
          Name  Flags
      section1  
      section2  

  private static boolean printAttributes(java.io.PrintStream, com.oracle.truffle.tools.profiler.CPUSampler, java.lang.String, java.util.List<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>, int, boolean, java.lang.Integer);
    descriptor: (Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/String;Ljava/util/List;IZLjava/lang/Integer;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=41, args_size=7
        start local 0 // java.io.PrintStream out
        start local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        start local 2 // java.lang.String prefix
        start local 3 // java.util.List nodes
        start local 4 // int maxRootLength
        start local 5 // boolean callTree
        start local 6 // java.lang.Integer minSamples
         0: .line 338
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getPeriod:()J
            lstore 7 /* samplePeriod */
        start local 7 // long samplePeriod
         1: .line 339
            aload 1 /* sampler */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler.getSampleCount:()J
            lstore 9 /* samples */
        start local 9 // long samples
         2: .line 341
            lconst_0
            lstore 11 /* selfInterpreted */
        start local 11 // long selfInterpreted
         3: .line 342
            lconst_0
            lstore 13 /* selfCompiled */
        start local 13 // long selfCompiled
         4: .line 343
            lconst_0
            lstore 15 /* totalInterpreted */
        start local 15 // long totalInterpreted
         5: .line 344
            lconst_0
            lstore 17 /* totalCompiled */
        start local 17 // long totalCompiled
         6: .line 345
            aload 3 /* nodes */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 20
            goto 20
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.String java.util.List int int java.lang.Integer long long long long long long top java.util.Iterator
      StackMap stack:
         7: aload 20
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 19 /* tree */
        start local 19 // com.oracle.truffle.tools.profiler.ProfilerNode tree
         8: .line 346
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getPayload:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.CPUSampler$Payload
            astore 21 /* payload */
        start local 21 // com.oracle.truffle.tools.profiler.CPUSampler$Payload payload
         9: .line 347
            lload 11 /* selfInterpreted */
            aload 21 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfInterpretedHitCount:()I
            i2l
            ladd
            lstore 11 /* selfInterpreted */
        10: .line 348
            lload 13 /* selfCompiled */
            aload 21 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfCompiledHitCount:()I
            i2l
            ladd
            lstore 13 /* selfCompiled */
        11: .line 349
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.isRecursive:()Z
            ifne 14
        12: .line 350
            lload 15 /* totalInterpreted */
            aload 21 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getInterpretedHitCount:()I
            i2l
            ladd
            lstore 15 /* totalInterpreted */
        13: .line 351
            lload 17 /* totalCompiled */
            aload 21 /* payload */
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getCompiledHitCount:()I
            i2l
            ladd
            lstore 17 /* totalCompiled */
        14: .line 353
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.String java.util.List int int java.lang.Integer long long long long long long com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator com.oracle.truffle.tools.profiler.CPUSampler$Payload
      StackMap stack:
            iload 5 /* callTree */
            ifeq 20
        15: .line 354
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$assertionsDisabled:Z
            ifne 16
            aload 3 /* nodes */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpeq 16
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        16: .line 355
      StackMap locals:
      StackMap stack:
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            astore 22 /* sourceSection */
        start local 22 // com.oracle.truffle.api.source.SourceSection sourceSection
        17: .line 356
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            astore 23 /* rootName */
        start local 23 // java.lang.String rootName
        18: .line 357
            aload 22 /* sourceSection */
            aload 23 /* rootName */
            lload 13 /* selfCompiled */
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            iconst_1
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getSelfHitCountForRecursiveChildren:(Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;JLjava/util/Collection;Z)J
            lstore 13 /* selfCompiled */
        19: .line 358
            aload 22 /* sourceSection */
            aload 23 /* rootName */
            lload 11 /* selfInterpreted */
            aload 19 /* tree */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            iconst_0
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getSelfHitCountForRecursiveChildren:(Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;JLjava/util/Collection;Z)J
            lstore 11 /* selfInterpreted */
        end local 23 // java.lang.String rootName
        end local 22 // com.oracle.truffle.api.source.SourceSection sourceSection
        end local 21 // com.oracle.truffle.tools.profiler.CPUSampler$Payload payload
        end local 19 // com.oracle.truffle.tools.profiler.ProfilerNode tree
        20: .line 345
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.String java.util.List int int java.lang.Integer long long long long long long top java.util.Iterator
      StackMap stack:
            aload 20
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        21: .line 362
            lload 15 /* totalInterpreted */
            lload 17 /* totalCompiled */
            ladd
            lstore 19 /* totalSamples */
        start local 19 // long totalSamples
        22: .line 363
            lload 19 /* totalSamples */
            aload 6 /* minSamples */
            invokevirtual java.lang.Integer.intValue:()I
            i2l
            lcmp
            ifgt 24
        23: .line 365
            iconst_0
            ireturn
        24: .line 367
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.String java.util.List int int java.lang.Integer long long long long long long long
      StackMap stack:
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$assertionsDisabled:Z
            ifne 25
            lload 19 /* totalSamples */
            lload 9 /* samples */
            lcmp
            iflt 25
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
        25: .line 368
      StackMap locals:
      StackMap stack:
            aload 3 /* nodes */
            iconst_0
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 21 /* firstNode */
        start local 21 // com.oracle.truffle.tools.profiler.ProfilerNode firstNode
        26: .line 369
            aload 21 /* firstNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            astore 22 /* sourceSection */
        start local 22 // com.oracle.truffle.api.source.SourceSection sourceSection
        27: .line 370
            aload 21 /* firstNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            astore 23 /* rootName */
        start local 23 // java.lang.String rootName
        28: .line 372
            aload 21 /* firstNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getTags:()Ljava/util/Set;
            ldc Lcom/oracle/truffle/api/instrumentation/StandardTags$RootTag;
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifne 30
        29: .line 373
            new java.lang.StringBuilder
            dup
            aload 23 /* rootName */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "~"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 22 /* sourceSection */
            aload 21 /* firstNode */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.needsColumnSpecifier:(Lcom/oracle/truffle/tools/profiler/ProfilerNode;)Z
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.formatIndices:(Lcom/oracle/truffle/api/source/SourceSection;Z)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 23 /* rootName */
        30: .line 376
      StackMap locals: com.oracle.truffle.tools.profiler.ProfilerNode com.oracle.truffle.api.source.SourceSection java.lang.String
      StackMap stack:
            lload 11 /* selfInterpreted */
            lload 13 /* selfCompiled */
            ladd
            lstore 24 /* selfSamples */
        start local 24 // long selfSamples
        31: .line 377
            lload 24 /* selfSamples */
            lload 7 /* samplePeriod */
            lmul
            lstore 26 /* selfTime */
        start local 26 // long selfTime
        32: .line 378
            lload 24 /* selfSamples */
            l2d
            lload 9 /* samples */
            l2d
            ddiv
            dstore 28 /* selfCost */
        start local 28 // double selfCost
        33: .line 379
            dconst_0
            dstore 30 /* selfCompiledP */
        start local 30 // double selfCompiledP
        34: .line 380
            lload 24 /* selfSamples */
            lconst_0
            lcmp
            ifle 36
        35: .line 381
            lload 13 /* selfCompiled */
            l2d
            lload 24 /* selfSamples */
            l2d
            ddiv
            dstore 30 /* selfCompiledP */
        36: .line 383
      StackMap locals: java.io.PrintStream com.oracle.truffle.tools.profiler.CPUSampler java.lang.String java.util.List int int java.lang.Integer long long long long long long long com.oracle.truffle.tools.profiler.ProfilerNode com.oracle.truffle.api.source.SourceSection java.lang.String long long double double
      StackMap stack:
            ldc "%10dms %5.1f%% | %5.1f%%"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            lload 26 /* selfTime */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            dload 28 /* selfCost */
            ldc 100.0
            dmul
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_2
            dload 30 /* selfCompiledP */
            ldc 100.0
            dmul
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 32 /* selfTimes */
        start local 32 // java.lang.String selfTimes
        37: .line 385
            lload 19 /* totalSamples */
            lload 7 /* samplePeriod */
            lmul
            lstore 33 /* totalTime */
        start local 33 // long totalTime
        38: .line 386
            lload 19 /* totalSamples */
            l2d
            lload 9 /* samples */
            l2d
            ddiv
            dstore 35 /* totalCost */
        start local 35 // double totalCost
        39: .line 387
            lload 17 /* totalCompiled */
            l2d
            lload 19 /* totalSamples */
            l2d
            ddiv
            dstore 37 /* totalCompiledP */
        start local 37 // double totalCompiledP
        40: .line 388
            ldc "%10dms %5.1f%% | %5.1f%%"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            lload 33 /* totalTime */
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            aastore
            dup
            iconst_1
            dload 35 /* totalCost */
            ldc 100.0
            dmul
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            dup
            iconst_2
            dload 37 /* totalCompiledP */
            ldc 100.0
            dmul
            invokestatic java.lang.Double.valueOf:(D)Ljava/lang/Double;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            astore 39 /* totalTimes */
        start local 39 // java.lang.String totalTimes
        41: .line 390
            aload 22 /* sourceSection */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getShortDescription:(Lcom/oracle/truffle/api/source/SourceSection;)Ljava/lang/String;
            astore 40 /* location */
        start local 40 // java.lang.String location
        42: .line 392
            aload 0 /* out */
            new java.lang.StringBuilder
            dup
            ldc " %-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 4 /* maxRootLength */
            bipush 10
            invokestatic java.lang.Math.max:(II)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "s | %s || %s | %s "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
        43: .line 393
            new java.lang.StringBuilder
            dup
            aload 2 /* prefix */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 23 /* rootName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aastore
            dup
            iconst_1
            aload 39 /* totalTimes */
            aastore
            dup
            iconst_2
            aload 32 /* selfTimes */
            aastore
            dup
            iconst_3
            aload 40 /* location */
            aastore
        44: .line 392
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        45: .line 394
            iconst_1
            ireturn
        end local 40 // java.lang.String location
        end local 39 // java.lang.String totalTimes
        end local 37 // double totalCompiledP
        end local 35 // double totalCost
        end local 33 // long totalTime
        end local 32 // java.lang.String selfTimes
        end local 30 // double selfCompiledP
        end local 28 // double selfCost
        end local 26 // long selfTime
        end local 24 // long selfSamples
        end local 23 // java.lang.String rootName
        end local 22 // com.oracle.truffle.api.source.SourceSection sourceSection
        end local 21 // com.oracle.truffle.tools.profiler.ProfilerNode firstNode
        end local 19 // long totalSamples
        end local 17 // long totalCompiled
        end local 15 // long totalInterpreted
        end local 13 // long selfCompiled
        end local 11 // long selfInterpreted
        end local 9 // long samples
        end local 7 // long samplePeriod
        end local 6 // java.lang.Integer minSamples
        end local 5 // boolean callTree
        end local 4 // int maxRootLength
        end local 3 // java.util.List nodes
        end local 2 // java.lang.String prefix
        end local 1 // com.oracle.truffle.tools.profiler.CPUSampler sampler
        end local 0 // java.io.PrintStream out
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   46     0               out  Ljava/io/PrintStream;
            0   46     1           sampler  Lcom/oracle/truffle/tools/profiler/CPUSampler;
            0   46     2            prefix  Ljava/lang/String;
            0   46     3             nodes  Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            0   46     4     maxRootLength  I
            0   46     5          callTree  Z
            0   46     6        minSamples  Ljava/lang/Integer;
            1   46     7      samplePeriod  J
            2   46     9           samples  J
            3   46    11   selfInterpreted  J
            4   46    13      selfCompiled  J
            5   46    15  totalInterpreted  J
            6   46    17     totalCompiled  J
            8   20    19              tree  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            9   20    21           payload  Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;
           17   20    22     sourceSection  Lcom/oracle/truffle/api/source/SourceSection;
           18   20    23          rootName  Ljava/lang/String;
           22   46    19      totalSamples  J
           26   46    21         firstNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
           27   46    22     sourceSection  Lcom/oracle/truffle/api/source/SourceSection;
           28   46    23          rootName  Ljava/lang/String;
           31   46    24       selfSamples  J
           32   46    26          selfTime  J
           33   46    28          selfCost  D
           34   46    30     selfCompiledP  D
           37   46    32         selfTimes  Ljava/lang/String;
           38   46    33         totalTime  J
           39   46    35         totalCost  D
           40   46    37    totalCompiledP  D
           41   46    39        totalTimes  Ljava/lang/String;
           42   46    40          location  Ljava/lang/String;
    Signature: (Ljava/io/PrintStream;Lcom/oracle/truffle/tools/profiler/CPUSampler;Ljava/lang/String;Ljava/util/List<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;IZLjava/lang/Integer;)Z
    MethodParameters:
               Name  Flags
      out            
      sampler        
      prefix         
      nodes          
      maxRootLength  
      callTree       
      minSamples     

  private static long getSelfHitCountForRecursiveChildren(com.oracle.truffle.api.source.SourceSection, java.lang.String, long, java.util.Collection<com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>>, );
    descriptor: (Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;JLjava/util/Collection;Z)J
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=8, locals=10, args_size=5
        start local 0 // com.oracle.truffle.api.source.SourceSection sourceSection
        start local 1 // java.lang.String rootName
        start local 2 // long selfCompiled
        start local 4 // java.util.Collection children
        start local 5 // boolean compiled
         0: .line 398
            lconst_0
            lstore 6 /* hitCount */
        start local 6 // long hitCount
         1: .line 399
            aload 4 /* children */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 9
            goto 9
      StackMap locals: com.oracle.truffle.api.source.SourceSection java.lang.String long java.util.Collection int long top java.util.Iterator
      StackMap stack:
         2: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 8 /* child */
        start local 8 // com.oracle.truffle.tools.profiler.ProfilerNode child
         3: .line 400
            aload 8 /* child */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            aload 0 /* sourceSection */
            invokevirtual com.oracle.truffle.api.source.SourceSection.equals:(Ljava/lang/Object;)Z
            ifeq 9
            aload 8 /* child */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            aload 1 /* rootName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 9
         4: .line 401
            iload 5 /* compiled */
            ifeq 7
         5: .line 402
            lload 6 /* hitCount */
            aload 8 /* child */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getPayload:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.CPUSampler$Payload
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfCompiledHitCount:()I
            i2l
            ladd
            lstore 6 /* hitCount */
         6: .line 403
            goto 8
         7: .line 404
      StackMap locals: com.oracle.truffle.api.source.SourceSection java.lang.String long java.util.Collection int long com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator
      StackMap stack:
            lload 6 /* hitCount */
            aload 8 /* child */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getPayload:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.CPUSampler$Payload
            invokevirtual com.oracle.truffle.tools.profiler.CPUSampler$Payload.getSelfInterpretedHitCount:()I
            i2l
            ladd
            lstore 6 /* hitCount */
         8: .line 406
      StackMap locals:
      StackMap stack:
            lload 6 /* hitCount */
            aload 0 /* sourceSection */
            aload 1 /* rootName */
            lload 6 /* hitCount */
            aload 8 /* child */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            iload 5 /* compiled */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.getSelfHitCountForRecursiveChildren:(Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;JLjava/util/Collection;Z)J
            ladd
            lstore 6 /* hitCount */
        end local 8 // com.oracle.truffle.tools.profiler.ProfilerNode child
         9: .line 399
      StackMap locals: com.oracle.truffle.api.source.SourceSection java.lang.String long java.util.Collection int long top java.util.Iterator
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        10: .line 409
            lload 2 /* selfCompiled */
            lload 6 /* hitCount */
            ladd
            lreturn
        end local 6 // long hitCount
        end local 5 // boolean compiled
        end local 4 // java.util.Collection children
        end local 2 // long selfCompiled
        end local 1 // java.lang.String rootName
        end local 0 // com.oracle.truffle.api.source.SourceSection sourceSection
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   11     0  sourceSection  Lcom/oracle/truffle/api/source/SourceSection;
            0   11     1       rootName  Ljava/lang/String;
            0   11     2   selfCompiled  J
            0   11     4       children  Ljava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;
            0   11     5       compiled  Z
            1   11     6       hitCount  J
            3    9     8          child  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
    Signature: (Lcom/oracle/truffle/api/source/SourceSection;Ljava/lang/String;JLjava/util/Collection<Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;>;Z)J
    MethodParameters:
               Name  Flags
      sourceSection  
      rootName       
      selfCompiled   
      children       
      compiled       

  private static boolean needsColumnSpecifier(com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>);
    descriptor: (Lcom/oracle/truffle/tools/profiler/ProfilerNode;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // com.oracle.truffle.tools.profiler.ProfilerNode firstNode
         0: .line 413
            iconst_0
            istore 1 /* needsColumnsSpecifier */
        start local 1 // boolean needsColumnsSpecifier
         1: .line 414
            aload 0 /* firstNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            astore 2 /* sourceSection */
        start local 2 // com.oracle.truffle.api.source.SourceSection sourceSection
         2: .line 415
            aload 0 /* firstNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getParent:()Lcom/oracle/truffle/tools/profiler/ProfilerNode;
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getChildren:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 9
      StackMap locals: com.oracle.truffle.tools.profiler.ProfilerNode int com.oracle.truffle.api.source.SourceSection top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.oracle.truffle.tools.profiler.ProfilerNode
            astore 3 /* node */
        start local 3 // com.oracle.truffle.tools.profiler.ProfilerNode node
         4: .line 416
            aload 3 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            aload 2 /* sourceSection */
            if_acmpne 6
         5: .line 417
            goto 9
         6: .line 419
      StackMap locals: com.oracle.truffle.tools.profiler.ProfilerNode int com.oracle.truffle.api.source.SourceSection com.oracle.truffle.tools.profiler.ProfilerNode java.util.Iterator
      StackMap stack:
            aload 3 /* node */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            aload 2 /* sourceSection */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.intersectsLines:(Lcom/oracle/truffle/api/source/SourceSection;Lcom/oracle/truffle/api/source/SourceSection;)Z
            ifeq 9
         7: .line 420
            iconst_1
            istore 1 /* needsColumnsSpecifier */
         8: .line 421
            goto 10
        end local 3 // com.oracle.truffle.tools.profiler.ProfilerNode node
         9: .line 415
      StackMap locals: com.oracle.truffle.tools.profiler.ProfilerNode int com.oracle.truffle.api.source.SourceSection top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        10: .line 424
      StackMap locals: com.oracle.truffle.tools.profiler.ProfilerNode int com.oracle.truffle.api.source.SourceSection
      StackMap stack:
            iload 1 /* needsColumnsSpecifier */
            ireturn
        end local 2 // com.oracle.truffle.api.source.SourceSection sourceSection
        end local 1 // boolean needsColumnsSpecifier
        end local 0 // com.oracle.truffle.tools.profiler.ProfilerNode firstNode
      LocalVariableTable:
        Start  End  Slot                   Name  Signature
            0   11     0              firstNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            1   11     1  needsColumnsSpecifier  Z
            2   11     2          sourceSection  Lcom/oracle/truffle/api/source/SourceSection;
            4    9     3                   node  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
    Signature: (Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;)Z
    MethodParameters:
           Name  Flags
      firstNode  

  private static int computeRootNameMaxLength(com.oracle.truffle.tools.profiler.ProfilerNode<com.oracle.truffle.tools.profiler.CPUSampler$Payload>);
    descriptor: (Lcom/oracle/truffle/tools/profiler/ProfilerNode;)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
         0: .line 428
            aload 0 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getRootName:()Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            istore 1 /* length */
        start local 1 // int length
         1: .line 429
            aload 0 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getTags:()Ljava/util/Set;
            ldc Lcom/oracle/truffle/api/instrumentation/StandardTags$RootTag;
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifne 3
         2: .line 431
            iload 1 /* length */
            aload 0 /* treeNode */
            invokevirtual com.oracle.truffle.tools.profiler.ProfilerNode.getSourceSection:()Lcom/oracle/truffle/api/source/SourceSection;
            aload 0 /* treeNode */
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.needsColumnSpecifier:(Lcom/oracle/truffle/tools/profiler/ProfilerNode;)Z
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.formatIndices:(Lcom/oracle/truffle/api/source/SourceSection;Z)Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            iconst_1
            iadd
            iadd
            istore 1 /* length */
         3: .line 433
      StackMap locals: int
      StackMap stack:
            iload 1 /* length */
            ireturn
        end local 1 // int length
        end local 0 // com.oracle.truffle.tools.profiler.ProfilerNode treeNode
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    4     0  treeNode  Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;
            1    4     1    length  I
    Signature: (Lcom/oracle/truffle/tools/profiler/ProfilerNode<Lcom/oracle/truffle/tools/profiler/CPUSampler$Payload;>;)I
    MethodParameters:
          Name  Flags
      treeNode  

  static int[] $SWITCH_TABLE$com$oracle$truffle$tools$profiler$impl$CPUSamplerCLI$Output();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 53
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$SWITCH_TABLE$com$oracle$truffle$tools$profiler$impl$CPUSamplerCLI$Output:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.values:()[Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.CALLTREE:Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;
            invokevirtual com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.ordinal:()I
            iconst_2
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.HISTOGRAM:Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;
            invokevirtual com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.ordinal:()I
            iconst_1
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.JSON:Lcom/oracle/truffle/tools/profiler/impl/CPUSamplerCLI$Output;
            invokevirtual com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output.ordinal:()I
            iconst_3
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            dup
            putstatic com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI.$SWITCH_TABLE$com$oracle$truffle$tools$profiler$impl$CPUSamplerCLI$Output:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
}
SourceFile: "CPUSamplerCLI.java"
NestMembers:
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$1  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$2  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$3  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$4  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$5  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output
InnerClasses:
  public abstract Group = com.oracle.truffle.api.Option$Group of com.oracle.truffle.api.Option
  public final RootTag = com.oracle.truffle.api.instrumentation.StandardTags$RootTag of com.oracle.truffle.api.instrumentation.StandardTags
  public final Env = com.oracle.truffle.api.instrumentation.TruffleInstrument$Env of com.oracle.truffle.api.instrumentation.TruffleInstrument
  public final Mode = com.oracle.truffle.tools.profiler.CPUSampler$Mode of com.oracle.truffle.tools.profiler.CPUSampler
  public final Payload = com.oracle.truffle.tools.profiler.CPUSampler$Payload of com.oracle.truffle.tools.profiler.CPUSampler
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$1
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$2
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$3
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$4
  com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$5
  final Output = com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI$Output of com.oracle.truffle.tools.profiler.impl.CPUSamplerCLI
  SourceLocation = com.oracle.truffle.tools.profiler.impl.ProfilerCLI$SourceLocation of com.oracle.truffle.tools.profiler.impl.ProfilerCLI
  public abstract Entry = java.util.Map$Entry of java.util.Map
    RuntimeInvisibleAnnotations: 
      com.oracle.truffle.api.Option$Group(value = {"cpusampler"})