class org.h2.table.JoinBatch$QueryRunnerUnion extends org.h2.table.JoinBatch$QueryRunnerBase
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.h2.table.JoinBatch$QueryRunnerUnion
  super_class: org.h2.table.JoinBatch$QueryRunnerBase
{
  final java.util.concurrent.Future<org.h2.index.Cursor>[] topFutureCursors;
    descriptor: [Ljava/util/concurrent/Future;
    flags: (0x0010) ACC_FINAL
    Signature: [Ljava/util/concurrent/Future<Lorg/h2/index/Cursor;>;

  private final org.h2.table.JoinBatch$ViewIndexLookupBatchUnion batchUnion;
    descriptor: Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 1076
            ldc Lorg/h2/table/JoinBatch;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.h2.table.JoinBatch$QueryRunnerUnion.$assertionsDisabled:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(org.h2.table.JoinBatch$ViewIndexLookupBatchUnion);
    descriptor: (Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
        start local 1 // org.h2.table.JoinBatch$ViewIndexLookupBatchUnion batchUnion
         0: .line 1082
            aload 0 /* this */
            aload 1 /* batchUnion */
            getfield org.h2.table.JoinBatch$ViewIndexLookupBatchUnion.viewIndex:Lorg/h2/index/ViewIndex;
            invokespecial org.h2.table.JoinBatch$QueryRunnerBase.<init>:(Lorg/h2/index/ViewIndex;)V
         1: .line 1083
            aload 0 /* this */
            aload 1 /* batchUnion */
            putfield org.h2.table.JoinBatch$QueryRunnerUnion.batchUnion:Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;
         2: .line 1084
            aload 0 /* this */
            aload 1 /* batchUnion */
            getfield org.h2.table.JoinBatch$ViewIndexLookupBatchUnion.filters:Ljava/util/ArrayList;
            invokevirtual java.util.ArrayList.size:()I
            anewarray java.util.concurrent.Future
            putfield org.h2.table.JoinBatch$QueryRunnerUnion.topFutureCursors:[Ljava/util/concurrent/Future;
         3: .line 1085
            return
        end local 1 // org.h2.table.JoinBatch$ViewIndexLookupBatchUnion batchUnion
        end local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lorg/h2/table/JoinBatch$QueryRunnerUnion;
            0    4     1  batchUnion  Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;
    MethodParameters:
            Name  Flags
      batchUnion  

  protected void clear();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
         0: .line 1089
            aload 0 /* this */
            invokespecial org.h2.table.JoinBatch$QueryRunnerBase.clear:()V
         1: .line 1090
            iconst_0
            istore 1 /* i */
        start local 1 // int i
         2: goto 5
         3: .line 1091
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.topFutureCursors:[Ljava/util/concurrent/Future;
            iload 1 /* i */
            aconst_null
            aastore
         4: .line 1090
            iinc 1 /* i */ 1
      StackMap locals:
      StackMap stack:
         5: iload 1 /* i */
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.topFutureCursors:[Ljava/util/concurrent/Future;
            arraylength
            if_icmplt 3
        end local 1 // int i
         6: .line 1093
            return
        end local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lorg/h2/table/JoinBatch$QueryRunnerUnion;
            2    6     1     i  I

  protected org.h2.index.Cursor run();
    descriptor: ()Lorg/h2/index/Cursor;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=5, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
         0: .line 1097
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.viewIndex:Lorg/h2/index/ViewIndex;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.viewIndex:Lorg/h2/index/ViewIndex;
            invokevirtual org.h2.index.ViewIndex.getSession:()Lorg/h2/engine/Session;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.first:Lorg/h2/result/SearchRow;
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.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
         1: .line 1098
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.batchUnion:Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;
            getfield org.h2.table.JoinBatch$ViewIndexLookupBatchUnion.joinBatches:Ljava/util/ArrayList;
            astore 1 /* joinBatches */
        start local 1 // java.util.ArrayList joinBatches
         2: .line 1099
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         3: aload 1 /* joinBatches */
            invokevirtual java.util.ArrayList.size:()I
            istore 3 /* size */
        start local 3 // int size
         4: goto 8
         5: .line 1100
      StackMap locals: java.util.ArrayList int int
      StackMap stack:
            getstatic org.h2.table.JoinBatch$QueryRunnerUnion.$assertionsDisabled:Z
            ifne 6
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.topFutureCursors:[Ljava/util/concurrent/Future;
            iload 2 /* i */
            aaload
            ifnonnull 6
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         6: .line 1101
      StackMap locals:
      StackMap stack:
            aload 1 /* joinBatches */
            iload 2 /* i */
            invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
            checkcast org.h2.table.JoinBatch
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.topFutureCursors:[Ljava/util/concurrent/Future;
            iload 2 /* i */
            aaload
            putfield org.h2.table.JoinBatch.viewTopFutureCursor:Ljava/util/concurrent/Future;
         7: .line 1099
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 2 /* i */
            iload 3 /* size */
            if_icmplt 5
        end local 3 // int size
        end local 2 // int i
         9: .line 1104
            iconst_0
            istore 3 /* lazy */
        start local 3 // boolean lazy
        10: .line 1106
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.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 2 /* localResult */
        start local 2 // org.h2.result.ResultInterface localResult
        11: .line 1107
            aload 2 /* localResult */
            invokeinterface org.h2.result.ResultInterface.isLazy:()Z
            istore 3 /* lazy */
        12: .line 1108
            goto 17
        end local 2 // org.h2.result.ResultInterface localResult
      StackMap locals: org.h2.table.JoinBatch$QueryRunnerUnion java.util.ArrayList top int
      StackMap stack: java.lang.Throwable
        13: astore 4
        14: .line 1109
            iload 3 /* lazy */
            ifne 16
        15: .line 1110
            aload 0 /* this */
            invokevirtual org.h2.table.JoinBatch$QueryRunnerUnion.resetViewTopFutureCursorAfterQuery:()V
        16: .line 1112
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 4
            athrow
        start local 2 // org.h2.result.ResultInterface localResult
        17: .line 1109
      StackMap locals: org.h2.table.JoinBatch$QueryRunnerUnion java.util.ArrayList org.h2.result.ResultInterface int
      StackMap stack:
            iload 3 /* lazy */
            ifne 19
        18: .line 1110
            aload 0 /* this */
            invokevirtual org.h2.table.JoinBatch$QueryRunnerUnion.resetViewTopFutureCursorAfterQuery:()V
        19: .line 1113
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 2 /* localResult */
            invokevirtual org.h2.table.JoinBatch$QueryRunnerUnion.newCursor:(Lorg/h2/result/ResultInterface;)Lorg/h2/index/ViewCursor;
            areturn
        end local 3 // boolean lazy
        end local 2 // org.h2.result.ResultInterface localResult
        end local 1 // java.util.ArrayList joinBatches
        end local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   20     0         this  Lorg/h2/table/JoinBatch$QueryRunnerUnion;
            2   20     1  joinBatches  Ljava/util/ArrayList<Lorg/h2/table/JoinBatch;>;
            3    9     2            i  I
            4    9     3         size  I
           11   13     2  localResult  Lorg/h2/result/ResultInterface;
           17   20     2  localResult  Lorg/h2/result/ResultInterface;
           10   20     3         lazy  Z
      Exception table:
        from    to  target  type
          10    13      13  any
    Exceptions:
      throws java.lang.Exception

  protected void resetViewTopFutureCursorAfterQuery();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
         0: .line 1118
            aload 0 /* this */
            getfield org.h2.table.JoinBatch$QueryRunnerUnion.batchUnion:Lorg/h2/table/JoinBatch$ViewIndexLookupBatchUnion;
            getfield org.h2.table.JoinBatch$ViewIndexLookupBatchUnion.joinBatches:Ljava/util/ArrayList;
            astore 1 /* joinBatches */
        start local 1 // java.util.ArrayList joinBatches
         1: .line 1119
            aload 1 /* joinBatches */
            ifnonnull 3
         2: .line 1120
            return
         3: .line 1122
      StackMap locals: java.util.ArrayList
      StackMap stack:
            aload 1 /* joinBatches */
            invokevirtual java.util.ArrayList.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.h2.table.JoinBatch$QueryRunnerUnion java.util.ArrayList top java.util.Iterator
      StackMap stack:
         4: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.h2.table.JoinBatch
            astore 2 /* joinBatch */
        start local 2 // org.h2.table.JoinBatch joinBatch
         5: .line 1123
            aload 2 /* joinBatch */
            aconst_null
            putfield org.h2.table.JoinBatch.viewTopFutureCursor:Ljava/util/concurrent/Future;
        end local 2 // org.h2.table.JoinBatch joinBatch
         6: .line 1122
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         7: .line 1125
            return
        end local 1 // java.util.ArrayList joinBatches
        end local 0 // org.h2.table.JoinBatch$QueryRunnerUnion this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Lorg/h2/table/JoinBatch$QueryRunnerUnion;
            1    8     1  joinBatches  Ljava/util/ArrayList<Lorg/h2/table/JoinBatch;>;
            5    6     2    joinBatch  Lorg/h2/table/JoinBatch;

  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$QueryRunnerUnion.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 abstract QueryRunnerBase = org.h2.table.JoinBatch$QueryRunnerBase of org.h2.table.JoinBatch
  private QueryRunnerUnion = org.h2.table.JoinBatch$QueryRunnerUnion of org.h2.table.JoinBatch
  private final ViewIndexLookupBatchUnion = org.h2.table.JoinBatch$ViewIndexLookupBatchUnion of org.h2.table.JoinBatch