public class io.ebeaninternal.server.transaction.DefaultProfileHandler implements io.ebeaninternal.api.SpiProfileHandler, io.ebean.plugin.Plugin
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.ebeaninternal.server.transaction.DefaultProfileHandler
  super_class: java.lang.Object
{
  private static final org.slf4j.Logger log;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.time.format.DateTimeFormatter DTF;
    descriptor: Ljava/time/format/DateTimeFormatter;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final java.util.Queue<io.ebeaninternal.server.transaction.TransactionProfile> queue;
    descriptor: Ljava/util/Queue;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Queue<Lio/ebeaninternal/server/transaction/TransactionProfile;>;

  private final java.util.concurrent.ExecutorService executor;
    descriptor: Ljava/util/concurrent/ExecutorService;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.util.concurrent.locks.ReentrantLock lock;
    descriptor: Ljava/util/concurrent/locks/ReentrantLock;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.io.File dir;
    descriptor: Ljava/io/File;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

  private final boolean verbose;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

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

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

  private java.io.Writer out;
    descriptor: Ljava/io/Writer;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 43
            ldc Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
         1: .line 48
            new java.time.format.DateTimeFormatterBuilder
            dup
            invokespecial java.time.format.DateTimeFormatterBuilder.<init>:()V
         2: .line 49
            invokevirtual java.time.format.DateTimeFormatterBuilder.parseCaseInsensitive:()Ljava/time/format/DateTimeFormatterBuilder;
         3: .line 50
            getstatic java.time.temporal.ChronoField.YEAR:Ljava/time/temporal/ChronoField;
            iconst_4
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
         4: .line 51
            getstatic java.time.temporal.ChronoField.MONTH_OF_YEAR:Ljava/time/temporal/ChronoField;
            iconst_2
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
         5: .line 52
            getstatic java.time.temporal.ChronoField.DAY_OF_MONTH:Ljava/time/temporal/ChronoField;
            iconst_2
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
         6: .line 53
            bipush 45
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendLiteral:(C)Ljava/time/format/DateTimeFormatterBuilder;
         7: .line 54
            getstatic java.time.temporal.ChronoField.HOUR_OF_DAY:Ljava/time/temporal/ChronoField;
            iconst_2
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
         8: .line 55
            getstatic java.time.temporal.ChronoField.MINUTE_OF_HOUR:Ljava/time/temporal/ChronoField;
            iconst_2
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
         9: .line 56
            getstatic java.time.temporal.ChronoField.SECOND_OF_MINUTE:Ljava/time/temporal/ChronoField;
            iconst_2
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
        10: .line 57
            bipush 45
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendLiteral:(C)Ljava/time/format/DateTimeFormatterBuilder;
        11: .line 58
            getstatic java.time.temporal.ChronoField.MILLI_OF_SECOND:Ljava/time/temporal/ChronoField;
            iconst_3
            invokevirtual java.time.format.DateTimeFormatterBuilder.appendValue:(Ljava/time/temporal/TemporalField;I)Ljava/time/format/DateTimeFormatterBuilder;
        12: .line 59
            invokevirtual java.time.format.DateTimeFormatterBuilder.toFormatter:()Ljava/time/format/DateTimeFormatter;
        13: .line 48
            putstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.DTF:Ljava/time/format/DateTimeFormatter;
        14: .line 60
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(io.ebean.config.ProfilingConfig);
    descriptor: (Lio/ebean/config/ProfilingConfig;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebean.config.ProfilingConfig config
         0: .line 90
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 65
            aload 0 /* this */
            new java.util.concurrent.ConcurrentLinkedQueue
            dup
            invokespecial java.util.concurrent.ConcurrentLinkedQueue.<init>:()V
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
         2: .line 69
            aload 0 /* this */
            new java.util.concurrent.locks.ReentrantLock
            dup
            invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
         3: .line 91
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebean.config.ProfilingConfig.isVerbose:()Z
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
         4: .line 92
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebean.config.ProfilingConfig.getMinimumMicros:()J
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.minMicros:J
         5: .line 93
            aload 0 /* this */
            aload 1 /* config */
            invokevirtual io.ebean.config.ProfilingConfig.getProfilesPerFile:()J
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profilesPerFile:J
         6: .line 97
            aload 0 /* this */
            invokestatic java.util.concurrent.Executors.newSingleThreadExecutor:()Ljava/util/concurrent/ExecutorService;
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
         7: .line 98
            aload 0 /* this */
            new java.io.File
            dup
            aload 1 /* config */
            invokevirtual io.ebean.config.ProfilingConfig.getDirectory:()Ljava/lang/String;
            invokespecial java.io.File.<init>:(Ljava/lang/String;)V
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
         8: .line 99
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
            invokevirtual java.io.File.exists:()Z
            ifne 10
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
            invokevirtual java.io.File.mkdirs:()Z
            ifne 10
         9: .line 100
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            new java.lang.StringBuilder
            dup
            ldc "failed to mkdirs "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
            invokevirtual java.io.File.getAbsolutePath:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;)V
        10: .line 102
      StackMap locals: io.ebeaninternal.server.transaction.DefaultProfileHandler io.ebean.config.ProfilingConfig
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.incrementFile:()V
        11: .line 103
            return
        end local 1 // io.ebean.config.ProfilingConfig config
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   12     0    this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0   12     1  config  Lio/ebean/config/ProfilingConfig;
    MethodParameters:
        Name  Flags
      config  

  public void collectTransactionProfile(io.ebeaninternal.server.transaction.TransactionProfile);
    descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebeaninternal.server.transaction.TransactionProfile transactionProfile
         0: .line 111
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
            aload 1 /* transactionProfile */
            invokeinterface java.util.Queue.add:(Ljava/lang/Object;)Z
            pop
         1: .line 112
            return
        end local 1 // io.ebeaninternal.server.transaction.TransactionProfile transactionProfile
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    2     0                this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    2     1  transactionProfile  Lio/ebeaninternal/server/transaction/TransactionProfile;
    MethodParameters:
                    Name  Flags
      transactionProfile  

  public io.ebeaninternal.server.transaction.ProfileStream createProfileStream(io.ebean.ProfileLocation);
    descriptor: (Lio/ebean/ProfileLocation;)Lio/ebeaninternal/server/transaction/ProfileStream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebean.ProfileLocation location
         0: .line 119
            new io.ebeaninternal.server.transaction.DefaultProfileStream
            dup
            aload 1 /* location */
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
            invokespecial io.ebeaninternal.server.transaction.DefaultProfileStream.<init>:(Lio/ebean/ProfileLocation;Z)V
            areturn
        end local 1 // io.ebean.ProfileLocation location
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    1     1  location  Lio/ebean/ProfileLocation;
    MethodParameters:
          Name  Flags
      location  

  private void flushCurrentFile();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=1
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
         0: .line 123
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 125
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            ifnull 11
         2: .line 127
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            invokevirtual java.io.Writer.close:()V
         3: .line 128
            aload 0 /* this */
            aconst_null
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
         4: .line 129
            goto 11
      StackMap locals:
      StackMap stack: java.io.IOException
         5: astore 1 /* e */
        start local 1 // java.io.IOException e
         6: .line 130
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Failed to flush and close transaction profiling file "
            aload 1 /* e */
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 1 // java.io.IOException e
         7: .line 133
            goto 11
      StackMap locals:
      StackMap stack: java.lang.Throwable
         8: astore 2
         9: .line 134
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        10: .line 135
            aload 2
            athrow
        11: .line 134
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        12: .line 136
            return
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   13     0  this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            6    7     1     e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2     4       5  Class java.io.IOException
           1     8       8  any

  private void incrementFile();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=6, locals=4, args_size=1
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
         0: .line 142
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
         1: .line 144
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
         2: .line 146
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.DTF:Ljava/time/format/DateTimeFormatter;
            invokestatic java.time.LocalDateTime.now:()Ljava/time/LocalDateTime;
            invokevirtual java.time.format.DateTimeFormatter.format:(Ljava/time/temporal/TemporalAccessor;)Ljava/lang/String;
            astore 1 /* now */
        start local 1 // java.lang.String now
         3: .line 147
            new java.io.File
            dup
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.dir:Ljava/io/File;
            new java.lang.StringBuilder
            dup
            ldc "txprofile-"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* now */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ".tprofile"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.io.File.<init>:(Ljava/io/File;Ljava/lang/String;)V
            astore 2 /* file */
        start local 2 // java.io.File file
         4: .line 148
            aload 0 /* this */
            new java.io.BufferedWriter
            dup
            new java.io.FileWriter
            dup
            aload 2 /* file */
            invokespecial java.io.FileWriter.<init>:(Ljava/io/File;)V
            invokespecial java.io.BufferedWriter.<init>:(Ljava/io/Writer;)V
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
        end local 2 // java.io.File file
        end local 1 // java.lang.String now
         5: .line 149
            goto 12
      StackMap locals:
      StackMap stack: java.io.IOException
         6: astore 1 /* e */
        start local 1 // java.io.IOException e
         7: .line 150
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Not expected"
            aload 1 /* e */
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 1 // java.io.IOException e
         8: .line 152
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Throwable
         9: astore 3
        10: .line 153
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        11: .line 154
            aload 3
            athrow
        12: .line 153
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.lock:Ljava/util/concurrent/locks/ReentrantLock;
            invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
        13: .line 155
            return
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            3    5     1   now  Ljava/lang/String;
            4    5     2  file  Ljava/io/File;
            7    8     1     e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2     5       6  Class java.io.IOException
           1     9       9  any

  private void collect();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
         0: .line 162
            goto 7
         1: .line 163
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            checkcast io.ebeaninternal.server.transaction.TransactionProfile
            astore 1 /* profile */
        start local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
         2: .line 164
            aload 1 /* profile */
            ifnonnull 5
         3: .line 165
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.sleep:()V
         4: .line 167
            goto 7
      StackMap locals: io.ebeaninternal.server.transaction.TransactionProfile
      StackMap stack:
         5: aload 0 /* this */
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.include:(Lio/ebeaninternal/server/transaction/TransactionProfile;)Z
            ifeq 7
         6: .line 168
            aload 0 /* this */
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.write:(Lio/ebeaninternal/server/transaction/TransactionProfile;)V
        end local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
         7: .line 162
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.shutdown:Z
            ifeq 1
         8: .line 171
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
         9: .line 172
            goto 12
      StackMap locals:
      StackMap stack: java.lang.Exception
        10: astore 1 /* e */
        start local 1 // java.lang.Exception e
        11: .line 173
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Error on collect"
            aload 1 /* e */
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 1 // java.lang.Exception e
        12: .line 175
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   13     0     this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            2    7     1  profile  Lio/ebeaninternal/server/transaction/TransactionProfile;
           11   12     1        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           0     9      10  Class java.lang.Exception

  private void write(io.ebeaninternal.server.transaction.TransactionProfile);
    descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
         0: .line 182
            aload 0 /* this */
            iconst_0
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
         1: .line 183
            aload 0 /* this */
            dup
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
            lconst_1
            ladd
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
         2: .line 185
            new java.lang.StringBuilder
            dup
            bipush 80
            invokespecial java.lang.StringBuilder.<init>:(I)V
            astore 2 /* sb */
        start local 2 // java.lang.StringBuilder sb
         3: .line 188
            aload 2 /* sb */
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getStartTime:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         4: .line 189
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getLabel:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
         5: .line 190
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         6: .line 193
            aload 0 /* this */
            aload 1 /* profile */
            aload 2 /* sb */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.appendSummary:(Lio/ebeaninternal/server/transaction/TransactionProfile;Ljava/lang/StringBuilder;)V
         7: .line 195
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            aload 2 /* sb */
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.Writer.write:(Ljava/lang/String;)V
         8: .line 196
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.verbose:Z
            ifeq 11
         9: .line 197
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            bipush 32
            invokevirtual java.io.Writer.write:(I)V
        10: .line 198
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getData:()Ljava/lang/String;
            invokevirtual java.io.Writer.write:(Ljava/lang/String;)V
        11: .line 200
      StackMap locals: java.lang.StringBuilder
      StackMap stack:
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.out:Ljava/io/Writer;
            bipush 10
            invokevirtual java.io.Writer.write:(I)V
        12: .line 202
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profilesPerFile:J
            lrem
            lconst_0
            lcmp
            ifne 18
        13: .line 203
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.incrementFile:()V
        14: .line 204
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "profiled {} transactions"
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.profileCounter:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
        end local 2 // java.lang.StringBuilder sb
        15: .line 206
            goto 18
      StackMap locals: io.ebeaninternal.server.transaction.DefaultProfileHandler io.ebeaninternal.server.transaction.TransactionProfile
      StackMap stack: java.io.IOException
        16: astore 2 /* e */
        start local 2 // java.io.IOException e
        17: .line 207
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Error writing transaction profiling"
            aload 2 /* e */
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 2 // java.io.IOException e
        18: .line 209
      StackMap locals:
      StackMap stack:
            return
        end local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   19     0     this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0   19     1  profile  Lio/ebeaninternal/server/transaction/TransactionProfile;
            3   15     2       sb  Ljava/lang/StringBuilder;
           17   18     2        e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           0    15      16  Class java.io.IOException
    MethodParameters:
         Name  Flags
      profile  

  private void appendSummary(io.ebeaninternal.server.transaction.TransactionProfile, java.lang.StringBuilder);
    descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;Ljava/lang/StringBuilder;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=4, args_size=3
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
        start local 2 // java.lang.StringBuilder sb
         0: .line 213
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getSummary:()Lio/ebeaninternal/server/transaction/TransactionProfile$Summary;
            astore 3 /* summary */
        start local 3 // io.ebeaninternal.server.transaction.TransactionProfile$Summary summary
         1: .line 215
            aload 2 /* sb */
            ldc "z:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
            ladd
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         2: .line 216
            aload 2 /* sb */
            ldc "p:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistMicros:J
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         3: .line 217
            aload 2 /* sb */
            ldc "q:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMicros:J
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         4: .line 219
            aload 2 /* sb */
            ldc "qm:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMax:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         5: .line 220
            aload 2 /* sb */
            ldc "qt:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryMicros:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         6: .line 221
            aload 2 /* sb */
            ldc "qc:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryCount:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         7: .line 222
            aload 2 /* sb */
            ldc "qb:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.queryBeans:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         8: .line 224
            aload 2 /* sb */
            ldc "pt:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistMicros:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
         9: .line 225
            aload 2 /* sb */
            ldc "pc:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        10: .line 226
            aload 2 /* sb */
            ldc "pb:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        11: .line 227
            aload 2 /* sb */
            ldc "po:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistOneCount:J
            invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
            bipush 32
            invokevirtual java.lang.StringBuilder.append:(C)Ljava/lang/StringBuilder;
            pop
        12: .line 228
            aload 2 /* sb */
            ldc "pz:"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistBeans:J
            aload 3 /* summary */
            getfield io.ebeaninternal.server.transaction.TransactionProfile$Summary.persistCount:J
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.rate:(JJ)I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            pop
        13: .line 229
            return
        end local 3 // io.ebeaninternal.server.transaction.TransactionProfile$Summary summary
        end local 2 // java.lang.StringBuilder sb
        end local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   14     0     this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0   14     1  profile  Lio/ebeaninternal/server/transaction/TransactionProfile;
            0   14     2       sb  Ljava/lang/StringBuilder;
            1   14     3  summary  Lio/ebeaninternal/server/transaction/TransactionProfile$Summary;
    MethodParameters:
         Name  Flags
      profile  
      sb       

  private int rate(long, long);
    descriptor: (JJ)I
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=5, args_size=3
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // long micros
        start local 3 // long count
         0: .line 232
            lload 3 /* count */
            lconst_1
            lcmp
            ifge 1
            iconst_0
            goto 2
      StackMap locals:
      StackMap stack:
         1: lload 1 /* micros */
            lload 3 /* count */
            ldiv
            l2i
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 3 // long count
        end local 1 // long micros
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    3     1  micros  J
            0    3     3   count  J
    MethodParameters:
        Name  Flags
      micros  
      count   

  private boolean include(io.ebeaninternal.server.transaction.TransactionProfile);
    descriptor: (Lio/ebeaninternal/server/transaction/TransactionProfile;)Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
         0: .line 239
            aload 1 /* profile */
            invokevirtual io.ebeaninternal.server.transaction.TransactionProfile.getTotalMicros:()J
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.minMicros:J
            lcmp
            iflt 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // io.ebeaninternal.server.transaction.TransactionProfile profile
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    2     1  profile  Lio/ebeaninternal/server/transaction/TransactionProfile;
    MethodParameters:
         Name  Flags
      profile  

  private void sleep();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
         0: .line 249
            aload 0 /* this */
            dup
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
            iconst_1
            iadd
            dup_x1
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.sleepBackoff:I
            sipush 250
            invokestatic java.lang.Math.min:(II)I
            istore 1 /* sleepFor */
        start local 1 // int sleepFor
         1: .line 250
            iload 1 /* sleepFor */
            i2l
            invokestatic java.lang.Thread.sleep:(J)V
        end local 1 // int sleepFor
         2: .line 251
            goto 5
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         3: pop
         4: .line 252
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
         5: .line 254
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    6     0      this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            1    2     1  sleepFor  I
      Exception table:
        from    to  target  type
           0     2       3  Class java.lang.InterruptedException

  public void configure(io.ebean.plugin.SpiServer);
    descriptor: (Lio/ebean/plugin/SpiServer;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // io.ebean.plugin.SpiServer server
         0: .line 259
            return
        end local 1 // io.ebean.plugin.SpiServer server
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    1     1  server  Lio/ebean/plugin/SpiServer;
    MethodParameters:
        Name  Flags
      server  

  public void online(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
        start local 1 // boolean online
         0: .line 263
            iload 1 /* online */
            ifeq 2
         1: .line 264
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
            aload 0 /* this */
            invokedynamic run(Lio/ebeaninternal/server/transaction/DefaultProfileHandler;)Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  io/ebeaninternal/server/transaction/DefaultProfileHandler.collect()V (7)
                  ()V
            invokeinterface java.util.concurrent.ExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            pop
         2: .line 266
      StackMap locals:
      StackMap stack:
            return
        end local 1 // boolean online
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    3     0    this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            0    3     1  online  Z
    MethodParameters:
        Name  Flags
      online  

  public void shutdown();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
         0: .line 270
            aload 0 /* this */
            iconst_1
            putfield io.ebeaninternal.server.transaction.DefaultProfileHandler.shutdown:Z
         1: .line 271
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "shutting down"
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
         2: .line 273
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
         3: .line 274
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
            ldc 4
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface java.util.concurrent.ExecutorService.awaitTermination:(JLjava/util/concurrent/TimeUnit;)Z
            ifne 10
         4: .line 275
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Shut down timeout exceeded. Terminating profiling consumer thread."
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;)V
         5: .line 276
            aload 0 /* this */
            getfield io.ebeaninternal.server.transaction.DefaultProfileHandler.executor:Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdownNow:()Ljava/util/List;
            pop
         6: .line 278
            goto 10
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
         7: astore 1 /* e */
        start local 1 // java.lang.InterruptedException e
         8: .line 279
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
         9: .line 280
            getstatic io.ebeaninternal.server.transaction.DefaultProfileHandler.log:Lorg/slf4j/Logger;
            ldc "Interrupt on shutdown"
            aload 1 /* e */
            invokeinterface org.slf4j.Logger.warn:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 1 // java.lang.InterruptedException e
        10: .line 282
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.ebeaninternal.server.transaction.DefaultProfileHandler.flushCurrentFile:()V
        11: .line 283
            return
        end local 0 // io.ebeaninternal.server.transaction.DefaultProfileHandler this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lio/ebeaninternal/server/transaction/DefaultProfileHandler;
            8   10     1     e  Ljava/lang/InterruptedException;
      Exception table:
        from    to  target  type
           2     6       7  Class java.lang.InterruptedException
}
SourceFile: "DefaultProfileHandler.java"
InnerClasses:
  public Summary = io.ebeaninternal.server.transaction.TransactionProfile$Summary of io.ebeaninternal.server.transaction.TransactionProfile
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles