public class io.ebeaninternal.server.query.LimitOffsetPagedList<T> implements io.ebean.PagedList<T>
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: io.ebeaninternal.server.query.LimitOffsetPagedList
super_class: java.lang.Object
{
private final transient io.ebeaninternal.api.SpiEbeanServer server;
descriptor: Lio/ebeaninternal/api/SpiEbeanServer;
flags: (0x0092) ACC_PRIVATE, ACC_FINAL, ACC_TRANSIENT
private final transient java.util.concurrent.locks.ReentrantLock lock;
descriptor: Ljava/util/concurrent/locks/ReentrantLock;
flags: (0x0092) ACC_PRIVATE, ACC_FINAL, ACC_TRANSIENT
private final io.ebeaninternal.api.SpiQuery<T> query;
descriptor: Lio/ebeaninternal/api/SpiQuery;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
Signature: Lio/ebeaninternal/api/SpiQuery<TT;>;
private final int firstRow;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final int maxRows;
descriptor: I
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private int foregroundTotalRowCount;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private java.util.concurrent.Future<java.lang.Integer> futureRowCount;
descriptor: Ljava/util/concurrent/Future;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/concurrent/Future<Ljava/lang/Integer;>;
private java.util.List<T> list;
descriptor: Ljava/util/List;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/List<TT;>;
public void <init>(io.ebeaninternal.api.SpiEbeanServer, io.ebeaninternal.api.SpiQuery<T>);
descriptor: (Lio/ebeaninternal/api/SpiEbeanServer;Lio/ebeaninternal/api/SpiQuery;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.locks.ReentrantLock
dup
invokespecial java.util.concurrent.locks.ReentrantLock.<init>:()V
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
2: aload 0
iconst_m1
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.foregroundTotalRowCount:I
3: aload 0
aload 1
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.server:Lio/ebeaninternal/api/SpiEbeanServer;
4: aload 0
aload 2
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.query:Lio/ebeaninternal/api/SpiQuery;
5: aload 0
aload 2
invokeinterface io.ebeaninternal.api.SpiQuery.getMaxRows:()I
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.maxRows:I
6: aload 0
aload 2
invokeinterface io.ebeaninternal.api.SpiQuery.getFirstRow:()I
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
7: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
0 8 1 server Lio/ebeaninternal/api/SpiEbeanServer;
0 8 2 query Lio/ebeaninternal/api/SpiQuery<TT;>;
Signature: (Lio/ebeaninternal/api/SpiEbeanServer;Lio/ebeaninternal/api/SpiQuery<TT;>;)V
MethodParameters:
Name Flags
server
query
public void loadCount();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual io.ebeaninternal.server.query.LimitOffsetPagedList.getFutureCount:()Ljava/util/concurrent/Future;
pop
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
public java.util.concurrent.Future<java.lang.Integer> getFutureCount();
descriptor: ()Ljava/util/concurrent/Future;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.futureRowCount:Ljava/util/concurrent/Future;
ifnonnull 3
2: aload 0
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.server:Lio/ebeaninternal/api/SpiEbeanServer;
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.query:Lio/ebeaninternal/api/SpiQuery;
aconst_null
invokeinterface io.ebeaninternal.api.SpiEbeanServer.findFutureCount:(Lio/ebean/Query;Lio/ebean/Transaction;)Lio/ebean/FutureRowCount;
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.futureRowCount:Ljava/util/concurrent/Future;
3: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.futureRowCount:Ljava/util/concurrent/Future;
astore 2
4: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
5: aload 2
areturn
6: StackMap locals:
StackMap stack: java.lang.Throwable
astore 1
7: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
8: aload 1
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
Exception table:
from to target type
1 4 6 any
Signature: ()Ljava/util/concurrent/Future<Ljava/lang/Integer;>;
public java.util.List<T> getList();
descriptor: ()Ljava/util/List;
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=3, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.list:Ljava/util/List;
ifnonnull 3
2: aload 0
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.server:Lio/ebeaninternal/api/SpiEbeanServer;
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.query:Lio/ebeaninternal/api/SpiQuery;
aconst_null
invokeinterface io.ebeaninternal.api.SpiEbeanServer.findList:(Lio/ebean/Query;Lio/ebean/Transaction;)Ljava/util/List;
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.list:Ljava/util/List;
3: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.list:Ljava/util/List;
astore 2
4: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
5: aload 2
areturn
6: StackMap locals:
StackMap stack: java.lang.Throwable
astore 1
7: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
8: aload 1
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
Exception table:
from to target type
1 4 6 any
Signature: ()Ljava/util/List<TT;>;
public int getPageIndex();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
ifne 2
1: iconst_0
ireturn
2: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
iconst_1
isub
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.maxRows:I
idiv
iconst_1
iadd
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
public int getTotalPageCount();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
invokevirtual io.ebeaninternal.server.query.LimitOffsetPagedList.getTotalCount:()I
istore 1
start local 1 1: iload 1
ifne 3
2: iconst_0
ireturn
3: StackMap locals: int
StackMap stack:
iload 1
iconst_1
isub
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.maxRows:I
idiv
iconst_1
iadd
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
1 4 1 rowCount I
public int getTotalCount();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.lock:()V
1: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.futureRowCount:Ljava/util/concurrent/Future;
ifnull 7
2: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.futureRowCount:Ljava/util/concurrent/Future;
invokeinterface java.util.concurrent.Future.get:()Ljava/lang/Object;
checkcast java.lang.Integer
invokevirtual java.lang.Integer.intValue:()I
istore 3
3: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
4: iload 3
ireturn
5: StackMap locals:
StackMap stack: java.lang.Exception
astore 1
start local 1 6: new javax.persistence.PersistenceException
dup
aload 1
invokespecial javax.persistence.PersistenceException.<init>:(Ljava/lang/Throwable;)V
athrow
end local 1 7: StackMap locals:
StackMap stack:
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.foregroundTotalRowCount:I
iconst_m1
if_icmple 9
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.foregroundTotalRowCount:I
istore 3
8: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
iload 3
ireturn
9: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.server:Lio/ebeaninternal/api/SpiEbeanServer;
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.query:Lio/ebeaninternal/api/SpiQuery;
aconst_null
invokeinterface io.ebeaninternal.api.SpiEbeanServer.findCount:(Lio/ebean/Query;Lio/ebean/Transaction;)I
putfield io.ebeaninternal.server.query.LimitOffsetPagedList.foregroundTotalRowCount:I
10: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.foregroundTotalRowCount:I
istore 3
11: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
12: iload 3
ireturn
13: StackMap locals:
StackMap stack: java.lang.Throwable
astore 2
14: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.lock:Ljava/util/concurrent/locks/ReentrantLock;
invokevirtual java.util.concurrent.locks.ReentrantLock.unlock:()V
15: aload 2
athrow
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
6 7 1 e Ljava/lang/Exception;
Exception table:
from to target type
2 3 5 Class java.lang.Exception
1 3 13 any
5 8 13 any
9 11 13 any
public boolean hasNext();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.maxRows:I
iadd
aload 0
invokevirtual io.ebeaninternal.server.query.LimitOffsetPagedList.getTotalCount:()I
if_icmpge 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
public boolean hasPrev();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
ifle 1
iconst_1
ireturn
StackMap locals:
StackMap stack:
1: iconst_0
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
public int getPageSize();
descriptor: ()I
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.maxRows:I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
public java.lang.String getDisplayXtoYofZ(java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
iconst_1
iadd
istore 3
start local 3 1: aload 0
getfield io.ebeaninternal.server.query.LimitOffsetPagedList.firstRow:I
aload 0
invokevirtual io.ebeaninternal.server.query.LimitOffsetPagedList.getList:()Ljava/util/List;
invokeinterface java.util.List.size:()I
iadd
istore 4
start local 4 2: aload 0
invokevirtual io.ebeaninternal.server.query.LimitOffsetPagedList.getTotalCount:()I
istore 5
start local 5 3: new java.lang.StringBuilder
dup
iload 3
invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
iload 4
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
iload 5
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
areturn
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/ebeaninternal/server/query/LimitOffsetPagedList<TT;>;
0 4 1 to Ljava/lang/String;
0 4 2 of Ljava/lang/String;
1 4 3 first I
2 4 4 last I
3 4 5 total I
MethodParameters:
Name Flags
to
of
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;Lio/ebean/PagedList<TT;>;
SourceFile: "LimitOffsetPagedList.java"