final class io.reactivex.internal.operators.flowable.FlowableGroupBy$State<T, K> extends io.reactivex.internal.subscriptions.BasicIntQueueSubscription<T> implements org.reactivestreams.Publisher<T>
minor version: 0
major version: 59
flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
this_class: io.reactivex.internal.operators.flowable.FlowableGroupBy$State
super_class: io.reactivex.internal.subscriptions.BasicIntQueueSubscription
{
private static final long serialVersionUID;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: -3852313036005250360
final K key;
descriptor: Ljava/lang/Object;
flags: (0x0010) ACC_FINAL
Signature: TK;
final io.reactivex.internal.queue.SpscLinkedArrayQueue<T> queue;
descriptor: Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
flags: (0x0010) ACC_FINAL
Signature: Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;
final io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber<?, K, T> parent;
descriptor: Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
flags: (0x0010) ACC_FINAL
Signature: Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;
final boolean delayError;
descriptor: Z
flags: (0x0010) ACC_FINAL
final java.util.concurrent.atomic.AtomicLong requested;
descriptor: Ljava/util/concurrent/atomic/AtomicLong;
flags: (0x0010) ACC_FINAL
volatile boolean done;
descriptor: Z
flags: (0x0040) ACC_VOLATILE
java.lang.Throwable error;
descriptor: Ljava/lang/Throwable;
flags: (0x0000)
final java.util.concurrent.atomic.AtomicBoolean cancelled;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0010) ACC_FINAL
final java.util.concurrent.atomic.AtomicReference<org.reactivestreams.Subscriber<? super T>> actual;
descriptor: Ljava/util/concurrent/atomic/AtomicReference;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/reactivestreams/Subscriber<-TT;>;>;
final java.util.concurrent.atomic.AtomicBoolean once;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0010) ACC_FINAL
boolean outputFused;
descriptor: Z
flags: (0x0000)
int produced;
descriptor: I
flags: (0x0000)
void <init>(int, io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber<?, K, T>, K, );
descriptor: (ILio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;Ljava/lang/Object;Z)V
flags: (0x0000)
Code:
stack=4, locals=5, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
invokespecial io.reactivex.internal.subscriptions.BasicIntQueueSubscription.<init>:()V
1: aload 0
new java.util.concurrent.atomic.AtomicLong
dup
invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
2: aload 0
new java.util.concurrent.atomic.AtomicBoolean
dup
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
3: aload 0
new java.util.concurrent.atomic.AtomicReference
dup
invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
4: aload 0
new java.util.concurrent.atomic.AtomicBoolean
dup
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.once:Ljava/util/concurrent/atomic/AtomicBoolean;
5: aload 0
new io.reactivex.internal.queue.SpscLinkedArrayQueue
dup
iload 1
invokespecial io.reactivex.internal.queue.SpscLinkedArrayQueue.<init>:(I)V
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
6: aload 0
aload 2
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
7: aload 0
aload 3
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.key:Ljava/lang/Object;
8: aload 0
iload 4
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
9: return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 10 1 bufferSize I
0 10 2 parent Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;
0 10 3 key TK;
0 10 4 delayError Z
Signature: (ILio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber<*TK;TT;>;TK;Z)V
MethodParameters:
Name Flags
bufferSize
parent
key
delayError
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: lload 1
invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(J)Z
ifeq 3
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
lload 1
invokestatic io.reactivex.internal.util.BackpressureHelper.add:(Ljava/util/concurrent/atomic/AtomicLong;J)J
pop2
2: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
3: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 4 1 n J
MethodParameters:
Name Flags
n
public void cancel();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifeq 2
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.key:Ljava/lang/Object;
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.cancel:(Ljava/lang/Object;)V
2: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
public void subscribe(org.reactivestreams.Subscriber<? super T>);
descriptor: (Lorg/reactivestreams/Subscriber;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.once:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifeq 5
1: aload 1
aload 0
invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
2: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
aload 1
invokevirtual java.util.concurrent.atomic.AtomicReference.lazySet:(Ljava/lang/Object;)V
3: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
4: goto 6
5: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
ldc "Only one Subscriber allowed!"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
aload 1
invokestatic io.reactivex.internal.subscriptions.EmptySubscription.error:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;)V
6: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 7 1 s Lorg/reactivestreams/Subscriber<-TT;>;
Signature: (Lorg/reactivestreams/Subscriber<-TT;>;)V
MethodParameters:
Name Flags
s
public void onNext();
descriptor: (Ljava/lang/Object;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
aload 1
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.offer:(Ljava/lang/Object;)Z
pop
1: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
2: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 3 1 t 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=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
1: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
2: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
3: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 4 1 e Ljava/lang/Throwable;
MethodParameters:
Name Flags
e
public void onComplete();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
1: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drain:()V
2: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
void drain();
descriptor: ()V
flags: (0x0000)
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.getAndIncrement:()I
ifeq 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.outputFused:Z
ifeq 5
3: aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drainFused:()V
4: goto 6
5: StackMap locals:
StackMap stack:
aload 0
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.drainNormal:()V
6: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 7 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
void drainFused();
descriptor: ()V
flags: (0x0000)
Code:
stack=2, locals=6, args_size=1
start local 0 0: iconst_1
istore 1
start local 1 1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
astore 2
start local 2 2: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.reactivestreams.Subscriber
astore 3
start local 3 3: StackMap locals: int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber
StackMap stack:
aload 3
ifnull 22
4: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
ifeq 7
5: aload 2
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
6: return
7: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
istore 4
start local 4 8: iload 4
ifeq 14
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
ifne 14
9: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
astore 5
start local 5 10: aload 5
ifnull 14
11: aload 2
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
12: aload 3
aload 5
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
13: return
end local 5 14: StackMap locals: int
StackMap stack:
aload 3
aconst_null
invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
15: iload 4
ifeq 22
16: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
astore 5
start local 5 17: aload 5
ifnull 20
18: aload 3
aload 5
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
19: goto 21
20: StackMap locals: java.lang.Throwable
StackMap stack:
aload 3
invokeinterface org.reactivestreams.Subscriber.onComplete:()V
21: StackMap locals:
StackMap stack:
return
end local 5 end local 4 22: StackMap locals:
StackMap stack:
aload 0
iload 1
ineg
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.addAndGet:(I)I
istore 1
23: iload 1
ifne 25
24: return
25: StackMap locals:
StackMap stack:
aload 3
ifnonnull 3
26: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.reactivestreams.Subscriber
astore 3
27: goto 3
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 28 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
1 28 1 missed I
2 28 2 q Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;
3 28 3 a Lorg/reactivestreams/Subscriber<-TT;>;
8 22 4 d Z
10 14 5 ex Ljava/lang/Throwable;
17 22 5 ex Ljava/lang/Throwable;
void drainNormal();
descriptor: ()V
flags: (0x0000)
Code:
stack=5, locals=12, args_size=1
start local 0 0: iconst_1
istore 1
start local 1 1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
astore 2
start local 2 2: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.delayError:Z
istore 3
start local 3 3: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.reactivestreams.Subscriber
astore 4
start local 4 4: StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupBy$State int io.reactivex.internal.queue.SpscLinkedArrayQueue int org.reactivestreams.Subscriber
StackMap stack:
aload 4
ifnull 26
5: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
lstore 5
start local 5 6: lconst_0
lstore 7
start local 7 7: goto 19
8: StackMap locals: long long
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
istore 9
start local 9 9: aload 2
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
astore 10
start local 10 10: aload 10
ifnonnull 11
iconst_1
goto 12
StackMap locals: int java.lang.Object
StackMap stack:
11: iconst_0
StackMap locals:
StackMap stack: int
12: istore 11
start local 11 13: aload 0
iload 9
iload 11
aload 4
iload 3
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Z)Z
ifeq 15
14: return
15: StackMap locals: int
StackMap stack:
iload 11
ifeq 17
16: goto 20
17: StackMap locals:
StackMap stack:
aload 4
aload 10
invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
18: lload 7
lconst_1
ladd
lstore 7
end local 11 end local 10 end local 9 19: StackMap locals:
StackMap stack:
lload 7
lload 5
lcmp
ifne 8
20: StackMap locals:
StackMap stack:
lload 7
lload 5
lcmp
ifne 22
aload 0
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.done:Z
aload 2
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.isEmpty:()Z
aload 4
iload 3
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.checkTerminated:(ZZLorg/reactivestreams/Subscriber;Z)Z
ifeq 22
21: return
22: StackMap locals:
StackMap stack:
lload 7
lconst_0
lcmp
ifeq 26
23: lload 5
ldc 9223372036854775807
lcmp
ifeq 25
24: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.requested:Ljava/util/concurrent/atomic/AtomicLong;
lload 7
lneg
invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
pop2
25: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.upstream:Lorg/reactivestreams/Subscription;
lload 7
invokeinterface org.reactivestreams.Subscription.request:(J)V
end local 7 end local 5 26: StackMap locals:
StackMap stack:
aload 0
iload 1
ineg
invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupBy$State.addAndGet:(I)I
istore 1
27: iload 1
ifne 29
28: goto 32
29: StackMap locals:
StackMap stack:
aload 4
ifnonnull 4
30: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.actual:Ljava/util/concurrent/atomic/AtomicReference;
invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
checkcast org.reactivestreams.Subscriber
astore 4
31: goto 4
32: StackMap locals:
StackMap stack:
return
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 33 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
1 33 1 missed I
2 33 2 q Lio/reactivex/internal/queue/SpscLinkedArrayQueue<TT;>;
3 33 3 delayError Z
4 33 4 a Lorg/reactivestreams/Subscriber<-TT;>;
6 26 5 r J
7 26 7 e J
9 19 9 d Z
10 19 10 v TT;
13 19 11 empty Z
boolean checkTerminated(boolean, boolean, org.reactivestreams.Subscriber<? super T>, );
descriptor: (ZZLorg/reactivestreams/Subscriber;Z)Z
flags: (0x0000)
Code:
stack=2, locals=6, args_size=5
start local 0 start local 1 start local 2 start local 3 start local 4 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.cancelled:Ljava/util/concurrent/atomic/AtomicBoolean;
invokevirtual java.util.concurrent.atomic.AtomicBoolean.get:()Z
ifeq 3
1: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
2: iconst_1
ireturn
3: StackMap locals:
StackMap stack:
iload 1
ifeq 20
4: iload 4
ifeq 12
5: iload 2
ifeq 20
6: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
astore 5
start local 5 7: aload 5
ifnull 10
8: aload 3
aload 5
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
9: goto 11
10: StackMap locals: java.lang.Throwable
StackMap stack:
aload 3
invokeinterface org.reactivestreams.Subscriber.onComplete:()V
11: StackMap locals:
StackMap stack:
iconst_1
ireturn
end local 5 12: StackMap locals:
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.error:Ljava/lang/Throwable;
astore 5
start local 5 13: aload 5
ifnull 17
14: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
15: aload 3
aload 5
invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
16: iconst_1
ireturn
17: StackMap locals: java.lang.Throwable
StackMap stack:
iload 2
ifeq 20
18: aload 3
invokeinterface org.reactivestreams.Subscriber.onComplete:()V
19: iconst_1
ireturn
end local 5 20: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 21 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 21 1 d Z
0 21 2 empty Z
0 21 3 a Lorg/reactivestreams/Subscriber<-TT;>;
0 21 4 delayError Z
7 12 5 e Ljava/lang/Throwable;
13 20 5 e Ljava/lang/Throwable;
Signature: (ZZLorg/reactivestreams/Subscriber<-TT;>;Z)Z
MethodParameters:
Name Flags
d
empty
a
delayError
public int requestFusion(int);
descriptor: (I)I
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: iload 1
iconst_2
iand
ifeq 3
1: aload 0
iconst_1
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.outputFused:Z
2: iconst_2
ireturn
3: StackMap locals:
StackMap stack:
iconst_0
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
0 4 1 mode I
MethodParameters:
Name Flags
mode
public T poll();
descriptor: ()Ljava/lang/Object;
flags: (0x0001) ACC_PUBLIC
Code:
stack=3, locals=3, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
astore 1
start local 1 1: aload 1
ifnull 4
2: aload 0
dup
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
iconst_1
iadd
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
3: aload 1
areturn
4: StackMap locals: java.lang.Object
StackMap stack:
aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
istore 2
start local 2 5: iload 2
ifeq 8
6: aload 0
iconst_0
putfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.produced:I
7: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.parent:Lio/reactivex/internal/operators/flowable/FlowableGroupBy$GroupBySubscriber;
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber.upstream:Lorg/reactivestreams/Subscription;
iload 2
i2l
invokeinterface org.reactivestreams.Subscription.request:(J)V
8: StackMap locals: int
StackMap stack:
aconst_null
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
1 9 1 v TT;
5 9 2 p I
Signature: ()TT;
RuntimeInvisibleAnnotations:
io.reactivex.annotations.Nullable()
public boolean isEmpty();
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.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.isEmpty:()Z
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
public void clear();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield io.reactivex.internal.operators.flowable.FlowableGroupBy$State.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lio/reactivex/internal/operators/flowable/FlowableGroupBy$State<TT;TK;>;
}
Signature: <T:Ljava/lang/Object;K:Ljava/lang/Object;>Lio/reactivex/internal/subscriptions/BasicIntQueueSubscription<TT;>;Lorg/reactivestreams/Publisher<TT;>;
SourceFile: "FlowableGroupBy.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableGroupBy
InnerClasses:
public final GroupBySubscriber = io.reactivex.internal.operators.flowable.FlowableGroupBy$GroupBySubscriber of io.reactivex.internal.operators.flowable.FlowableGroupBy
final State = io.reactivex.internal.operators.flowable.FlowableGroupBy$State of io.reactivex.internal.operators.flowable.FlowableGroupBy