public class org.h2.util.Profiler implements java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.h2.util.Profiler
  super_class: java.lang.Object
{
  private static java.lang.instrument.Instrumentation instrumentation;
    descriptor: Ljava/lang/instrument/Instrumentation;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

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

  private static final int MAX_ELEMENTS;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 1000

  public int interval;
    descriptor: I
    flags: (0x0001) ACC_PUBLIC

  public int depth;
    descriptor: I
    flags: (0x0001) ACC_PUBLIC

  public boolean paused;
    descriptor: Z
    flags: (0x0001) ACC_PUBLIC

  public boolean sumClasses;
    descriptor: Z
    flags: (0x0001) ACC_PUBLIC

  public boolean sumMethods;
    descriptor: Z
    flags: (0x0001) ACC_PUBLIC

  private int pid;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private final java.lang.String[] ignoreLines;
    descriptor: [Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String[] ignorePackages;
    descriptor: [Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String[] ignoreThreads;
    descriptor: [Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private volatile boolean stop;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private final java.util.HashMap<java.lang.String, java.lang.Integer> counts;
    descriptor: Ljava/util/HashMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;

  private final java.util.HashMap<java.lang.String, java.lang.Integer> summary;
    descriptor: Ljava/util/HashMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;

  private int minCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private int total;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.lang.Thread thread;
    descriptor: Ljava/lang/Thread;
    flags: (0x0002) ACC_PRIVATE

  private long start;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private long time;
    descriptor: J
    flags: (0x0002) ACC_PRIVATE

  private int threadDumps;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 35
            ldc "line.separator"
            ldc "\n"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
         1: .line 34
            putstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
         2: .line 36
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.h2.util.Profiler this
         0: .line 31
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 38
            aload 0 /* this */
            iconst_2
            putfield org.h2.util.Profiler.interval:I
         2: .line 39
            aload 0 /* this */
            bipush 48
            putfield org.h2.util.Profiler.depth:I
         3: .line 46
            aload 0 /* this */
            ldc "java,sun,com.sun.,com.google.common.,com.mongodb.,org.bson.,"
         4: .line 53
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            putfield org.h2.util.Profiler.ignoreLines:[Ljava/lang/String;
         5: .line 54
            aload 0 /* this */
            ldc "java,sun,com.sun.,com.google.common.,com.mongodb.,org.bson"
         6: .line 61
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            putfield org.h2.util.Profiler.ignorePackages:[Ljava/lang/String;
         7: .line 62
            aload 0 /* this */
            ldc "java.lang.Object.wait,java.lang.Thread.dumpThreads,java.lang.Thread.getThreads,java.lang.Thread.sleep,java.lang.UNIXProcess.waitForProcessExit,java.net.PlainDatagramSocketImpl.receive0,java.net.PlainSocketImpl.accept,java.net.PlainSocketImpl.socketAccept,java.net.SocketInputStream.socketRead,java.net.SocketOutputStream.socketWrite,org.eclipse.jetty.io.nio.SelectorManager$SelectSet.doSelect,sun.awt.windows.WToolkit.eventLoop,sun.misc.Unsafe.park,sun.nio.ch.EPollArrayWrapper.epollWait,sun.nio.ch.KQueueArrayWrapper.kevent0,sun.nio.ch.ServerSocketChannelImpl.accept,dalvik.system.VMStack.getThreadStackTrace,dalvik.system.NativeStart.run"
         8: .line 81
            ldc ","
            invokevirtual java.lang.String.split:(Ljava/lang/String;)[Ljava/lang/String;
            putfield org.h2.util.Profiler.ignoreThreads:[Ljava/lang/String;
         9: .line 84
            aload 0 /* this */
        10: .line 85
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.h2.util.Profiler.counts:Ljava/util/HashMap;
        11: .line 91
            aload 0 /* this */
        12: .line 92
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.h2.util.Profiler.summary:Ljava/util/HashMap;
        13: .line 93
            aload 0 /* this */
            iconst_1
            putfield org.h2.util.Profiler.minCount:I
        14: .line 31
            return
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   15     0  this  Lorg/h2/util/Profiler;

  public static void premain(java.lang.String, java.lang.instrument.Instrumentation);
    descriptor: (Ljava/lang/String;Ljava/lang/instrument/Instrumentation;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // java.lang.String agentArgs
        start local 1 // java.lang.instrument.Instrumentation inst
         0: .line 107
            aload 1 /* inst */
            putstatic org.h2.util.Profiler.instrumentation:Ljava/lang/instrument/Instrumentation;
         1: .line 108
            return
        end local 1 // java.lang.instrument.Instrumentation inst
        end local 0 // java.lang.String agentArgs
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0  agentArgs  Ljava/lang/String;
            0    2     1       inst  Ljava/lang/instrument/Instrumentation;
    MethodParameters:
           Name  Flags
      agentArgs  
      inst       

  public static java.lang.instrument.Instrumentation getInstrumentation();
    descriptor: ()Ljava/lang/instrument/Instrumentation;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 116
            getstatic org.h2.util.Profiler.instrumentation:Ljava/lang/instrument/Instrumentation;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static void main(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0089) ACC_PUBLIC, ACC_STATIC, ACC_VARARGS
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String[] args
         0: .line 127
            new org.h2.util.Profiler
            dup
            invokespecial org.h2.util.Profiler.<init>:()V
            aload 0 /* args */
            invokevirtual org.h2.util.Profiler.run:([Ljava/lang/String;)V
         1: .line 128
            return
        end local 0 // java.lang.String[] args
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  args  [Ljava/lang/String;
    MethodParameters:
      Name  Flags
      args  

  private void run(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0082) ACC_PRIVATE, ACC_VARARGS
    Code:
      stack=5, locals=11, args_size=2
        start local 0 // org.h2.util.Profiler this
        start local 1 // java.lang.String[] args
         0: .line 131
            aload 1 /* args */
            arraylength
            ifne 9
         1: .line 132
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Show profiling data"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         2: .line 133
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Usage: java "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         3: .line 134
            ldc " <pid> | <stackTraceFileNames>"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 133
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         5: .line 135
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Processes:"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 136
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "jps"
            aastore
            dup
            iconst_1
            ldc "-l"
            aastore
            invokestatic org.h2.util.Profiler.exec:([Ljava/lang/String;)Ljava/lang/String;
            astore 2 /* processes */
        start local 2 // java.lang.String processes
         7: .line 137
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 2 /* processes */
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 138
            return
        end local 2 // java.lang.String processes
         9: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.h2.util.Profiler.start:J
        10: .line 141
            aload 1 /* args */
            iconst_0
            aaload
            ldc "\\d+"
            invokevirtual java.lang.String.matches:(Ljava/lang/String;)Z
            ifeq 20
        11: .line 142
            aload 0 /* this */
            aload 1 /* args */
            iconst_0
            aaload
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
            putfield org.h2.util.Profiler.pid:I
        12: .line 143
            lconst_0
            lstore 2 /* last */
        start local 2 // long last
        13: .line 145
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.h2.util.Profiler.tick:()V
        14: .line 146
            invokestatic java.lang.System.nanoTime:()J
            lstore 4 /* t */
        start local 4 // long t
        15: .line 147
            lload 4 /* t */
            lload 2 /* last */
            lsub
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            ldc 5
            invokevirtual java.util.concurrent.TimeUnit.toNanos:(J)J
            lcmp
            ifle 13
        16: .line 148
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield org.h2.util.Profiler.start:J
            lsub
            putfield org.h2.util.Profiler.time:J
        17: .line 149
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 0 /* this */
            iconst_3
            invokevirtual org.h2.util.Profiler.getTopTraces:(I)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        18: .line 150
            lload 4 /* t */
            lstore 2 /* last */
        end local 4 // long t
        19: .line 144
            goto 13
        end local 2 // long last
        20: .line 155
      StackMap locals:
      StackMap stack:
            aload 1 /* args */
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 60
      StackMap locals: org.h2.util.Profiler java.lang.String[] top int int java.lang.String[]
      StackMap stack:
        21: aload 5
            iload 3
            aaload
            astore 2 /* arg */
        start local 2 // java.lang.String arg
        22: .line 156
            aload 2 /* arg */
            ldc "-"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 34
        23: .line 157
            ldc "-classes"
            aload 2 /* arg */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 26
        24: .line 158
            aload 0 /* this */
            iconst_1
            putfield org.h2.util.Profiler.sumClasses:Z
        25: .line 159
            goto 59
      StackMap locals: org.h2.util.Profiler java.lang.String[] java.lang.String int int java.lang.String[]
      StackMap stack:
        26: ldc "-methods"
            aload 2 /* arg */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 29
        27: .line 160
            aload 0 /* this */
            iconst_1
            putfield org.h2.util.Profiler.sumMethods:Z
        28: .line 161
            goto 59
      StackMap locals:
      StackMap stack:
        29: ldc "-packages"
            aload 2 /* arg */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 33
        30: .line 162
            aload 0 /* this */
            iconst_0
            putfield org.h2.util.Profiler.sumClasses:Z
        31: .line 163
            aload 0 /* this */
            iconst_0
            putfield org.h2.util.Profiler.sumMethods:Z
        32: .line 164
            goto 59
        33: .line 165
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalArgumentException
            dup
            aload 2 /* arg */
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
        34: .line 169
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 6
            aconst_null
            astore 7
        35: new java.io.InputStreamReader
            dup
            new java.io.FileInputStream
            dup
            aload 2 /* arg */
            invokespecial java.io.FileInputStream.<init>:(Ljava/lang/String;)V
            invokespecial java.io.InputStreamReader.<init>:(Ljava/io/InputStream;)V
            astore 8 /* reader */
        start local 8 // java.io.Reader reader
        36: .line 170
            new java.io.LineNumberReader
            dup
            aload 8 /* reader */
            invokespecial java.io.LineNumberReader.<init>:(Ljava/io/Reader;)V
            astore 9 /* r */
        start local 9 // java.io.LineNumberReader r
        37: .line 172
      StackMap locals: org.h2.util.Profiler java.lang.String[] java.lang.String int int java.lang.String[] java.lang.Throwable java.lang.Throwable java.io.Reader java.io.LineNumberReader
      StackMap stack:
            aload 9 /* r */
            invokevirtual java.io.LineNumberReader.readLine:()Ljava/lang/String;
            astore 10 /* line */
        start local 10 // java.lang.String line
        38: .line 173
            aload 10 /* line */
            ifnonnull 40
        39: .line 174
            goto 43
        40: .line 175
      StackMap locals: java.lang.String
      StackMap stack:
            aload 10 /* line */
            ldc "Full thread dump"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 37
        41: .line 176
            aload 0 /* this */
            dup
            getfield org.h2.util.Profiler.threadDumps:I
            iconst_1
            iadd
            putfield org.h2.util.Profiler.threadDumps:I
        end local 10 // java.lang.String line
        42: .line 171
            goto 37
        end local 9 // java.io.LineNumberReader r
        43: .line 179
      StackMap locals:
      StackMap stack:
            aload 8 /* reader */
            ifnull 49
            aload 8 /* reader */
            invokevirtual java.io.Reader.close:()V
            goto 49
      StackMap locals:
      StackMap stack: java.lang.Throwable
        44: astore 6
            aload 8 /* reader */
            ifnull 45
            aload 8 /* reader */
            invokevirtual java.io.Reader.close:()V
        end local 8 // java.io.Reader reader
      StackMap locals:
      StackMap stack:
        45: aload 6
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        46: astore 7
            aload 6
            ifnonnull 47
            aload 7
            astore 6
            goto 48
      StackMap locals:
      StackMap stack:
        47: aload 6
            aload 7
            if_acmpeq 48
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        48: aload 6
            athrow
        49: .line 180
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 6
            aconst_null
            astore 7
        50: new java.io.InputStreamReader
            dup
            new java.io.FileInputStream
            dup
            aload 2 /* arg */
            invokespecial java.io.FileInputStream.<init>:(Ljava/lang/String;)V
            invokespecial java.io.InputStreamReader.<init>:(Ljava/io/InputStream;)V
            astore 8 /* reader */
        start local 8 // java.io.Reader reader
        51: .line 181
            new java.io.LineNumberReader
            dup
            aload 8 /* reader */
            invokespecial java.io.LineNumberReader.<init>:(Ljava/io/Reader;)V
            astore 9 /* r */
        start local 9 // java.io.LineNumberReader r
        52: .line 182
            aload 0 /* this */
            aload 9 /* r */
            invokestatic org.h2.util.Profiler.readStackTrace:(Ljava/io/LineNumberReader;)Ljava/util/List;
            invokevirtual org.h2.util.Profiler.processList:(Ljava/util/List;)V
        end local 9 // java.io.LineNumberReader r
        53: .line 183
            aload 8 /* reader */
            ifnull 59
            aload 8 /* reader */
            invokevirtual java.io.Reader.close:()V
            goto 59
      StackMap locals: org.h2.util.Profiler java.lang.String[] java.lang.String int int java.lang.String[] java.lang.Throwable java.lang.Throwable java.io.Reader
      StackMap stack: java.lang.Throwable
        54: astore 6
            aload 8 /* reader */
            ifnull 55
            aload 8 /* reader */
            invokevirtual java.io.Reader.close:()V
        end local 8 // java.io.Reader reader
      StackMap locals:
      StackMap stack:
        55: aload 6
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        56: astore 7
            aload 6
            ifnonnull 57
            aload 7
            astore 6
            goto 58
      StackMap locals:
      StackMap stack:
        57: aload 6
            aload 7
            if_acmpeq 58
            aload 6
            aload 7
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        58: aload 6
            athrow
        end local 2 // java.lang.String arg
        59: .line 155
      StackMap locals: org.h2.util.Profiler java.lang.String[] top int int java.lang.String[]
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
        60: iload 3
            iload 4
            if_icmplt 21
        61: .line 185
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            aload 0 /* this */
            iconst_5
            invokevirtual org.h2.util.Profiler.getTopTraces:(I)Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        62: .line 186
            goto 65
      StackMap locals: org.h2.util.Profiler java.lang.String[]
      StackMap stack: java.io.IOException
        63: astore 2 /* e */
        start local 2 // java.io.IOException e
        64: .line 187
            new java.lang.RuntimeException
            dup
            aload 2 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        65: .line 189
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.String[] args
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   66     0       this  Lorg/h2/util/Profiler;
            0   66     1       args  [Ljava/lang/String;
            7    9     2  processes  Ljava/lang/String;
           13   20     2       last  J
           15   19     4          t  J
           22   59     2        arg  Ljava/lang/String;
           36   45     8     reader  Ljava/io/Reader;
           37   43     9          r  Ljava/io/LineNumberReader;
           38   42    10       line  Ljava/lang/String;
           51   55     8     reader  Ljava/io/Reader;
           52   53     9          r  Ljava/io/LineNumberReader;
           64   65     2          e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          36    43      44  any
          35    46      46  any
          51    53      54  any
          50    56      56  any
          20    62      63  Class java.io.IOException
    MethodParameters:
      Name  Flags
      args  

  private static java.util.List<java.lang.Object[]> getRunnableStackTraces();
    descriptor: ()Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=6, args_size=0
         0: .line 192
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 0 /* list */
        start local 0 // java.util.ArrayList list
         1: .line 193
            invokestatic java.lang.Thread.getAllStackTraces:()Ljava/util/Map;
            astore 1 /* map */
        start local 1 // java.util.Map map
         2: .line 194
            aload 1 /* map */
            invokeinterface java.util.Map.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 11
      StackMap locals: java.util.ArrayList java.util.Map top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 2 /* entry */
        start local 2 // java.util.Map$Entry entry
         4: .line 195
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.Thread
            astore 4 /* t */
        start local 4 // java.lang.Thread t
         5: .line 196
            aload 4 /* t */
            invokevirtual java.lang.Thread.getState:()Ljava/lang/Thread$State;
            getstatic java.lang.Thread$State.RUNNABLE:Ljava/lang/Thread$State;
            if_acmpeq 7
         6: .line 197
            goto 11
         7: .line 199
      StackMap locals: java.util.ArrayList java.util.Map java.util.Map$Entry java.util.Iterator java.lang.Thread
      StackMap stack:
            aload 2 /* entry */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.StackTraceElement[]
            astore 5 /* dump */
        start local 5 // java.lang.StackTraceElement[] dump
         8: .line 200
            aload 5 /* dump */
            ifnull 11
            aload 5 /* dump */
            arraylength
            ifne 10
         9: .line 201
            goto 11
        10: .line 203
      StackMap locals: java.lang.StackTraceElement[]
      StackMap stack:
            aload 0 /* list */
            aload 5 /* dump */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // java.lang.StackTraceElement[] dump
        end local 4 // java.lang.Thread t
        end local 2 // java.util.Map$Entry entry
        11: .line 194
      StackMap locals: java.util.ArrayList java.util.Map top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        12: .line 205
            aload 0 /* list */
            areturn
        end local 1 // java.util.Map map
        end local 0 // java.util.ArrayList list
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            1   13     0   list  Ljava/util/ArrayList<[Ljava/lang/Object;>;
            2   13     1    map  Ljava/util/Map<Ljava/lang/Thread;[Ljava/lang/StackTraceElement;>;
            4   11     2  entry  Ljava/util/Map$Entry<Ljava/lang/Thread;[Ljava/lang/StackTraceElement;>;
            5   11     4      t  Ljava/lang/Thread;
            8   11     5   dump  [Ljava/lang/StackTraceElement;
    Signature: ()Ljava/util/List<[Ljava/lang/Object;>;

  private static java.util.List<java.lang.Object[]> readRunnableStackTraces(int);
    descriptor: (I)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=1
        start local 0 // int pid
         0: .line 210
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "jstack"
            aastore
            dup
            iconst_1
            iload 0 /* pid */
            invokestatic java.lang.Integer.toString:(I)Ljava/lang/String;
            aastore
            invokestatic org.h2.util.Profiler.exec:([Ljava/lang/String;)Ljava/lang/String;
            astore 1 /* jstack */
        start local 1 // java.lang.String jstack
         1: .line 211
            new java.io.LineNumberReader
            dup
         2: .line 212
            new java.io.StringReader
            dup
            aload 1 /* jstack */
            invokespecial java.io.StringReader.<init>:(Ljava/lang/String;)V
         3: .line 211
            invokespecial java.io.LineNumberReader.<init>:(Ljava/io/Reader;)V
            astore 2 /* r */
        start local 2 // java.io.LineNumberReader r
         4: .line 213
            aload 2 /* r */
            invokestatic org.h2.util.Profiler.readStackTrace:(Ljava/io/LineNumberReader;)Ljava/util/List;
         5: areturn
        end local 2 // java.io.LineNumberReader r
        end local 1 // java.lang.String jstack
         6: .line 214
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 1 /* e */
        start local 1 // java.io.IOException e
         7: .line 215
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.io.IOException e
        end local 0 // int pid
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    8     0     pid  I
            1    6     1  jstack  Ljava/lang/String;
            4    6     2       r  Ljava/io/LineNumberReader;
            7    8     1       e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0     5       6  Class java.io.IOException
    Signature: (I)Ljava/util/List<[Ljava/lang/Object;>;
    MethodParameters:
      Name  Flags
      pid   

  private static java.util.List<java.lang.Object[]> readStackTrace(java.io.LineNumberReader);
    descriptor: (Ljava/io/LineNumberReader;)Ljava/util/List;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // java.io.LineNumberReader r
         0: .line 221
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* list */
        start local 1 // java.util.ArrayList list
         1: .line 223
      StackMap locals: java.util.ArrayList
      StackMap stack:
            aload 0 /* r */
            invokevirtual java.io.LineNumberReader.readLine:()Ljava/lang/String;
            astore 2 /* line */
        start local 2 // java.lang.String line
         2: .line 224
            aload 2 /* line */
            ifnonnull 4
         3: .line 225
            goto 28
         4: .line 227
      StackMap locals: java.lang.String
      StackMap stack:
            aload 2 /* line */
            ldc "\""
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 6
         5: .line 229
            goto 1
         6: .line 231
      StackMap locals:
      StackMap stack:
            aload 0 /* r */
            invokevirtual java.io.LineNumberReader.readLine:()Ljava/lang/String;
            astore 2 /* line */
         7: .line 232
            aload 2 /* line */
            ifnonnull 9
         8: .line 233
            goto 28
         9: .line 235
      StackMap locals:
      StackMap stack:
            aload 2 /* line */
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 2 /* line */
        10: .line 236
            aload 2 /* line */
            ldc "java.lang.Thread.State: RUNNABLE"
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 12
        11: .line 237
            goto 1
        12: .line 239
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 3 /* stack */
        start local 3 // java.util.ArrayList stack
        13: .line 241
      StackMap locals: java.util.ArrayList
      StackMap stack:
            aload 0 /* r */
            invokevirtual java.io.LineNumberReader.readLine:()Ljava/lang/String;
            astore 2 /* line */
        14: .line 242
            aload 2 /* line */
            ifnonnull 16
        15: .line 243
            goto 24
        16: .line 245
      StackMap locals:
      StackMap stack:
            aload 2 /* line */
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            astore 2 /* line */
        17: .line 246
            aload 2 /* line */
            ldc "- "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 19
        18: .line 247
            goto 13
        19: .line 249
      StackMap locals:
      StackMap stack:
            aload 2 /* line */
            ldc "at "
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifne 21
        20: .line 250
            goto 24
        21: .line 252
      StackMap locals:
      StackMap stack:
            aload 2 /* line */
            iconst_3
            invokestatic org.h2.util.StringUtils.trimSubstring:(Ljava/lang/String;I)Ljava/lang/String;
            astore 2 /* line */
        22: .line 253
            aload 3 /* stack */
            aload 2 /* line */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        23: .line 240
            goto 13
        24: .line 255
      StackMap locals:
      StackMap stack:
            aload 3 /* stack */
            invokevirtual java.util.ArrayList.isEmpty:()Z
            ifne 1
        25: .line 256
            aload 3 /* stack */
            iconst_0
            anewarray java.lang.String
            invokevirtual java.util.ArrayList.toArray:([Ljava/lang/Object;)[Ljava/lang/Object;
            checkcast java.lang.String[]
            astore 4 /* s */
        start local 4 // java.lang.String[] s
        26: .line 257
            aload 1 /* list */
            aload 4 /* s */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // java.lang.String[] s
        end local 3 // java.util.ArrayList stack
        end local 2 // java.lang.String line
        27: .line 222
            goto 1
        28: .line 260
      StackMap locals:
      StackMap stack:
            aload 1 /* list */
            areturn
        end local 1 // java.util.ArrayList list
        end local 0 // java.io.LineNumberReader r
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   29     0      r  Ljava/io/LineNumberReader;
            1   29     1   list  Ljava/util/ArrayList<[Ljava/lang/Object;>;
            2   27     2   line  Ljava/lang/String;
           13   27     3  stack  Ljava/util/ArrayList<Ljava/lang/String;>;
           26   27     4      s  [Ljava/lang/String;
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/io/LineNumberReader;)Ljava/util/List<[Ljava/lang/Object;>;
    MethodParameters:
      Name  Flags
      r     

  private static java.lang.String exec(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)Ljava/lang/String;
    flags: (0x008a) ACC_PRIVATE, ACC_STATIC, ACC_VARARGS
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // java.lang.String[] args
         0: .line 264
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 1 /* err */
        start local 1 // java.io.ByteArrayOutputStream err
         1: .line 265
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* out */
        start local 2 // java.io.ByteArrayOutputStream out
         2: .line 267
            invokestatic java.lang.Runtime.getRuntime:()Ljava/lang/Runtime;
            aload 0 /* args */
            invokevirtual java.lang.Runtime.exec:([Ljava/lang/String;)Ljava/lang/Process;
            astore 3 /* p */
        start local 3 // java.lang.Process p
         3: .line 268
            aload 3 /* p */
            invokevirtual java.lang.Process.getInputStream:()Ljava/io/InputStream;
            aload 2 /* out */
            invokestatic org.h2.util.Profiler.copyInThread:(Ljava/io/InputStream;Ljava/io/OutputStream;)V
         4: .line 269
            aload 3 /* p */
            invokevirtual java.lang.Process.getErrorStream:()Ljava/io/InputStream;
            aload 1 /* err */
            invokestatic org.h2.util.Profiler.copyInThread:(Ljava/io/InputStream;Ljava/io/OutputStream;)V
         5: .line 270
            aload 3 /* p */
            invokevirtual java.lang.Process.waitFor:()I
            pop
         6: .line 271
            new java.lang.String
            dup
            aload 1 /* err */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokespecial java.lang.String.<init>:([BLjava/nio/charset/Charset;)V
            astore 4 /* e */
        start local 4 // java.lang.String e
         7: .line 272
            aload 4 /* e */
            invokevirtual java.lang.String.length:()I
            ifle 9
         8: .line 273
            new java.lang.RuntimeException
            dup
            aload 4 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 275
      StackMap locals: java.lang.String[] java.io.ByteArrayOutputStream java.io.ByteArrayOutputStream java.lang.Process java.lang.String
      StackMap stack:
            new java.lang.String
            dup
            aload 2 /* out */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokespecial java.lang.String.<init>:([BLjava/nio/charset/Charset;)V
        10: areturn
        end local 4 // java.lang.String e
        end local 3 // java.lang.Process p
        11: .line 276
      StackMap locals: java.lang.String[] java.io.ByteArrayOutputStream java.io.ByteArrayOutputStream
      StackMap stack: java.lang.Exception
            astore 3 /* e */
        start local 3 // java.lang.Exception e
        12: .line 277
            new java.lang.RuntimeException
            dup
            aload 3 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        end local 2 // java.io.ByteArrayOutputStream out
        end local 1 // java.io.ByteArrayOutputStream err
        end local 0 // java.lang.String[] args
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  args  [Ljava/lang/String;
            1   13     1   err  Ljava/io/ByteArrayOutputStream;
            2   13     2   out  Ljava/io/ByteArrayOutputStream;
            3   11     3     p  Ljava/lang/Process;
            7   11     4     e  Ljava/lang/String;
           12   13     3     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           2    10      11  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      args  

  private static void copyInThread(java.io.InputStream, java.io.OutputStream);
    descriptor: (Ljava/io/InputStream;Ljava/io/OutputStream;)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // java.io.InputStream in
        start local 1 // java.io.OutputStream out
         0: .line 283
            new org.h2.util.Profiler$1
            dup
            ldc "Profiler stream copy"
            aload 0 /* in */
            aload 1 /* out */
            invokespecial org.h2.util.Profiler$1.<init>:(Ljava/lang/String;Ljava/io/InputStream;Ljava/io/OutputStream;)V
         1: .line 299
            invokevirtual org.h2.util.Profiler$1.start:()V
         2: .line 300
            return
        end local 1 // java.io.OutputStream out
        end local 0 // java.io.InputStream in
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0    in  Ljava/io/InputStream;
            0    3     1   out  Ljava/io/OutputStream;
    MethodParameters:
      Name  Flags
      in    final
      out   final

  public org.h2.util.Profiler startCollecting();
    descriptor: ()Lorg/h2/util/Profiler;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.h2.util.Profiler this
         0: .line 308
            aload 0 /* this */
            new java.lang.Thread
            dup
            aload 0 /* this */
            ldc "Profiler"
            invokespecial java.lang.Thread.<init>:(Ljava/lang/Runnable;Ljava/lang/String;)V
            putfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
         1: .line 309
            aload 0 /* this */
            getfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
            iconst_1
            invokevirtual java.lang.Thread.setDaemon:(Z)V
         2: .line 310
            aload 0 /* this */
            getfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
            invokevirtual java.lang.Thread.start:()V
         3: .line 311
            aload 0 /* this */
            areturn
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/h2/util/Profiler;

  public org.h2.util.Profiler stopCollecting();
    descriptor: ()Lorg/h2/util/Profiler;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.h2.util.Profiler this
         0: .line 320
            aload 0 /* this */
            iconst_1
            putfield org.h2.util.Profiler.stop:Z
         1: .line 321
            aload 0 /* this */
            getfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
            ifnull 6
         2: .line 323
            aload 0 /* this */
            getfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
            invokevirtual java.lang.Thread.join:()V
         3: .line 324
            goto 5
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         4: pop
         5: .line 327
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield org.h2.util.Profiler.thread:Ljava/lang/Thread;
         6: .line 329
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            areturn
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/h2/util/Profiler;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.InterruptedException

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=1, args_size=1
        start local 0 // org.h2.util.Profiler this
         0: .line 334
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            putfield org.h2.util.Profiler.start:J
         1: .line 335
            goto 6
         2: .line 337
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.h2.util.Profiler.tick:()V
         3: .line 338
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Throwable
         4: pop
         5: .line 339
            goto 7
         6: .line 335
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.stop:Z
            ifeq 2
         7: .line 342
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokestatic java.lang.System.nanoTime:()J
            aload 0 /* this */
            getfield org.h2.util.Profiler.start:J
            lsub
            putfield org.h2.util.Profiler.time:J
         8: .line 343
            return
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/h2/util/Profiler;
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.Throwable

  private void tick();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.h2.util.Profiler this
         0: .line 346
            aload 0 /* this */
            getfield org.h2.util.Profiler.interval:I
            ifle 6
         1: .line 347
            aload 0 /* this */
            getfield org.h2.util.Profiler.paused:Z
            ifeq 3
         2: .line 348
            return
         3: .line 351
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.interval:I
            i2l
            iconst_0
            invokestatic java.lang.Thread.sleep:(JI)V
         4: .line 352
            goto 6
      StackMap locals:
      StackMap stack: java.lang.Exception
         5: pop
         6: .line 358
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.pid:I
            ifeq 9
         7: .line 359
            aload 0 /* this */
            getfield org.h2.util.Profiler.pid:I
            invokestatic org.h2.util.Profiler.readRunnableStackTraces:(I)Ljava/util/List;
            astore 1 /* list */
        start local 1 // java.util.List list
         8: .line 360
            goto 10
        end local 1 // java.util.List list
         9: .line 361
      StackMap locals:
      StackMap stack:
            invokestatic org.h2.util.Profiler.getRunnableStackTraces:()Ljava/util/List;
            astore 1 /* list */
        start local 1 // java.util.List list
        10: .line 363
      StackMap locals: java.util.List
      StackMap stack:
            aload 0 /* this */
            dup
            getfield org.h2.util.Profiler.threadDumps:I
            iconst_1
            iadd
            putfield org.h2.util.Profiler.threadDumps:I
        11: .line 364
            aload 0 /* this */
            aload 1 /* list */
            invokevirtual org.h2.util.Profiler.processList:(Ljava/util/List;)V
        12: .line 365
            return
        end local 1 // java.util.List list
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lorg/h2/util/Profiler;
            8    9     1  list  Ljava/util/List<[Ljava/lang/Object;>;
           10   13     1  list  Ljava/util/List<[Ljava/lang/Object;>;
      Exception table:
        from    to  target  type
           3     4       5  Class java.lang.Exception

  private void processList(java.util.List<java.lang.Object[]>);
    descriptor: (Ljava/util/List;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=12, args_size=2
        start local 0 // org.h2.util.Profiler this
        start local 1 // java.util.List list
         0: .line 368
            aload 1 /* list */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 43
      StackMap locals: org.h2.util.Profiler java.util.List top java.util.Iterator
      StackMap stack:
         1: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object[]
            astore 2 /* dump */
        start local 2 // java.lang.Object[] dump
         2: .line 369
            aload 2 /* dump */
            iconst_0
            aaload
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield org.h2.util.Profiler.ignoreThreads:[Ljava/lang/String;
            invokestatic org.h2.util.Profiler.startsWithAny:(Ljava/lang/String;[Ljava/lang/String;)Z
            ifeq 4
         3: .line 370
            goto 43
         4: .line 372
      StackMap locals: org.h2.util.Profiler java.util.List java.lang.Object[] java.util.Iterator
      StackMap stack:
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 4 /* buff */
        start local 4 // java.lang.StringBuilder buff
         5: .line 374
            aconst_null
            astore 5 /* last */
        start local 5 // java.lang.String last
         6: .line 375
            iconst_0
            istore 6 /* packageCounts */
        start local 6 // boolean packageCounts
         7: .line 376
            iconst_0
            istore 7 /* j */
        start local 7 // int j
         8: iconst_0
            istore 8 /* i */
        start local 8 // int i
         9: goto 39
        10: .line 377
      StackMap locals: org.h2.util.Profiler java.util.List java.lang.Object[] java.util.Iterator java.lang.StringBuilder java.lang.String int int int
      StackMap stack:
            aload 2 /* dump */
            iload 8 /* i */
            aaload
            invokevirtual java.lang.Object.toString:()Ljava/lang/String;
            astore 9 /* el */
        start local 9 // java.lang.String el
        11: .line 378
            aload 9 /* el */
            aload 5 /* last */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 38
            aload 9 /* el */
            aload 0 /* this */
            getfield org.h2.util.Profiler.ignoreLines:[Ljava/lang/String;
            invokestatic org.h2.util.Profiler.startsWithAny:(Ljava/lang/String;[Ljava/lang/String;)Z
            ifne 38
        12: .line 379
            aload 9 /* el */
            astore 5 /* last */
        13: .line 380
            aload 4 /* buff */
            ldc "at "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 9 /* el */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        14: .line 381
            iload 6 /* packageCounts */
            ifne 37
            aload 9 /* el */
            aload 0 /* this */
            getfield org.h2.util.Profiler.ignorePackages:[Ljava/lang/String;
            invokestatic org.h2.util.Profiler.startsWithAny:(Ljava/lang/String;[Ljava/lang/String;)Z
            ifne 37
        15: .line 382
            iconst_1
            istore 6 /* packageCounts */
        16: .line 383
            iconst_0
            istore 10 /* index */
        start local 10 // int index
        17: .line 384
            goto 22
        18: .line 385
      StackMap locals: java.lang.String int
      StackMap stack:
            aload 9 /* el */
            iload 10 /* index */
            invokevirtual java.lang.String.charAt:(I)C
            istore 11 /* c */
        start local 11 // char c
        19: .line 386
            iload 11 /* c */
            bipush 40
            if_icmpeq 23
            iload 11 /* c */
            invokestatic java.lang.Character.isUpperCase:(C)Z
            ifeq 21
        20: .line 387
            goto 23
        end local 11 // char c
        21: .line 384
      StackMap locals:
      StackMap stack:
            iinc 10 /* index */ 1
      StackMap locals:
      StackMap stack:
        22: iload 10 /* index */
            aload 9 /* el */
            invokevirtual java.lang.String.length:()I
            if_icmplt 18
        23: .line 390
      StackMap locals:
      StackMap stack:
            iload 10 /* index */
            ifle 25
            aload 9 /* el */
            iload 10 /* index */
            iconst_1
            isub
            invokevirtual java.lang.String.charAt:(I)C
            bipush 46
            if_icmpne 25
        24: .line 391
            iinc 10 /* index */ -1
        25: .line 393
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.sumClasses:Z
            ifeq 30
        26: .line 394
            aload 9 /* el */
            bipush 46
            iload 10 /* index */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            istore 11 /* m */
        start local 11 // int m
        27: .line 395
            iload 11 /* m */
            iflt 28
            iload 11 /* m */
            goto 29
      StackMap locals: int
      StackMap stack:
        28: iload 10 /* index */
      StackMap locals:
      StackMap stack: int
        29: istore 10 /* index */
        end local 11 // int m
        30: .line 397
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.sumMethods:Z
            ifeq 35
        31: .line 398
            aload 9 /* el */
            bipush 40
            iload 10 /* index */
            iconst_1
            iadd
            invokevirtual java.lang.String.indexOf:(II)I
            istore 11 /* m */
        start local 11 // int m
        32: .line 399
            iload 11 /* m */
            iflt 33
            iload 11 /* m */
            goto 34
      StackMap locals: int
      StackMap stack:
        33: iload 10 /* index */
      StackMap locals:
      StackMap stack: int
        34: istore 10 /* index */
        end local 11 // int m
        35: .line 401
      StackMap locals:
      StackMap stack:
            aload 9 /* el */
            iconst_0
            iload 10 /* index */
            invokevirtual java.lang.String.substring:(II)Ljava/lang/String;
            astore 11 /* groupName */
        start local 11 // java.lang.String groupName
        36: .line 402
            aload 0 /* this */
            getfield org.h2.util.Profiler.summary:Ljava/util/HashMap;
            aload 11 /* groupName */
            iconst_0
            invokestatic org.h2.util.Profiler.increment:(Ljava/util/HashMap;Ljava/lang/String;I)I
            pop
        end local 11 // java.lang.String groupName
        end local 10 // int index
        37: .line 404
      StackMap locals:
      StackMap stack:
            iinc 7 /* j */ 1
        end local 9 // java.lang.String el
        38: .line 376
      StackMap locals:
      StackMap stack:
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        39: iload 8 /* i */
            aload 2 /* dump */
            arraylength
            if_icmpge 40
            iload 7 /* j */
            aload 0 /* this */
            getfield org.h2.util.Profiler.depth:I
            if_icmplt 10
        end local 8 // int i
        end local 7 // int j
        40: .line 407
      StackMap locals:
      StackMap stack:
            aload 4 /* buff */
            invokevirtual java.lang.StringBuilder.length:()I
            ifle 43
        41: .line 408
            aload 0 /* this */
            aload 0 /* this */
            getfield org.h2.util.Profiler.counts:Ljava/util/HashMap;
            aload 4 /* buff */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.trim:()Ljava/lang/String;
            aload 0 /* this */
            getfield org.h2.util.Profiler.minCount:I
            invokestatic org.h2.util.Profiler.increment:(Ljava/util/HashMap;Ljava/lang/String;I)I
            putfield org.h2.util.Profiler.minCount:I
        42: .line 409
            aload 0 /* this */
            dup
            getfield org.h2.util.Profiler.total:I
            iconst_1
            iadd
            putfield org.h2.util.Profiler.total:I
        end local 6 // boolean packageCounts
        end local 5 // java.lang.String last
        end local 4 // java.lang.StringBuilder buff
        end local 2 // java.lang.Object[] dump
        43: .line 368
      StackMap locals: org.h2.util.Profiler java.util.List top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
        44: .line 412
            return
        end local 1 // java.util.List list
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   45     0           this  Lorg/h2/util/Profiler;
            0   45     1           list  Ljava/util/List<[Ljava/lang/Object;>;
            2   43     2           dump  [Ljava/lang/Object;
            5   43     4           buff  Ljava/lang/StringBuilder;
            6   43     5           last  Ljava/lang/String;
            7   43     6  packageCounts  Z
            8   40     7              j  I
            9   40     8              i  I
           11   38     9             el  Ljava/lang/String;
           17   37    10          index  I
           19   21    11              c  C
           27   30    11              m  I
           32   35    11              m  I
           36   37    11      groupName  Ljava/lang/String;
    Signature: (Ljava/util/List<[Ljava/lang/Object;>;)V
    MethodParameters:
      Name  Flags
      list  

  private static boolean startsWithAny(java.lang.String, java.lang.String[]);
    descriptor: (Ljava/lang/String;[Ljava/lang/String;)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=6, args_size=2
        start local 0 // java.lang.String s
        start local 1 // java.lang.String[] prefixes
         0: .line 415
            aload 1 /* prefixes */
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 5
      StackMap locals: java.lang.String java.lang.String[] top int int java.lang.String[]
      StackMap stack:
         1: aload 5
            iload 3
            aaload
            astore 2 /* p */
        start local 2 // java.lang.String p
         2: .line 416
            aload 2 /* p */
            invokevirtual java.lang.String.length:()I
            ifle 4
            aload 0 /* s */
            aload 2 /* p */
            invokevirtual java.lang.String.startsWith:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 417
            iconst_1
            ireturn
        end local 2 // java.lang.String p
         4: .line 415
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
         5: iload 3
            iload 4
            if_icmplt 1
         6: .line 420
            iconst_0
            ireturn
        end local 1 // java.lang.String[] prefixes
        end local 0 // java.lang.String s
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0         s  Ljava/lang/String;
            0    7     1  prefixes  [Ljava/lang/String;
            2    4     2         p  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      s         
      prefixes  

  private static int increment(java.util.HashMap<java.lang.String, java.lang.Integer>, java.lang.String, );
    descriptor: (Ljava/util/HashMap;Ljava/lang/String;I)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // java.util.HashMap map
        start local 1 // java.lang.String trace
        start local 2 // int minCount
         0: .line 425
            aload 0 /* map */
            aload 1 /* trace */
            invokevirtual java.util.HashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 3 /* oldCount */
        start local 3 // java.lang.Integer oldCount
         1: .line 426
            aload 3 /* oldCount */
            ifnonnull 4
         2: .line 427
            aload 0 /* map */
            aload 1 /* trace */
            iconst_1
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 428
            goto 15
         4: .line 429
      StackMap locals: java.lang.Integer
      StackMap stack:
            aload 0 /* map */
            aload 1 /* trace */
            aload 3 /* oldCount */
            invokevirtual java.lang.Integer.intValue:()I
            iconst_1
            iadd
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.util.HashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 431
            goto 15
         6: .line 433
      StackMap locals:
      StackMap stack:
            aload 0 /* map */
            invokevirtual java.util.HashMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
         7: .line 432
            astore 4 /* ei */
        start local 4 // java.util.Iterator ei
         8: .line 433
            goto 12
         9: .line 434
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 4 /* ei */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 5 /* e */
        start local 5 // java.util.Map$Entry e
        10: .line 435
            aload 5 /* e */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            iload 2 /* minCount */
            if_icmpgt 12
        11: .line 436
            aload 4 /* ei */
            invokeinterface java.util.Iterator.remove:()V
        end local 5 // java.util.Map$Entry e
        12: .line 433
      StackMap locals:
      StackMap stack:
            aload 4 /* ei */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        end local 4 // java.util.Iterator ei
        13: .line 439
            aload 0 /* map */
            invokevirtual java.util.HashMap.size:()I
            sipush 1000
            if_icmple 15
        14: .line 440
            iinc 2 /* minCount */ 1
        15: .line 431
      StackMap locals:
      StackMap stack:
            aload 0 /* map */
            invokevirtual java.util.HashMap.size:()I
            sipush 1000
            if_icmpgt 6
        16: .line 443
            iload 2 /* minCount */
            ireturn
        end local 3 // java.lang.Integer oldCount
        end local 2 // int minCount
        end local 1 // java.lang.String trace
        end local 0 // java.util.HashMap map
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   17     0       map  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;
            0   17     1     trace  Ljava/lang/String;
            0   17     2  minCount  I
            1   17     3  oldCount  Ljava/lang/Integer;
            8   13     4        ei  Ljava/util/Iterator<Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Integer;>;>;
           10   12     5         e  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Integer;>;
    Signature: (Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;Ljava/lang/String;I)I
    MethodParameters:
          Name  Flags
      map       
      trace     
      minCount  

  public java.lang.String getTop(int);
    descriptor: (I)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.util.Profiler this
        start local 1 // int count
         0: .line 453
            aload 0 /* this */
            invokevirtual org.h2.util.Profiler.stopCollecting:()Lorg/h2/util/Profiler;
            pop
         1: .line 454
            aload 0 /* this */
            iload 1 /* count */
            invokevirtual org.h2.util.Profiler.getTopTraces:(I)Ljava/lang/String;
            areturn
        end local 1 // int count
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lorg/h2/util/Profiler;
            0    2     1  count  I
    MethodParameters:
       Name  Flags
      count  

  private java.lang.String getTopTraces(int);
    descriptor: (I)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.h2.util.Profiler this
        start local 1 // int count
         0: .line 458
            new java.lang.StringBuilder
            dup
            invokespecial java.lang.StringBuilder.<init>:()V
            astore 2 /* buff */
        start local 2 // java.lang.StringBuilder buff
         1: .line 459
            aload 2 /* buff */
            ldc "Profiler: top "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            iload 1 /* count */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " stack trace(s) of "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         2: .line 460
            aload 0 /* this */
            getfield org.h2.util.Profiler.time:J
            lconst_0
            lcmp
            ifle 4
         3: .line 461
            aload 2 /* buff */
            ldc " of "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            aload 0 /* this */
            getfield org.h2.util.Profiler.time:J
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            ldc " ms"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         4: .line 463
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.util.Profiler.threadDumps:I
            ifle 6
         5: .line 464
            aload 2 /* buff */
            ldc " of "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield org.h2.util.Profiler.threadDumps:I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " thread dumps"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         6: .line 466
      StackMap locals:
      StackMap stack:
            aload 2 /* buff */
            ldc ":"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         7: .line 467
            aload 0 /* this */
            getfield org.h2.util.Profiler.counts:Ljava/util/HashMap;
            invokevirtual java.util.HashMap.size:()I
            ifne 9
         8: .line 468
            aload 2 /* buff */
            ldc "(none)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
         9: .line 470
      StackMap locals:
      StackMap stack:
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.h2.util.Profiler.counts:Ljava/util/HashMap;
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 3 /* copy */
        start local 3 // java.util.HashMap copy
        10: .line 471
            aload 2 /* buff */
            aload 3 /* copy */
            iload 1 /* count */
            aload 0 /* this */
            getfield org.h2.util.Profiler.total:I
            iconst_0
            invokestatic org.h2.util.Profiler.appendTop:(Ljava/lang/StringBuilder;Ljava/util/HashMap;IIZ)V
        11: .line 472
            aload 2 /* buff */
            ldc "summary:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        12: .line 473
            new java.util.HashMap
            dup
            aload 0 /* this */
            getfield org.h2.util.Profiler.summary:Ljava/util/HashMap;
            invokespecial java.util.HashMap.<init>:(Ljava/util/Map;)V
            astore 3 /* copy */
        13: .line 474
            aload 2 /* buff */
            aload 3 /* copy */
            iload 1 /* count */
            aload 0 /* this */
            getfield org.h2.util.Profiler.total:I
            iconst_1
            invokestatic org.h2.util.Profiler.appendTop:(Ljava/lang/StringBuilder;Ljava/util/HashMap;IIZ)V
        14: .line 475
            aload 2 /* buff */
            bipush 46
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        15: .line 476
            aload 2 /* buff */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            areturn
        end local 3 // java.util.HashMap copy
        end local 2 // java.lang.StringBuilder buff
        end local 1 // int count
        end local 0 // org.h2.util.Profiler this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   16     0   this  Lorg/h2/util/Profiler;
            0   16     1  count  I
            1   16     2   buff  Ljava/lang/StringBuilder;
           10   16     3   copy  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;
    MethodParameters:
       Name  Flags
      count  

  private static void appendTop(java.lang.StringBuilder, java.util.HashMap<java.lang.String, java.lang.Integer>, int, int, );
    descriptor: (Ljava/lang/StringBuilder;Ljava/util/HashMap;IIZ)V
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=11, args_size=5
        start local 0 // java.lang.StringBuilder buff
        start local 1 // java.util.HashMap map
        start local 2 // int count
        start local 3 // int total
        start local 4 // boolean table
         0: .line 481
            iconst_0
            istore 5 /* x */
        start local 5 // int x
         1: iconst_0
            istore 6 /* min */
        start local 6 // int min
         2: .line 482
      StackMap locals: int int
      StackMap stack:
            iconst_0
            istore 7 /* highest */
        start local 7 // int highest
         3: .line 483
            aconst_null
            astore 8 /* best */
        start local 8 // java.util.Map$Entry best
         4: .line 484
            aload 1 /* map */
            invokevirtual java.util.HashMap.entrySet:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 10
            goto 9
      StackMap locals: java.lang.StringBuilder java.util.HashMap int int int int int int java.util.Map$Entry top java.util.Iterator
      StackMap stack:
         5: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.Map$Entry
            astore 9 /* el */
        start local 9 // java.util.Map$Entry el
         6: .line 485
            aload 9 /* el */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            iload 7 /* highest */
            if_icmple 9
         7: .line 486
            aload 9 /* el */
            astore 8 /* best */
         8: .line 487
            aload 9 /* el */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 7 /* highest */
        end local 9 // java.util.Map$Entry el
         9: .line 484
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        10: .line 490
            aload 8 /* best */
            ifnonnull 12
        11: .line 491
            goto 31
        12: .line 493
      StackMap locals: java.lang.StringBuilder java.util.HashMap int int int int int int java.util.Map$Entry
      StackMap stack:
            aload 1 /* map */
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            invokevirtual java.util.HashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        13: .line 494
            iinc 5 /* x */ 1
            iload 5 /* x */
            iload 2 /* count */
            if_icmplt 17
        14: .line 495
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            iload 6 /* min */
            if_icmpge 16
        15: .line 496
            goto 31
        16: .line 498
      StackMap locals:
      StackMap stack:
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 6 /* min */
        17: .line 500
      StackMap locals:
      StackMap stack:
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
            checkcast java.lang.Integer
            invokevirtual java.lang.Integer.intValue:()I
            istore 9 /* c */
        start local 9 // int c
        18: .line 501
            bipush 100
            iload 9 /* c */
            imul
            iload 3 /* total */
            iconst_1
            invokestatic java.lang.Math.max:(II)I
            idiv
            istore 10 /* percent */
        start local 10 // int percent
        19: .line 502
            iload 4 /* table */
            ifeq 25
        20: .line 503
            iload 10 /* percent */
            iconst_1
            if_icmple 2
        21: .line 504
            aload 0 /* buff */
            iload 10 /* percent */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        22: .line 505
            ldc "%: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        23: .line 506
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        24: .line 508
            goto 2
        25: .line 509
      StackMap locals: int int
      StackMap stack:
            aload 0 /* buff */
            iload 9 /* c */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            bipush 47
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            iload 3 /* total */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " ("
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        26: .line 510
            iload 10 /* percent */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        27: .line 511
            ldc "%):"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        28: .line 512
            aload 8 /* best */
            invokeinterface java.util.Map$Entry.getKey:()Ljava/lang/Object;
            checkcast java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        29: .line 513
            getstatic org.h2.util.Profiler.LINE_SEPARATOR:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            pop
        end local 10 // int percent
        end local 9 // int c
        end local 8 // java.util.Map$Entry best
        end local 7 // int highest
        30: .line 481
            goto 2
        end local 6 // int min
        end local 5 // int x
        31: .line 516
      StackMap locals: java.lang.StringBuilder java.util.HashMap int int int
      StackMap stack:
            return
        end local 4 // boolean table
        end local 3 // int total
        end local 2 // int count
        end local 1 // java.util.HashMap map
        end local 0 // java.lang.StringBuilder buff
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   32     0     buff  Ljava/lang/StringBuilder;
            0   32     1      map  Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;
            0   32     2    count  I
            0   32     3    total  I
            0   32     4    table  Z
            1   31     5        x  I
            2   31     6      min  I
            3   30     7  highest  I
            4   30     8     best  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Integer;>;
            6    9     9       el  Ljava/util/Map$Entry<Ljava/lang/String;Ljava/lang/Integer;>;
           18   30     9        c  I
           19   30    10  percent  I
    Signature: (Ljava/lang/StringBuilder;Ljava/util/HashMap<Ljava/lang/String;Ljava/lang/Integer;>;IIZ)V
    MethodParameters:
       Name  Flags
      buff   
      map    
      count  
      total  
      table  
}
SourceFile: "Profiler.java"
NestMembers:
  org.h2.util.Profiler$1
InnerClasses:
  public final State = java.lang.Thread$State of java.lang.Thread
  public abstract Entry = java.util.Map$Entry of java.util.Map
  org.h2.util.Profiler$1