public class io.ebeaninternal.server.query.CQueryPlanManager implements io.ebeaninternal.api.QueryPlanManager
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.ebeaninternal.server.query.CQueryPlanManager
  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.lang.Object dummy;
    descriptor: Ljava/lang/Object;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final java.util.concurrent.ConcurrentHashMap<io.ebeaninternal.server.query.CQueryBindCapture, java.lang.Object> plans;
    descriptor: Ljava/util/concurrent/ConcurrentHashMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentHashMap<Lio/ebeaninternal/server/query/CQueryBindCapture;Ljava/lang/Object;>;

  private final io.ebeaninternal.server.transaction.TransactionManager transactionManager;
    descriptor: Lio/ebeaninternal/server/transaction/TransactionManager;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  private final io.ebeaninternal.server.query.QueryPlanLogger planLogger;
    descriptor: Lio/ebeaninternal/server/query/QueryPlanLogger;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final io.ebean.metric.TimedMetric timeCollection;
    descriptor: Lio/ebean/metric/TimedMetric;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final io.ebean.metric.TimedMetric timeBindCapture;
    descriptor: Lio/ebean/metric/TimedMetric;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 25
            ldc Lio/ebeaninternal/server/query/CQueryPlanManager;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic io.ebeaninternal.server.query.CQueryPlanManager.log:Lorg/slf4j/Logger;
         1: .line 27
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putstatic io.ebeaninternal.server.query.CQueryPlanManager.dummy:Ljava/lang/Object;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(io.ebeaninternal.server.transaction.TransactionManager, long, io.ebeaninternal.server.query.QueryPlanLogger, io.ebeaninternal.api.ExtraMetrics);
    descriptor: (Lio/ebeaninternal/server/transaction/TransactionManager;JLio/ebeaninternal/server/query/QueryPlanLogger;Lio/ebeaninternal/api/ExtraMetrics;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=5
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // io.ebeaninternal.server.transaction.TransactionManager transactionManager
        start local 2 // long defaultThreshold
        start local 4 // io.ebeaninternal.server.query.QueryPlanLogger planLogger
        start local 5 // io.ebeaninternal.api.ExtraMetrics extraMetrics
         0: .line 41
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 29
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield io.ebeaninternal.server.query.CQueryPlanManager.plans:Ljava/util/concurrent/ConcurrentHashMap;
         2: .line 42
            aload 0 /* this */
            aload 1 /* transactionManager */
            putfield io.ebeaninternal.server.query.CQueryPlanManager.transactionManager:Lio/ebeaninternal/server/transaction/TransactionManager;
         3: .line 43
            aload 0 /* this */
            lload 2 /* defaultThreshold */
            putfield io.ebeaninternal.server.query.CQueryPlanManager.defaultThreshold:J
         4: .line 44
            aload 0 /* this */
            aload 4 /* planLogger */
            putfield io.ebeaninternal.server.query.CQueryPlanManager.planLogger:Lio/ebeaninternal/server/query/QueryPlanLogger;
         5: .line 45
            aload 0 /* this */
            aload 5 /* extraMetrics */
            invokevirtual io.ebeaninternal.api.ExtraMetrics.getPlanCollect:()Lio/ebean/metric/TimedMetric;
            putfield io.ebeaninternal.server.query.CQueryPlanManager.timeCollection:Lio/ebean/metric/TimedMetric;
         6: .line 46
            aload 0 /* this */
            aload 5 /* extraMetrics */
            invokevirtual io.ebeaninternal.api.ExtraMetrics.getBindCapture:()Lio/ebean/metric/TimedMetric;
            putfield io.ebeaninternal.server.query.CQueryPlanManager.timeBindCapture:Lio/ebean/metric/TimedMetric;
         7: .line 47
            return
        end local 5 // io.ebeaninternal.api.ExtraMetrics extraMetrics
        end local 4 // io.ebeaninternal.server.query.QueryPlanLogger planLogger
        end local 2 // long defaultThreshold
        end local 1 // io.ebeaninternal.server.transaction.TransactionManager transactionManager
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    8     0                this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0    8     1  transactionManager  Lio/ebeaninternal/server/transaction/TransactionManager;
            0    8     2    defaultThreshold  J
            0    8     4          planLogger  Lio/ebeaninternal/server/query/QueryPlanLogger;
            0    8     5        extraMetrics  Lio/ebeaninternal/api/ExtraMetrics;
    MethodParameters:
                    Name  Flags
      transactionManager  
      defaultThreshold    
      planLogger          
      extraMetrics        

  public io.ebeaninternal.api.SpiQueryBindCapture createBindCapture(io.ebeaninternal.api.SpiQueryPlan);
    descriptor: (Lio/ebeaninternal/api/SpiQueryPlan;)Lio/ebeaninternal/api/SpiQueryBindCapture;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // io.ebeaninternal.api.SpiQueryPlan queryPlan
         0: .line 51
            new io.ebeaninternal.server.query.CQueryBindCapture
            dup
            aload 0 /* this */
            aload 1 /* queryPlan */
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.defaultThreshold:J
            invokespecial io.ebeaninternal.server.query.CQueryBindCapture.<init>:(Lio/ebeaninternal/server/query/CQueryPlanManager;Lio/ebeaninternal/api/SpiQueryPlan;J)V
            areturn
        end local 1 // io.ebeaninternal.api.SpiQueryPlan queryPlan
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    1     0       this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0    1     1  queryPlan  Lio/ebeaninternal/api/SpiQueryPlan;
    MethodParameters:
           Name  Flags
      queryPlan  

  public void notifyBindCapture(io.ebeaninternal.server.query.CQueryBindCapture, long);
    descriptor: (Lio/ebeaninternal/server/query/CQueryBindCapture;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // io.ebeaninternal.server.query.CQueryBindCapture planBind
        start local 2 // long startNanos
         0: .line 55
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.plans:Ljava/util/concurrent/ConcurrentHashMap;
            aload 1 /* planBind */
            getstatic io.ebeaninternal.server.query.CQueryPlanManager.dummy:Ljava/lang/Object;
            invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 56
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.timeBindCapture:Lio/ebean/metric/TimedMetric;
            lload 2 /* startNanos */
            invokeinterface io.ebean.metric.TimedMetric.addSinceNanos:(J)V
         2: .line 57
            return
        end local 2 // long startNanos
        end local 1 // io.ebeaninternal.server.query.CQueryBindCapture planBind
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    3     0        this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0    3     1    planBind  Lio/ebeaninternal/server/query/CQueryBindCapture;
            0    3     2  startNanos  J
    MethodParameters:
            Name  Flags
      planBind    
      startNanos  

  public java.util.List<io.ebean.meta.MetaQueryPlan> collect(io.ebean.meta.QueryPlanRequest);
    descriptor: (Lio/ebean/meta/QueryPlanRequest;)Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // io.ebean.meta.QueryPlanRequest request
         0: .line 61
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.plans:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.isEmpty:()Z
            ifeq 2
         1: .line 62
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
         2: .line 64
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* request */
            invokevirtual io.ebeaninternal.server.query.CQueryPlanManager.collectPlans:(Lio/ebean/meta/QueryPlanRequest;)Ljava/util/List;
            areturn
        end local 1 // io.ebean.meta.QueryPlanRequest request
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0    3     1  request  Lio/ebean/meta/QueryPlanRequest;
    Signature: (Lio/ebean/meta/QueryPlanRequest;)Ljava/util/List<Lio/ebean/meta/MetaQueryPlan;>;
    MethodParameters:
         Name  Flags
      request  

  private java.util.List<io.ebean.meta.MetaQueryPlan> collectPlans(io.ebean.meta.QueryPlanRequest);
    descriptor: (Lio/ebean/meta/QueryPlanRequest;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // io.ebean.meta.QueryPlanRequest request
         0: .line 68
            aconst_null
            astore 2
            aconst_null
            astore 3
         1: aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.transactionManager:Lio/ebeaninternal/server/transaction/TransactionManager;
            invokevirtual io.ebeaninternal.server.transaction.TransactionManager.getQueryPlanConnection:()Ljava/sql/Connection;
            astore 4 /* connection */
        start local 4 // java.sql.Connection connection
         2: .line 69
            new io.ebeaninternal.server.query.CQueryPlanRequest
            dup
            aload 4 /* connection */
            aload 1 /* request */
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.plans:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.keySet:()Ljava/util/concurrent/ConcurrentHashMap$KeySetView;
            invokevirtual java.util.concurrent.ConcurrentHashMap$KeySetView.iterator:()Ljava/util/Iterator;
            invokespecial io.ebeaninternal.server.query.CQueryPlanRequest.<init>:(Ljava/sql/Connection;Lio/ebean/meta/QueryPlanRequest;Ljava/util/Iterator;)V
            astore 5 /* req */
        start local 5 // io.ebeaninternal.server.query.CQueryPlanRequest req
         3: .line 70
            goto 5
         4: .line 71
      StackMap locals: io.ebeaninternal.server.query.CQueryPlanManager io.ebean.meta.QueryPlanRequest java.lang.Throwable java.lang.Throwable java.sql.Connection io.ebeaninternal.server.query.CQueryPlanRequest
      StackMap stack:
            aload 5 /* req */
            invokevirtual io.ebeaninternal.server.query.CQueryPlanRequest.nextCapture:()V
         5: .line 70
      StackMap locals:
      StackMap stack:
            aload 5 /* req */
            invokevirtual io.ebeaninternal.server.query.CQueryPlanRequest.hasNext:()Z
            ifne 4
         6: .line 73
            aload 5 /* req */
            invokevirtual io.ebeaninternal.server.query.CQueryPlanRequest.getPlans:()Ljava/util/List;
         7: .line 74
            aload 4 /* connection */
            ifnull 8
            aload 4 /* connection */
            invokeinterface java.sql.Connection.close:()V
         8: .line 73
      StackMap locals:
      StackMap stack: java.util.List
            areturn
        end local 5 // io.ebeaninternal.server.query.CQueryPlanRequest req
      StackMap locals: io.ebeaninternal.server.query.CQueryPlanManager io.ebean.meta.QueryPlanRequest java.lang.Throwable java.lang.Throwable java.sql.Connection
      StackMap stack: java.lang.Throwable
         9: astore 2
        10: .line 74
            aload 4 /* connection */
            ifnull 11
            aload 4 /* connection */
            invokeinterface java.sql.Connection.close:()V
        end local 4 // java.sql.Connection connection
      StackMap locals:
      StackMap stack:
        11: aload 2
            athrow
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: astore 3
            aload 2
            ifnonnull 13
            aload 3
            astore 2
            goto 14
      StackMap locals:
      StackMap stack:
        13: aload 2
            aload 3
            if_acmpeq 14
            aload 2
            aload 3
            invokevirtual java.lang.Throwable.addSuppressed:(Ljava/lang/Throwable;)V
      StackMap locals:
      StackMap stack:
        14: aload 2
            athrow
      StackMap locals: io.ebeaninternal.server.query.CQueryPlanManager io.ebean.meta.QueryPlanRequest
      StackMap stack: java.sql.SQLException
        15: astore 2 /* e */
        start local 2 // java.sql.SQLException e
        16: .line 75
            getstatic io.ebeaninternal.server.query.CQueryPlanManager.log:Lorg/slf4j/Logger;
            ldc "Error during query plan collection"
            aload 2 /* e */
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        17: .line 76
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            areturn
        end local 2 // java.sql.SQLException e
        end local 1 // io.ebean.meta.QueryPlanRequest request
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   18     0        this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0   18     1     request  Lio/ebean/meta/QueryPlanRequest;
            2   11     4  connection  Ljava/sql/Connection;
            3    9     5         req  Lio/ebeaninternal/server/query/CQueryPlanRequest;
           16   18     2           e  Ljava/sql/SQLException;
      Exception table:
        from    to  target  type
           2     7       9  any
           1     8      12  any
           9    12      12  any
           0     8      15  Class java.sql.SQLException
           9    15      15  Class java.sql.SQLException
    Signature: (Lio/ebean/meta/QueryPlanRequest;)Ljava/util/List<Lio/ebean/meta/MetaQueryPlan;>;
    MethodParameters:
         Name  Flags
      request  

  public io.ebeaninternal.api.SpiDbQueryPlan collectPlan(java.sql.Connection, io.ebeaninternal.api.SpiQueryPlan, io.ebeaninternal.server.type.bindcapture.BindCapture);
    descriptor: (Ljava/sql/Connection;Lio/ebeaninternal/api/SpiQueryPlan;Lio/ebeaninternal/server/type/bindcapture/BindCapture;)Lio/ebeaninternal/api/SpiDbQueryPlan;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=4
        start local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
        start local 1 // java.sql.Connection connection
        start local 2 // io.ebeaninternal.api.SpiQueryPlan queryPlan
        start local 3 // io.ebeaninternal.server.type.bindcapture.BindCapture last
         0: .line 81
            invokestatic java.lang.System.nanoTime:()J
            lstore 4 /* startNanos */
        start local 4 // long startNanos
         1: .line 83
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.planLogger:Lio/ebeaninternal/server/query/QueryPlanLogger;
            aload 1 /* connection */
            aload 2 /* queryPlan */
            aload 3 /* last */
            invokevirtual io.ebeaninternal.server.query.QueryPlanLogger.collectPlan:(Ljava/sql/Connection;Lio/ebeaninternal/api/SpiQueryPlan;Lio/ebeaninternal/server/type/bindcapture/BindCapture;)Lio/ebeaninternal/api/SpiDbQueryPlan;
            astore 7
         2: .line 85
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.timeCollection:Lio/ebean/metric/TimedMetric;
            lload 4 /* startNanos */
            invokeinterface io.ebean.metric.TimedMetric.addSinceNanos:(J)V
         3: .line 83
            aload 7
            areturn
         4: .line 84
      StackMap locals: io.ebeaninternal.server.query.CQueryPlanManager java.sql.Connection io.ebeaninternal.api.SpiQueryPlan io.ebeaninternal.server.type.bindcapture.BindCapture long
      StackMap stack: java.lang.Throwable
            astore 6
         5: .line 85
            aload 0 /* this */
            getfield io.ebeaninternal.server.query.CQueryPlanManager.timeCollection:Lio/ebean/metric/TimedMetric;
            lload 4 /* startNanos */
            invokeinterface io.ebean.metric.TimedMetric.addSinceNanos:(J)V
         6: .line 86
            aload 6
            athrow
        end local 4 // long startNanos
        end local 3 // io.ebeaninternal.server.type.bindcapture.BindCapture last
        end local 2 // io.ebeaninternal.api.SpiQueryPlan queryPlan
        end local 1 // java.sql.Connection connection
        end local 0 // io.ebeaninternal.server.query.CQueryPlanManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lio/ebeaninternal/server/query/CQueryPlanManager;
            0    7     1  connection  Ljava/sql/Connection;
            0    7     2   queryPlan  Lio/ebeaninternal/api/SpiQueryPlan;
            0    7     3        last  Lio/ebeaninternal/server/type/bindcapture/BindCapture;
            1    7     4  startNanos  J
      Exception table:
        from    to  target  type
           1     2       4  any
    MethodParameters:
            Name  Flags
      connection  
      queryPlan   
      last        
}
SourceFile: "CQueryPlanManager.java"
InnerClasses:
  public KeySetView = java.util.concurrent.ConcurrentHashMap$KeySetView of java.util.concurrent.ConcurrentHashMap