final class org.h2.table.JoinBatch$QueryRunner extends org.h2.table.JoinBatch$QueryRunnerBase
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: org.h2.table.JoinBatch$QueryRunner
  super_class: org.h2.table.JoinBatch$QueryRunnerBase
{
  java.util.concurrent.Future<org.h2.index.Cursor> topFutureCursor;
    descriptor: Ljava/util/concurrent/Future;
    flags: (0x0000) 
    Signature: Ljava/util/concurrent/Future<Lorg/h2/index/Cursor;>;

  final org.h2.table.JoinBatch this$0;
    descriptor: Lorg/h2/table/JoinBatch;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(org.h2.table.JoinBatch, org.h2.index.ViewIndex);
    descriptor: (Lorg/h2/table/JoinBatch;Lorg/h2/index/ViewIndex;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.h2.table.JoinBatch$QueryRunner this
        start local 2 // org.h2.index.ViewIndex viewIndex
         0: .line 945
            aload 0 /* this */
            aload 1
            putfield org.h2.table.JoinBatch$QueryRunner.this$0:Lorg/h2/table/JoinBatch;
         1: .line 946
            aload 0 /* this */
            aload 2 /* viewIndex */
            invokespecial org.h2.table.JoinBatch$QueryRunnerBase.<init>:(Lorg/h2/index/ViewIndex;)V
         2: .line 947
            return
        end local 2 // org.h2.index.ViewIndex viewIndex
        end local 0 // org.h2.table.JoinBatch$QueryRunner this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lorg/h2/table/JoinBatch$QueryRunner;
            0    3     2  viewIndex  Lorg/h2/index/ViewIndex;
    MethodParameters:
           Name  Flags
      this$0     final
      viewIndex  

  protected void clear();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunner this
         0: .line 951
            aload 0 /* this */
            invokespecial org.h2.table.JoinBatch$QueryRunnerBase.clear:()V
         1: .line 952
            aload 0 /* this */
            aconst_null
            putfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
         2: .line 953
            return
        end local 0 // org.h2.table.JoinBatch$QueryRunner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/h2/table/JoinBatch$QueryRunner;

  protected org.h2.index.Cursor run();
    descriptor: ()Lorg/h2/index/Cursor;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=4, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunner this
         0: .line 957
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
            ifnonnull 2
         1: .line 960
            getstatic org.h2.table.JoinBatch.EMPTY_CURSOR:Lorg/h2/index/Cursor;
            areturn
         2: .line 962
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.viewIndex:Lorg/h2/index/ViewIndex;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.viewIndex:Lorg/h2/index/ViewIndex;
            invokevirtual org.h2.index.ViewIndex.getSession:()Lorg/h2/engine/Session;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.first:Lorg/h2/result/SearchRow;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.last:Lorg/h2/result/SearchRow;
            aconst_null
            invokevirtual org.h2.index.ViewIndex.setupQueryParameters:(Lorg/h2/engine/Session;Lorg/h2/result/SearchRow;Lorg/h2/result/SearchRow;Lorg/h2/result/SearchRow;)V
         3: .line 963
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.this$0:Lorg/h2/table/JoinBatch;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
            putfield org.h2.table.JoinBatch.viewTopFutureCursor:Ljava/util/concurrent/Future;
         4: .line 965
            iconst_0
            istore 2 /* lazy */
        start local 2 // boolean lazy
         5: .line 967
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.viewIndex:Lorg/h2/index/ViewIndex;
            invokevirtual org.h2.index.ViewIndex.getQuery:()Lorg/h2/command/dml/Query;
            iconst_0
            invokevirtual org.h2.command.dml.Query.query:(I)Lorg/h2/result/ResultInterface;
            astore 1 /* localResult */
        start local 1 // org.h2.result.ResultInterface localResult
         6: .line 968
            aload 1 /* localResult */
            invokeinterface org.h2.result.ResultInterface.isLazy:()Z
            istore 2 /* lazy */
         7: .line 969
            goto 12
        end local 1 // org.h2.result.ResultInterface localResult
      StackMap locals: org.h2.table.JoinBatch$QueryRunner top int
      StackMap stack: java.lang.Throwable
         8: astore 3
         9: .line 970
            iload 2 /* lazy */
            ifne 11
        10: .line 971
            aload 0 /* this */
            invokevirtual org.h2.table.JoinBatch$QueryRunner.resetViewTopFutureCursorAfterQuery:()V
        11: .line 973
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 3
            athrow
        start local 1 // org.h2.result.ResultInterface localResult
        12: .line 970
      StackMap locals: org.h2.table.JoinBatch$QueryRunner org.h2.result.ResultInterface int
      StackMap stack:
            iload 2 /* lazy */
            ifne 14
        13: .line 971
            aload 0 /* this */
            invokevirtual org.h2.table.JoinBatch$QueryRunner.resetViewTopFutureCursorAfterQuery:()V
        14: .line 974
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* localResult */
            invokevirtual org.h2.table.JoinBatch$QueryRunner.newCursor:(Lorg/h2/result/ResultInterface;)Lorg/h2/index/ViewCursor;
            areturn
        end local 2 // boolean lazy
        end local 1 // org.h2.result.ResultInterface localResult
        end local 0 // org.h2.table.JoinBatch$QueryRunner this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   15     0         this  Lorg/h2/table/JoinBatch$QueryRunner;
            6    8     1  localResult  Lorg/h2/result/ResultInterface;
           12   15     1  localResult  Lorg/h2/result/ResultInterface;
            5   15     2         lazy  Z
      Exception table:
        from    to  target  type
           5     8       8  any
    Exceptions:
      throws java.lang.Exception

  protected void resetViewTopFutureCursorAfterQuery();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunner this
         0: .line 979
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunner.this$0:Lorg/h2/table/JoinBatch;
            aconst_null
            putfield org.h2.table.JoinBatch.viewTopFutureCursor:Ljava/util/concurrent/Future;
         1: .line 980
            return
        end local 0 // org.h2.table.JoinBatch$QueryRunner this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/h2/table/JoinBatch$QueryRunner;

  protected java.lang.Object run();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1044) ACC_PROTECTED, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual org.h2.table.JoinBatch$QueryRunner.run:()Lorg/h2/index/Cursor;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception
}
SourceFile: "JoinBatch.java"
NestHost: org.h2.table.JoinBatch
InnerClasses:
  private final QueryRunner = org.h2.table.JoinBatch$QueryRunner of org.h2.table.JoinBatch
  private abstract QueryRunnerBase = org.h2.table.JoinBatch$QueryRunnerBase of org.h2.table.JoinBatch