final class io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber<T, U extends java.util.Collection<? super T>> extends io.reactivex.internal.subscribers.QueueDrainSubscriber<T, U, U> implements org.reactivestreams.Subscription, java.lang.Runnable, io.reactivex.disposables.Disposable
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
super_class: io.reactivex.internal.subscribers.QueueDrainSubscriber
{
final java.util.concurrent.Callable<U> bufferSupplier;
descriptor: Ljava/util/concurrent/Callable;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/concurrent/Callable<TU;>;
final long timespan;
descriptor: J
flags: (0x0010) ACC_FINAL
final java.util.concurrent.TimeUnit unit;
descriptor: Ljava/util/concurrent/TimeUnit;
flags: (0x0010) ACC_FINAL
final int maxSize;
descriptor: I
flags: (0x0010) ACC_FINAL
final boolean restartTimerOnMaxSize;
descriptor: Z
flags: (0x0010) ACC_FINAL
final io.reactivex.Scheduler$Worker w;
descriptor: Lio/reactivex/Scheduler$Worker;
flags: (0x0010) ACC_FINAL
U buffer;
descriptor: Ljava/util/Collection;
flags: (0x0000)
Signature: TU;
io.reactivex.disposables.Disposable timer;
descriptor: Lio/reactivex/disposables/Disposable;
flags: (0x0000)
org.reactivestreams.Subscription upstream;
descriptor: Lorg/reactivestreams/Subscription;
flags: (0x0000)
long producerIndex;
descriptor: J
flags: (0x0000)
long consumerIndex;
descriptor: J
flags: (0x0000)
void <init>(org.reactivestreams.Subscriber<? super U>, java.util.concurrent.Callable<U>, long, java.util.concurrent.TimeUnit, int, boolean, io.reactivex.Scheduler$Worker);
descriptor: (Lorg/reactivestreams/Subscriber;Ljava/util/concurrent/Callable;JLjava/util/concurrent/TimeUnit;IZLio/reactivex/Scheduler$Worker;)V
flags: (0x0000)
Code:
stack=4, locals=9, args_size=8
start local 0 start local 1 start local 2 start local 3 start local 5 start local 6 start local 7 start local 8 0: aload 0
aload 1
new io.reactivex.internal.queue.MpscLinkedQueue
dup
invokespecial io.reactivex.internal.queue.MpscLinkedQueue.<init>:()V
invokespecial io.reactivex.internal.subscribers.QueueDrainSubscriber.<init>:(Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimplePlainQueue;)V
1: aload 0
aload 2
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.bufferSupplier:Ljava/util/concurrent/Callable;
2: aload 0
lload 3
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timespan:J
3: aload 0
aload 5
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.unit:Ljava/util/concurrent/TimeUnit;
4: aload 0
iload 6
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.maxSize:I
5: aload 0
iload 7
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.restartTimerOnMaxSize:Z
6: aload 0
aload 8
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
7: return
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 8 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 8 1 actual Lorg/reactivestreams/Subscriber<-TU;>;
0 8 2 bufferSupplier Ljava/util/concurrent/Callable<TU;>;
0 8 3 timespan J
0 8 5 unit Ljava/util/concurrent/TimeUnit;
0 8 6 maxSize I
0 8 7 restartOnMaxSize Z
0 8 8 w Lio/reactivex/Scheduler$Worker;
Signature: (Lorg/reactivestreams/Subscriber<-TU;>;Ljava/util/concurrent/Callable<TU;>;JLjava/util/concurrent/TimeUnit;IZLio/reactivex/Scheduler$Worker;)V
MethodParameters:
Name Flags
actual
bufferSupplier
timespan
unit
maxSize
restartOnMaxSize
w
public void onSubscribe(org.reactivestreams.Subscription);
descriptor: (Lorg/reactivestreams/Subscription;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=4, args_size=2
start local 0 start local 1 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.upstream:Lorg/reactivestreams/Subscription;
aload 1
invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
ifne 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.upstream:Lorg/reactivestreams/Subscription;
3: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.bufferSupplier:Ljava/util/concurrent/Callable;
invokeinterface java.util.concurrent.Callable.call:()Ljava/lang/Object;
checkcast java.util.Collection
ldc "The supplied buffer is null"
invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.Collection
astore 2
start local 2 4: goto 11
end local 2 StackMap locals:
StackMap stack: java.lang.Throwable
5: astore 3
start local 3 6: aload 3
invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
7: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
8: aload 1
invokeinterface org.reactivestreams.Subscription.cancel:()V
9: aload 3
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
invokestatic io.reactivex.internal.subscriptions.EmptySubscription.error:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;)V
10: return
end local 3 start local 2 11: StackMap locals: java.util.Collection
StackMap stack:
aload 0
aload 2
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
12: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
aload 0
invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
13: aload 0
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
aload 0
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timespan:J
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timespan:J
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.unit:Ljava/util/concurrent/TimeUnit;
invokevirtual io.reactivex.Scheduler$Worker.schedulePeriodically:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timer:Lio/reactivex/disposables/Disposable;
14: aload 1
ldc 9223372036854775807
invokeinterface org.reactivestreams.Subscription.request:(J)V
15: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 16 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 16 1 s Lorg/reactivestreams/Subscription;
4 5 2 b TU;
11 16 2 b TU;
6 11 3 e Ljava/lang/Throwable;
Exception table:
from to target type
3 4 5 Class java.lang.Throwable
MethodParameters:
Name Flags
s
public void onNext();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=8, locals=4, args_size=2
start local 0 start local 1 0: aload 0
dup
astore 3
monitorenter
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
astore 2
start local 2 2: aload 2
ifnonnull 5
3: aload 3
monitorexit
4: return
5: StackMap locals: java.util.Collection io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack:
aload 2
aload 1
invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
pop
6: aload 2
invokeinterface java.util.Collection.size:()I
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.maxSize:I
if_icmpge 9
7: aload 3
monitorexit
8: return
9: StackMap locals:
StackMap stack:
aload 0
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
10: aload 0
dup
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.producerIndex:J
lconst_1
ladd
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.producerIndex:J
11: aload 3
monitorexit
12: goto 15
end local 2 StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.lang.Object top io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
13: aload 3
monitorexit
14: athrow
start local 2 15: StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.lang.Object java.util.Collection
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.restartTimerOnMaxSize:Z
ifeq 17
16: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timer:Lio/reactivex/disposables/Disposable;
invokeinterface io.reactivex.disposables.Disposable.dispose:()V
17: StackMap locals:
StackMap stack:
aload 0
aload 2
iconst_0
aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.fastPathOrderedEmitMax:(Ljava/lang/Object;ZLio/reactivex/disposables/Disposable;)V
18: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.bufferSupplier:Ljava/util/concurrent/Callable;
invokeinterface java.util.concurrent.Callable.call:()Ljava/lang/Object;
checkcast java.util.Collection
ldc "The supplied buffer is null"
invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.Collection
astore 2
19: goto 25
StackMap locals:
StackMap stack: java.lang.Throwable
20: astore 3
start local 3 21: aload 3
invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
22: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.cancel:()V
23: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
aload 3
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
24: return
end local 3 25: StackMap locals:
StackMap stack:
aload 0
dup
astore 3
monitorenter
26: aload 0
aload 2
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
27: aload 0
dup
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.consumerIndex:J
lconst_1
ladd
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.consumerIndex:J
28: aload 3
monitorexit
29: goto 32
StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.lang.Object java.util.Collection io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
30: aload 3
monitorexit
31: athrow
32: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.restartTimerOnMaxSize:Z
ifeq 34
33: aload 0
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
aload 0
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timespan:J
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timespan:J
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.unit:Ljava/util/concurrent/TimeUnit;
invokevirtual io.reactivex.Scheduler$Worker.schedulePeriodically:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.timer:Lio/reactivex/disposables/Disposable;
34: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 35 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 35 1 t TT;
2 13 2 b TU;
15 35 2 b TU;
21 25 3 e Ljava/lang/Throwable;
Exception table:
from to target type
1 4 13 any
5 8 13 any
9 12 13 any
13 14 13 any
18 19 20 Class java.lang.Throwable
26 29 30 any
30 31 30 any
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=3, args_size=2
start local 0 start local 1 0: aload 0
dup
astore 2
monitorenter
1: aload 0
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
2: aload 2
monitorexit
3: goto 6
StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.lang.Throwable io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
4: aload 2
monitorexit
5: athrow
6: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
aload 1
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
7: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
8: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 9 1 t Ljava/lang/Throwable;
Exception table:
from to target type
1 3 4 any
4 5 4 any
MethodParameters:
Name Flags
t
public void onComplete();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=3, args_size=1
start local 0 0: aload 0
dup
astore 2
monitorenter
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
astore 1
start local 1 2: aload 0
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
3: aload 2
monitorexit
4: goto 7
end local 1 StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber top io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
5: aload 2
monitorexit
6: athrow
start local 1 7: StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.util.Collection
StackMap stack:
aload 1
ifnull 13
8: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
aload 1
invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.offer:(Ljava/lang/Object;)Z
pop
9: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.done:Z
10: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.enter:()Z
ifeq 12
11: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
iconst_0
aload 0
aload 0
invokestatic io.reactivex.internal.util.QueueDrainHelper.drainMaxLoop:(Lio/reactivex/internal/fuseable/SimplePlainQueue;Lorg/reactivestreams/Subscriber;ZLio/reactivex/disposables/Disposable;Lio/reactivex/internal/util/QueueDrain;)V
12: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
13: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 14 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
2 5 1 b TU;
7 14 1 b TU;
Exception table:
from to target type
1 4 5 any
5 6 5 any
public boolean accept(org.reactivestreams.Subscriber<? super U>, );
descriptor: (Lorg/reactivestreams/Subscriber;Ljava/util/Collection;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=3, args_size=3
start local 0 start local 1 start local 2 0: aload 1
aload 2
invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
1: iconst_1
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 2 1 a Lorg/reactivestreams/Subscriber<-TU;>;
0 2 2 v TU;
Signature: (Lorg/reactivestreams/Subscriber<-TU;>;TU;)Z
MethodParameters:
Name Flags
a
v
public void request(long);
descriptor: (J)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: aload 0
lload 1
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.requested:(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/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
0 2 1 n J
MethodParameters:
Name Flags
n
public void cancel();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.cancelled:Z
ifne 3
1: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.cancelled:Z
2: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.dispose:()V
3: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
public void dispose();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
dup
astore 1
monitorenter
1: aload 0
aconst_null
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
2: aload 1
monitorexit
3: goto 6
StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
4: aload 1
monitorexit
5: athrow
6: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.upstream:Lorg/reactivestreams/Subscription;
invokeinterface org.reactivestreams.Subscription.cancel:()V
7: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
8: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
Exception table:
from to target type
1 3 4 any
4 5 4 any
public boolean isDisposed();
descriptor: ()Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.w:Lio/reactivex/Scheduler$Worker;
invokevirtual io.reactivex.Scheduler$Worker.isDisposed:()Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
public void run();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.bufferSupplier:Ljava/util/concurrent/Callable;
invokeinterface java.util.concurrent.Callable.call:()Ljava/lang/Object;
checkcast java.util.Collection
ldc "The supplied buffer is null"
invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
checkcast java.util.Collection
astore 1
start local 1 1: goto 7
end local 1 StackMap locals:
StackMap stack: java.lang.Throwable
2: astore 2
start local 2 3: aload 2
invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
4: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.cancel:()V
5: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.downstream:Lorg/reactivestreams/Subscriber;
aload 2
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
6: return
end local 2 start local 1 7: StackMap locals: java.util.Collection
StackMap stack:
aload 0
dup
astore 3
monitorenter
8: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
astore 2
start local 2 9: aload 2
ifnull 10
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.producerIndex:J
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.consumerIndex:J
lcmp
ifeq 12
10: StackMap locals: java.util.Collection io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack:
aload 3
monitorexit
11: return
12: StackMap locals:
StackMap stack:
aload 0
aload 1
putfield io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.buffer:Ljava/util/Collection;
13: aload 3
monitorexit
14: goto 17
end local 2 StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.util.Collection top io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber
StackMap stack: java.lang.Throwable
15: aload 3
monitorexit
16: athrow
start local 2 17: StackMap locals: io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber java.util.Collection java.util.Collection
StackMap stack:
aload 0
aload 2
iconst_0
aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.fastPathOrderedEmitMax:(Ljava/lang/Object;ZLio/reactivex/disposables/Disposable;)V
18: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Lio/reactivex/internal/operators/flowable/FlowableBufferTimed$BufferExactBoundedSubscriber<TT;TU;>;
1 2 1 next TU;
7 19 1 next TU;
3 7 2 e Ljava/lang/Throwable;
9 15 2 current TU;
17 19 2 current TU;
Exception table:
from to target type
0 1 2 Class java.lang.Throwable
8 11 15 any
12 14 15 any
15 16 15 any
public boolean accept(org.reactivestreams.Subscriber, java.lang.Object);
descriptor: (Lorg/reactivestreams/Subscriber;Ljava/lang/Object;)Z
flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
Code:
stack=3, locals=3, args_size=3
0: aload 0
aload 1
checkcast org.reactivestreams.Subscriber
aload 2
checkcast java.util.Collection
invokevirtual io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber.accept:(Lorg/reactivestreams/Subscriber;Ljava/util/Collection;)Z
ireturn
LocalVariableTable:
Start End Slot Name Signature
}
Signature: <T:Ljava/lang/Object;U::Ljava/util/Collection<-TT;>;>Lio/reactivex/internal/subscribers/QueueDrainSubscriber<TT;TU;TU;>;Lorg/reactivestreams/Subscription;Ljava/lang/Runnable;Lio/reactivex/disposables/Disposable;
SourceFile: "FlowableBufferTimed.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableBufferTimed
InnerClasses:
public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
final BufferExactBoundedSubscriber = io.reactivex.internal.operators.flowable.FlowableBufferTimed$BufferExactBoundedSubscriber of io.reactivex.internal.operators.flowable.FlowableBufferTimed