public final class io.reactivex.internal.operators.flowable.FlowableCache<T> extends io.reactivex.internal.operators.flowable.AbstractFlowableWithUpstream<T, T> implements io.reactivex.FlowableSubscriber<T>
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: io.reactivex.internal.operators.flowable.FlowableCache
super_class: io.reactivex.internal.operators.flowable.AbstractFlowableWithUpstream
{
final java.util.concurrent.atomic.AtomicBoolean once;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0010) ACC_FINAL
final int capacityHint;
descriptor: I
flags: (0x0010) ACC_FINAL
final java.util.concurrent.atomic.AtomicReference<io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription<T>[]> subscribers;
descriptor: Ljava/util/concurrent/atomic/AtomicReference;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReference<[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;>;
static final io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[] EMPTY;
descriptor: [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
flags: (0x0018) ACC_STATIC, ACC_FINAL
static final io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[] TERMINATED;
descriptor: [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
flags: (0x0018) ACC_STATIC, ACC_FINAL
volatile long size;
descriptor: J
flags: (0x0040) ACC_VOLATILE
final io.reactivex.internal.operators.flowable.FlowableCache$Node<T> head;
descriptor: Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
flags: (0x0010) ACC_FINAL
Signature: Lio/reactivex/internal/operators/flowable/FlowableCache$Node<TT;>;
io.reactivex.internal.operators.flowable.FlowableCache$Node<T> tail;
descriptor: Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
flags: (0x0000)
Signature: Lio/reactivex/internal/operators/flowable/FlowableCache$Node<TT;>;
int tailOffset;
descriptor: I
flags: (0x0000)
java.lang.Throwable error;
descriptor: Ljava/lang/Throwable;
flags: (0x0000)
volatile boolean done;
descriptor: Z
flags: (0x0040) ACC_VOLATILE
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: iconst_0
anewarray io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
putstatic io.reactivex.internal.operators.flowable.FlowableCache.EMPTY:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
1: iconst_0
anewarray io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
putstatic io.reactivex.internal.operators.flowable.FlowableCache.TERMINATED:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
return
LocalVariableTable:
Start End Slot Name Signature
public void <init>(io.reactivex.Flowable<T>, );
descriptor: (Lio/reactivex/Flowable;I)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 0
aload 1
invokespecial io.reactivex.internal.operators.flowable.AbstractFlowableWithUpstream.<init>:(Lio/reactivex/Flowable;)V
1: aload 0
iload 2
putfield io.reactivex.internal.operators.flowable.FlowableCache.capacityHint:I
2: aload 0
new java.util.concurrent.atomic.AtomicBoolean
dup
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
putfield io.reactivex.internal.operators.flowable.FlowableCache.once:Ljava/util/concurrent/atomic/AtomicBoolean;
3: new io.reactivex.internal.operators.flowable.FlowableCache$Node
dup
iload 2
invokespecial io.reactivex.internal.operators.flowable.FlowableCache$Node.<init>:(I)V
astore 3
start local 3 4: aload 0
aload 3
putfield io.reactivex.internal.operators.flowable.FlowableCache.head:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
5: aload 0
aload 3
putfield io.reactivex.internal.operators.flowable.FlowableCache.tail:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
6: aload 0
new java.util.concurrent.atomic.AtomicReference
dup
getstatic io.reactivex.internal.operators.flowable.FlowableCache.EMPTY:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:(Ljava/lang/Object;)V
putfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
7: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 8 1 source Lio/reactivex/Flowable<TT;>;
0 8 2 capacityHint I
4 8 3 n Lio/reactivex/internal/operators/flowable/FlowableCache$Node<TT;>;
Signature: (Lio/reactivex/Flowable<TT;>;I)V
MethodParameters:
Name Flags
source
capacityHint
protected void subscribeActual(org.reactivestreams.Subscriber<? super T>);
descriptor: (Lorg/reactivestreams/Subscriber;)V
flags: (0x0004) ACC_PROTECTED
Code:
stack=4, locals=3, args_size=2
start local 0 start local 1 0: new io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
dup
aload 1
aload 0
invokespecial io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.<init>:(Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/operators/flowable/FlowableCache;)V
astore 2
start local 2 1: aload 1
aload 2
invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
2: aload 0
aload 2
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache.add:(Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
3: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.once:Ljava/util/concurrent/atomic/AtomicBoolean;
invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
ifne 6
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.once:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifeq 6
4: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.source:Lio/reactivex/Flowable;
aload 0
invokevirtual io.reactivex.Flowable.subscribe:(Lio/reactivex/FlowableSubscriber;)V
5: goto 7
6: StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
StackMap stack:
aload 0
aload 2
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache.replay:(Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
7: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 8 1 t Lorg/reactivestreams/Subscriber<-TT;>;
1 8 2 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
Signature: (Lorg/reactivestreams/Subscriber<-TT;>;)V
MethodParameters:
Name Flags
t
boolean isConnected();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.once:Ljava/util/concurrent/atomic/AtomicBoolean;
invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
boolean hasSubscribers();
descriptor: ()Z
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
arraylength
ifeq 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/reactivex/internal/operators/flowable/FlowableCache<TT;>;
long cachedEventCount();
descriptor: ()J
flags: (0x0000)
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.size:J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
void add(io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription<T>);
descriptor: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
flags: (0x0000)
Code:
stack=5, locals=5, args_size=2
start local 0 start local 1 0: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
astore 2
start local 2 1: aload 2
getstatic io.reactivex.internal.operators.flowable.FlowableCache.TERMINATED:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
if_acmpne 3
2: return
3: StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
StackMap stack:
aload 2
arraylength
istore 3
start local 3 4: iload 3
iconst_1
iadd
anewarray io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
astore 4
start local 4 5: aload 2
iconst_0
aload 4
iconst_0
iload 3
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
6: aload 4
iload 3
aload 1
aastore
7: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
aload 2
aload 4
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 0
8: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 9 1 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
1 9 2 current [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
4 9 3 n I
5 9 4 next [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
Signature: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;)V
MethodParameters:
Name Flags
consumer
void remove(io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription<T>);
descriptor: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
flags: (0x0000)
Code:
stack=6, locals=6, args_size=2
start local 0 start local 1 0: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
astore 2
start local 2 1: aload 2
arraylength
istore 3
start local 3 2: iload 3
ifne 4
3: return
4: StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[] int
StackMap stack:
iconst_m1
istore 4
start local 4 5: iconst_0
istore 5
start local 5 6: goto 11
7: StackMap locals: int int
StackMap stack:
aload 2
iload 5
aaload
aload 1
if_acmpne 10
8: iload 5
istore 4
9: goto 12
10: StackMap locals:
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
11: iload 5
iload 3
if_icmplt 7
end local 5 12: StackMap locals:
StackMap stack:
iload 4
ifge 14
13: return
14: StackMap locals:
StackMap stack:
iload 3
iconst_1
if_icmpne 17
15: getstatic io.reactivex.internal.operators.flowable.FlowableCache.EMPTY:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
astore 5
start local 5 16: goto 20
end local 5 17: StackMap locals:
StackMap stack:
iload 3
iconst_1
isub
anewarray io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription
astore 5
start local 5 18: aload 2
iconst_0
aload 5
iconst_0
iload 4
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
19: aload 2
iload 4
iconst_1
iadd
aload 5
iload 4
iload 3
iload 4
isub
iconst_1
isub
invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
20: StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
aload 2
aload 5
invokevirtual java.util.concurrent.atomic.AtomicReference.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;)Z
ifeq 0
21: return
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 22 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 22 1 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
1 22 2 current [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
2 22 3 n I
5 22 4 j I
6 12 5 i I
16 17 5 next [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
18 22 5 next [Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
Signature: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;)V
MethodParameters:
Name Flags
consumer
void replay(io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription<T>);
descriptor: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
flags: (0x0000)
Code:
stack=4, locals=14, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.getAndIncrement:()I
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
iconst_1
istore 2
start local 2 3: aload 1
getfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.index:J
lstore 3
start local 3 4: aload 1
getfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.offset:I
istore 5
start local 5 5: aload 1
getfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.node:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
astore 6
start local 6 6: aload 1
getfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.requested:Ljava/util/concurrent/atomic/AtomicLong;
astore 7
start local 7 7: aload 1
getfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.downstream:Lorg/reactivestreams/Subscriber;
astore 8
start local 8 8: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.capacityHint:I
istore 9
start local 9 9: StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription int long int io.reactivex.internal.operators.flowable.FlowableCache$Node java.util.concurrent.atomic.AtomicLong org.reactivestreams.Subscriber int
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.done:Z
istore 10
start local 10 10: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.size:J
lload 3
lcmp
ifne 11
iconst_1
goto 12
StackMap locals: int
StackMap stack:
11: iconst_0
StackMap locals:
StackMap stack: int
12: istore 11
start local 11 13: iload 10
ifeq 21
iload 11
ifeq 21
14: aload 1
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.node:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
15: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.error:Ljava/lang/Throwable;
astore 12
start local 12 16: aload 12
ifnull 19
17: aload 8
aload 12
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
18: goto 20
19: StackMap locals: int java.lang.Throwable
StackMap stack:
aload 8
invokeinterface org.reactivestreams.Subscriber.onComplete:()V
20: StackMap locals:
StackMap stack:
return
end local 12 21: StackMap locals:
StackMap stack:
iload 11
ifne 34
22: aload 7
invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
lstore 12
start local 12 23: lload 12
ldc -9223372036854775808
lcmp
ifne 26
24: aload 1
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.node:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
25: return
26: StackMap locals: long
StackMap stack:
lload 12
lload 3
lcmp
ifeq 34
27: iload 5
iload 9
if_icmpne 30
28: aload 6
getfield io.reactivex.internal.operators.flowable.FlowableCache$Node.next:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
astore 6
29: iconst_0
istore 5
30: StackMap locals:
StackMap stack:
aload 8
aload 6
getfield io.reactivex.internal.operators.flowable.FlowableCache$Node.values:[Ljava/lang/Object;
iload 5
aaload
invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
31: iinc 5 1
32: lload 3
lconst_1
ladd
lstore 3
33: goto 9
end local 12 34: StackMap locals:
StackMap stack:
aload 1
lload 3
putfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.index:J
35: aload 1
iload 5
putfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.offset:I
36: aload 1
aload 6
putfield io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.node:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
37: aload 1
iload 2
ineg
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription.addAndGet:(I)I
istore 2
38: iload 2
ifne 9
end local 11 end local 10 39: return
end local 9 end local 8 end local 7 end local 6 end local 5 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 40 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 40 1 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
3 40 2 missed I
4 40 3 index J
5 40 5 offset I
6 40 6 node Lio/reactivex/internal/operators/flowable/FlowableCache$Node<TT;>;
7 40 7 requested Ljava/util/concurrent/atomic/AtomicLong;
8 40 8 downstream Lorg/reactivestreams/Subscriber<-TT;>;
9 40 9 capacity I
10 39 10 sourceDone Z
13 39 11 empty Z
16 21 12 ex Ljava/lang/Throwable;
23 34 12 consumerRequested J
Signature: (Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;)V
MethodParameters:
Name Flags
consumer
public void onSubscribe(org.reactivestreams.Subscription);
descriptor: (Lorg/reactivestreams/Subscription;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ldc 9223372036854775807
invokeinterface org.reactivestreams.Subscription.request:(J)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 2 1 s Lorg/reactivestreams/Subscription;
MethodParameters:
Name Flags
s
public void onNext();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=7, args_size=2
start local 0 start local 1 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.tailOffset:I
istore 2
start local 2 1: iload 2
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.capacityHint:I
if_icmpne 8
2: new io.reactivex.internal.operators.flowable.FlowableCache$Node
dup
iload 2
invokespecial io.reactivex.internal.operators.flowable.FlowableCache$Node.<init>:(I)V
astore 3
start local 3 3: aload 3
getfield io.reactivex.internal.operators.flowable.FlowableCache$Node.values:[Ljava/lang/Object;
iconst_0
aload 1
aastore
4: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableCache.tailOffset:I
5: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.tail:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
aload 3
putfield io.reactivex.internal.operators.flowable.FlowableCache$Node.next:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
6: aload 0
aload 3
putfield io.reactivex.internal.operators.flowable.FlowableCache.tail:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
end local 3 7: goto 10
8: StackMap locals: int
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.tail:Lio/reactivex/internal/operators/flowable/FlowableCache$Node;
getfield io.reactivex.internal.operators.flowable.FlowableCache$Node.values:[Ljava/lang/Object;
iload 2
aload 1
aastore
9: aload 0
iload 2
iconst_1
iadd
putfield io.reactivex.internal.operators.flowable.FlowableCache.tailOffset:I
10: StackMap locals:
StackMap stack:
aload 0
dup
getfield io.reactivex.internal.operators.flowable.FlowableCache.size:J
lconst_1
ladd
putfield io.reactivex.internal.operators.flowable.FlowableCache.size:J
11: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
dup
astore 6
arraylength
istore 5
iconst_0
istore 4
goto 15
StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache java.lang.Object int top int int io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
StackMap stack:
12: aload 6
iload 4
aaload
astore 3
start local 3 13: aload 0
aload 3
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache.replay:(Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
end local 3 14: iinc 4 1
StackMap locals:
StackMap stack:
15: iload 4
iload 5
if_icmplt 12
16: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 17 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 17 1 t TT;
1 17 2 tailOffset I
3 7 3 n Lio/reactivex/internal/operators/flowable/FlowableCache$Node<TT;>;
13 14 3 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
Signature: (TT;)V
MethodParameters:
Name Flags
t
public void onError(java.lang.Throwable);
descriptor: (Ljava/lang/Throwable;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=6, args_size=2
start local 0 start local 1 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.done:Z
ifeq 3
1: aload 1
invokestatic io.reactivex.plugins.RxJavaPlugins.onError:(Ljava/lang/Throwable;)V
2: return
3: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield io.reactivex.internal.operators.flowable.FlowableCache.error:Ljava/lang/Throwable;
4: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableCache.done:Z
5: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
getstatic io.reactivex.internal.operators.flowable.FlowableCache.TERMINATED:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
invokevirtual java.util.concurrent.atomic.AtomicReference.getAndSet:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
dup
astore 5
arraylength
istore 4
iconst_0
istore 3
goto 9
StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache java.lang.Throwable top int int io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
StackMap stack:
6: aload 5
iload 3
aaload
astore 2
start local 2 7: aload 0
aload 2
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache.replay:(Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
end local 2 8: iinc 3 1
StackMap locals:
StackMap stack:
9: iload 3
iload 4
if_icmplt 6
10: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 11 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
0 11 1 t Ljava/lang/Throwable;
7 8 2 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
MethodParameters:
Name Flags
t
public void onComplete();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=5, args_size=1
start local 0 0: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableCache.done:Z
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableCache.subscribers:Ljava/util/concurrent/atomic/AtomicReference;
getstatic io.reactivex.internal.operators.flowable.FlowableCache.TERMINATED:[Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;
invokevirtual java.util.concurrent.atomic.AtomicReference.getAndSet:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
dup
astore 4
arraylength
istore 3
iconst_0
istore 2
goto 5
StackMap locals: io.reactivex.internal.operators.flowable.FlowableCache top int int io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription[]
StackMap stack:
2: aload 4
iload 2
aaload
astore 1
start local 1 3: aload 0
aload 1
invokevirtual io.reactivex.internal.operators.flowable.FlowableCache.replay:(Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription;)V
end local 1 4: iinc 2 1
StackMap locals:
StackMap stack:
5: iload 2
iload 3
if_icmplt 2
6: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lio/reactivex/internal/operators/flowable/FlowableCache<TT;>;
3 4 1 consumer Lio/reactivex/internal/operators/flowable/FlowableCache$CacheSubscription<TT;>;
}
Signature: <T:Ljava/lang/Object;>Lio/reactivex/internal/operators/flowable/AbstractFlowableWithUpstream<TT;TT;>;Lio/reactivex/FlowableSubscriber<TT;>;
SourceFile: "FlowableCache.java"
NestMembers:
io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription io.reactivex.internal.operators.flowable.FlowableCache$Node
InnerClasses:
final CacheSubscription = io.reactivex.internal.operators.flowable.FlowableCache$CacheSubscription of io.reactivex.internal.operators.flowable.FlowableCache
final Node = io.reactivex.internal.operators.flowable.FlowableCache$Node of io.reactivex.internal.operators.flowable.FlowableCache