abstract class org.h2.table.JoinBatch$ViewIndexLookupBatchBase<R extends org.h2.table.JoinBatch$QueryRunnerBase> implements org.h2.index.IndexLookupBatch
minor version: 0
major version: 59
flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
this_class: org.h2.table.JoinBatch$ViewIndexLookupBatchBase
super_class: java.lang.Object
{
protected final org.h2.index.ViewIndex viewIndex;
descriptor: Lorg/h2/index/ViewIndex;
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
private final java.util.ArrayList<java.util.concurrent.Future<org.h2.index.Cursor>> result;
descriptor: Ljava/util/ArrayList;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Ljava/util/ArrayList<Ljava/util/concurrent/Future<Lorg/h2/index/Cursor;>;>;
private int resultSize;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private boolean findCalled;
descriptor: Z
flags: (0x0002) ACC_PRIVATE
protected void <init>(org.h2.index.ViewIndex);
descriptor: (Lorg/h2/index/ViewIndex;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
invokestatic org.h2.util.Utils.newSmallArrayList:()Ljava/util/ArrayList;
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
2: aload 0
aload 1
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.viewIndex:Lorg/h2/index/ViewIndex;
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
0 4 1 viewIndex Lorg/h2/index/ViewIndex;
MethodParameters:
Name Flags
viewIndex
public java.lang.String getPlanSQL();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: ldc "view"
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
protected abstract boolean collectSearchRows();
descriptor: (Lorg/h2/table/JoinBatch$QueryRunnerBase;)Z
flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
Signature: (TR;)Z
MethodParameters:
Name Flags
r
protected abstract R newQueryRunner();
descriptor: ()Lorg/h2/table/JoinBatch$QueryRunnerBase;
flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
Signature: ()TR;
protected abstract void startQueryRunners(int);
descriptor: (I)V
flags: (0x0404) ACC_PROTECTED, ACC_ABSTRACT
MethodParameters:
Name Flags
resultSize
protected final boolean resetAfterFind();
descriptor: ()Z
flags: (0x0014) ACC_PROTECTED, ACC_FINAL
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.findCalled:Z
ifne 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
iconst_0
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.findCalled:Z
3: iconst_0
istore 1
start local 1 4: goto 7
5: StackMap locals: int
StackMap stack:
aload 0
iload 1
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.queryRunner:(I)Lorg/h2/table/JoinBatch$QueryRunnerBase;
invokevirtual org.h2.table.JoinBatch$QueryRunnerBase.reset:()Z
pop
6: iinc 1 1
StackMap locals:
StackMap stack:
7: iload 1
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
if_icmplt 5
end local 1 8: aload 0
iconst_0
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
9: iconst_1
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
4 8 1 i I
protected R queryRunner();
descriptor: (I)Lorg/h2/table/JoinBatch$QueryRunnerBase;
flags: (0x0004) ACC_PROTECTED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
iload 1
invokevirtual java.util.ArrayList.get:(I)Ljava/lang/Object;
checkcast org.h2.table.JoinBatch$QueryRunnerBase
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
0 1 1 i I
Signature: (I)TR;
MethodParameters:
Name Flags
i
public final boolean addSearchRows(org.h2.result.SearchRow, org.h2.result.SearchRow);
descriptor: (Lorg/h2/result/SearchRow;Lorg/h2/result/SearchRow;)Z
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=5, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resetAfterFind:()Z
pop
1: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.viewIndex:Lorg/h2/index/ViewIndex;
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.viewIndex:Lorg/h2/index/ViewIndex;
invokevirtual org.h2.index.ViewIndex.getSession:()Lorg/h2/engine/Session;
aload 1
aload 2
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
2: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.size:()I
if_icmpge 5
3: aload 0
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.queryRunner:(I)Lorg/h2/table/JoinBatch$QueryRunnerBase;
astore 3
start local 3 4: goto 7
end local 3 5: StackMap locals:
StackMap stack:
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
aload 0
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.newQueryRunner:()Lorg/h2/table/JoinBatch$QueryRunnerBase;
dup
astore 3
start local 3 6: invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
7: StackMap locals: org.h2.table.JoinBatch$QueryRunnerBase
StackMap stack:
aload 3
aload 1
putfield org.h2.table.JoinBatch$QueryRunnerBase.first:Lorg/h2/result/SearchRow;
8: aload 3
aload 2
putfield org.h2.table.JoinBatch$QueryRunnerBase.last:Lorg/h2/result/SearchRow;
9: aload 0
aload 3
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.collectSearchRows:(Lorg/h2/table/JoinBatch$QueryRunnerBase;)Z
ifne 12
10: aload 3
invokevirtual org.h2.table.JoinBatch$QueryRunnerBase.clear:()V
11: iconst_0
ireturn
12: StackMap locals:
StackMap stack:
aload 0
dup
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
iconst_1
iadd
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
13: iconst_1
ireturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
0 14 1 first Lorg/h2/result/SearchRow;
0 14 2 last Lorg/h2/result/SearchRow;
4 5 3 r TR;
6 14 3 r TR;
MethodParameters:
Name Flags
first
last
public void reset(boolean);
descriptor: (Z)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=2
start local 0 start local 1 0: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
ifeq 7
aload 0
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resetAfterFind:()Z
ifne 7
1: iconst_0
istore 2
start local 2 2: goto 5
3: StackMap locals: int
StackMap stack:
aload 0
iload 2
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.queryRunner:(I)Lorg/h2/table/JoinBatch$QueryRunnerBase;
invokevirtual org.h2.table.JoinBatch$QueryRunnerBase.clear:()V
4: iinc 2 1
StackMap locals:
StackMap stack:
5: iload 2
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
if_icmplt 3
end local 2 6: aload 0
iconst_0
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
7: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
0 8 1 beforeQuery Z
2 6 2 i I
MethodParameters:
Name Flags
beforeQuery
public final java.util.List<java.util.concurrent.Future<org.h2.index.Cursor>> find();
descriptor: ()Ljava/util/List;
flags: (0x0011) ACC_PUBLIC, ACC_FINAL
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
ifne 2
1: invokestatic java.util.Collections.emptyList:()Ljava/util/List;
areturn
2: StackMap locals:
StackMap stack:
aload 0
iconst_1
putfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.findCalled:Z
3: aload 0
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
invokevirtual org.h2.table.JoinBatch$ViewIndexLookupBatchBase.startQueryRunners:(I)V
4: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.size:()I
if_icmpne 5
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
goto 6
StackMap locals:
StackMap stack:
5: aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.result:Ljava/util/ArrayList;
iconst_0
aload 0
getfield org.h2.table.JoinBatch$ViewIndexLookupBatchBase.resultSize:I
invokevirtual java.util.ArrayList.subList:(II)Ljava/util/List;
StackMap locals:
StackMap stack: java.util.List
6: areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lorg/h2/table/JoinBatch$ViewIndexLookupBatchBase<TR;>;
Signature: ()Ljava/util/List<Ljava/util/concurrent/Future<Lorg/h2/index/Cursor;>;>;
}
Signature: <R:Lorg/h2/table/JoinBatch$QueryRunnerBase;>Ljava/lang/Object;Lorg/h2/index/IndexLookupBatch;
SourceFile: "JoinBatch.java"
NestHost: org.h2.table.JoinBatch
InnerClasses:
private abstract QueryRunnerBase = org.h2.table.JoinBatch$QueryRunnerBase of org.h2.table.JoinBatch
private abstract ViewIndexLookupBatchBase = org.h2.table.JoinBatch$ViewIndexLookupBatchBase of org.h2.table.JoinBatch