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 start local 2 0: aload 0
aload 1
putfield org.h2.table.JoinBatch$QueryRunner.this$0:Lorg/h2/table/JoinBatch;
1: aload 0
aload 2
invokespecial org.h2.table.JoinBatch$QueryRunnerBase.<init>:(Lorg/h2/index/ViewIndex;)V
2: return
end local 2 end local 0 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 0: aload 0
invokespecial org.h2.table.JoinBatch$QueryRunnerBase.clear:()V
1: aload 0
aconst_null
putfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
2: return
end local 0 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 0: aload 0
getfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
ifnonnull 2
1: getstatic org.h2.table.JoinBatch.EMPTY_CURSOR:Lorg/h2/index/Cursor;
areturn
2: StackMap locals:
StackMap stack:
aload 0
getfield org.h2.table.JoinBatch$QueryRunner.viewIndex:Lorg/h2/index/ViewIndex;
aload 0
getfield org.h2.table.JoinBatch$QueryRunner.viewIndex:Lorg/h2/index/ViewIndex;
invokevirtual org.h2.index.ViewIndex.getSession:()Lorg/h2/engine/Session;
aload 0
getfield org.h2.table.JoinBatch$QueryRunner.first:Lorg/h2/result/SearchRow;
aload 0
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: aload 0
getfield org.h2.table.JoinBatch$QueryRunner.this$0:Lorg/h2/table/JoinBatch;
aload 0
getfield org.h2.table.JoinBatch$QueryRunner.topFutureCursor:Ljava/util/concurrent/Future;
putfield org.h2.table.JoinBatch.viewTopFutureCursor:Ljava/util/concurrent/Future;
4: iconst_0
istore 2
start local 2 5: aload 0
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
start local 1 6: aload 1
invokeinterface org.h2.result.ResultInterface.isLazy:()Z
istore 2
7: goto 12
end local 1 StackMap locals: org.h2.table.JoinBatch$QueryRunner top int
StackMap stack: java.lang.Throwable
8: astore 3
9: iload 2
ifne 11
10: aload 0
invokevirtual org.h2.table.JoinBatch$QueryRunner.resetViewTopFutureCursorAfterQuery:()V
11: StackMap locals: java.lang.Throwable
StackMap stack:
aload 3
athrow
start local 1 12: StackMap locals: org.h2.table.JoinBatch$QueryRunner org.h2.result.ResultInterface int
StackMap stack:
iload 2
ifne 14
13: aload 0
invokevirtual org.h2.table.JoinBatch$QueryRunner.resetViewTopFutureCursorAfterQuery:()V
14: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual org.h2.table.JoinBatch$QueryRunner.newCursor:(Lorg/h2/result/ResultInterface;)Lorg/h2/index/ViewCursor;
areturn
end local 2 end local 1 end local 0 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 0: aload 0
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: return
end local 0 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: 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