final class io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription<TLeft, TRight, TLeftEnd, TRightEnd, R> extends java.util.concurrent.atomic.AtomicInteger implements org.reactivestreams.Subscription, io.reactivex.internal.operators.flowable.FlowableGroupJoin$JoinSupport
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription
  super_class: java.util.concurrent.atomic.AtomicInteger
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -6071216598687999801

  final org.reactivestreams.Subscriber<? super R> downstream;
    descriptor: Lorg/reactivestreams/Subscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/reactivestreams/Subscriber<-TR;>;

  final java.util.concurrent.atomic.AtomicLong requested;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0010) ACC_FINAL

  final io.reactivex.internal.queue.SpscLinkedArrayQueue<java.lang.Object> queue;
    descriptor: Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/internal/queue/SpscLinkedArrayQueue<Ljava/lang/Object;>;

  final io.reactivex.disposables.CompositeDisposable disposables;
    descriptor: Lio/reactivex/disposables/CompositeDisposable;
    flags: (0x0010) ACC_FINAL

  final java.util.Map<java.lang.Integer, io.reactivex.processors.UnicastProcessor<TRight>> lefts;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Integer;Lio/reactivex/processors/UnicastProcessor<TTRight;>;>;

  final java.util.Map<java.lang.Integer, TRight> rights;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Integer;TTRight;>;

  final java.util.concurrent.atomic.AtomicReference<java.lang.Throwable> error;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Ljava/lang/Throwable;>;

  final io.reactivex.functions.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>> leftEnd;
    descriptor: Lio/reactivex/functions/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/functions/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;

  final io.reactivex.functions.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>> rightEnd;
    descriptor: Lio/reactivex/functions/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/functions/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;

  final io.reactivex.functions.BiFunction<? super TLeft, ? super io.reactivex.Flowable<TRight>, ? extends R> resultSelector;
    descriptor: Lio/reactivex/functions/BiFunction;
    flags: (0x0010) ACC_FINAL
    Signature: Lio/reactivex/functions/BiFunction<-TTLeft;-Lio/reactivex/Flowable<TTRight;>;+TR;>;

  final java.util.concurrent.atomic.AtomicInteger active;
    descriptor: Ljava/util/concurrent/atomic/AtomicInteger;
    flags: (0x0010) ACC_FINAL

  int leftIndex;
    descriptor: I
    flags: (0x0000) 

  int rightIndex;
    descriptor: I
    flags: (0x0000) 

  volatile boolean cancelled;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  static final java.lang.Integer LEFT_VALUE;
    descriptor: Ljava/lang/Integer;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final java.lang.Integer RIGHT_VALUE;
    descriptor: Ljava/lang/Integer;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final java.lang.Integer LEFT_CLOSE;
    descriptor: Ljava/lang/Integer;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final java.lang.Integer RIGHT_CLOSE;
    descriptor: Ljava/lang/Integer;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 122
            iconst_1
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
         1: .line 124
            iconst_2
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
         2: .line 126
            iconst_3
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
         3: .line 128
            iconst_4
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(org.reactivestreams.Subscriber<? super R>, io.reactivex.functions.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>>, io.reactivex.functions.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>>, io.reactivex.functions.BiFunction<? super TLeft, ? super io.reactivex.Flowable<TRight>, ? extends R>);
    descriptor: (Lorg/reactivestreams/Subscriber;Lio/reactivex/functions/Function;Lio/reactivex/functions/Function;Lio/reactivex/functions/BiFunction;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=5, args_size=5
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // io.reactivex.functions.Function leftEnd
        start local 3 // io.reactivex.functions.Function rightEnd
        start local 4 // io.reactivex.functions.BiFunction resultSelector
         0: .line 130
            aload 0 /* this */
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
         1: .line 133
            aload 0 /* this */
            aload 1 /* actual */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.downstream:Lorg/reactivestreams/Subscriber;
         2: .line 134
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.requested:Ljava/util/concurrent/atomic/AtomicLong;
         3: .line 135
            aload 0 /* this */
            new io.reactivex.disposables.CompositeDisposable
            dup
            invokespecial io.reactivex.disposables.CompositeDisposable.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
         4: .line 136
            aload 0 /* this */
            new io.reactivex.internal.queue.SpscLinkedArrayQueue
            dup
            invokestatic io.reactivex.internal.operators.flowable.FlowableGroupJoin.bufferSize:()I
            invokespecial io.reactivex.internal.queue.SpscLinkedArrayQueue.<init>:(I)V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
         5: .line 137
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
         6: .line 138
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
         7: .line 139
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicReference
            dup
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
         8: .line 140
            aload 0 /* this */
            aload 2 /* leftEnd */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.leftEnd:Lio/reactivex/functions/Function;
         9: .line 141
            aload 0 /* this */
            aload 3 /* rightEnd */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rightEnd:Lio/reactivex/functions/Function;
        10: .line 142
            aload 0 /* this */
            aload 4 /* resultSelector */
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.resultSelector:Lio/reactivex/functions/BiFunction;
        11: .line 143
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            iconst_2
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:(I)V
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.active:Ljava/util/concurrent/atomic/AtomicInteger;
        12: .line 144
            return
        end local 4 // io.reactivex.functions.BiFunction resultSelector
        end local 3 // io.reactivex.functions.Function rightEnd
        end local 2 // io.reactivex.functions.Function leftEnd
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   13     0            this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0   13     1          actual  Lorg/reactivestreams/Subscriber<-TR;>;
            0   13     2         leftEnd  Lio/reactivex/functions/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;
            0   13     3        rightEnd  Lio/reactivex/functions/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;
            0   13     4  resultSelector  Lio/reactivex/functions/BiFunction<-TTLeft;-Lio/reactivex/Flowable<TTRight;>;+TR;>;
    Signature: (Lorg/reactivestreams/Subscriber<-TR;>;Lio/reactivex/functions/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;Lio/reactivex/functions/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;Lio/reactivex/functions/BiFunction<-TTLeft;-Lio/reactivex/Flowable<TTRight;>;+TR;>;)V
    MethodParameters:
                Name  Flags
      actual          
      leftEnd         
      rightEnd        
      resultSelector  

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // long n
         0: .line 148
            lload 1 /* n */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(J)Z
            ifeq 2
         1: .line 149
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 1 /* n */
            invokestatic io.reactivex.internal.util.BackpressureHelper.add:(Ljava/util/concurrent/atomic/AtomicLong;J)J
            pop2
         2: .line 151
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    3     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 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
         0: .line 155
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelled:Z
            ifeq 2
         1: .line 156
            return
         2: .line 158
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelled:Z
         3: .line 159
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelAll:()V
         4: .line 160
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.getAndIncrement:()I
            ifne 6
         5: .line 161
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
         6: .line 163
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;

  void cancelAll();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
         0: .line 166
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            invokevirtual io.reactivex.disposables.CompositeDisposable.dispose:()V
         1: .line 167
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;

  void errorAll(org.reactivestreams.Subscriber<?>);
    descriptor: (Lorg/reactivestreams/Subscriber;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // org.reactivestreams.Subscriber a
         0: .line 170
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            invokestatic io.reactivex.internal.util.ExceptionHelper.terminate:(Ljava/util/concurrent/atomic/AtomicReference;)Ljava/lang/Throwable;
            astore 2 /* ex */
        start local 2 // java.lang.Throwable ex
         1: .line 172
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription org.reactivestreams.Subscriber java.lang.Throwable top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 3 /* up */
        start local 3 // io.reactivex.processors.UnicastProcessor up
         3: .line 173
            aload 3 /* up */
            aload 2 /* ex */
            invokevirtual io.reactivex.processors.UnicastProcessor.onError:(Ljava/lang/Throwable;)V
        end local 3 // io.reactivex.processors.UnicastProcessor up
         4: .line 172
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 176
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         6: .line 177
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         7: .line 179
            aload 1 /* a */
            aload 2 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         8: .line 180
            return
        end local 2 // java.lang.Throwable ex
        end local 1 // org.reactivestreams.Subscriber a
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    9     1     a  Lorg/reactivestreams/Subscriber<*>;
            1    9     2    ex  Ljava/lang/Throwable;
            3    4     3    up  Lio/reactivex/processors/UnicastProcessor<TTRight;>;
    Signature: (Lorg/reactivestreams/Subscriber<*>;)V
    MethodParameters:
      Name  Flags
      a     

  void fail(java.lang.Throwable, org.reactivestreams.Subscriber<?>, io.reactivex.internal.fuseable.SimpleQueue<?>);
    descriptor: (Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimpleQueue;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // java.lang.Throwable exc
        start local 2 // org.reactivestreams.Subscriber a
        start local 3 // io.reactivex.internal.fuseable.SimpleQueue q
         0: .line 183
            aload 1 /* exc */
            invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
         1: .line 184
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* exc */
            invokestatic io.reactivex.internal.util.ExceptionHelper.addThrowable:(Ljava/util/concurrent/atomic/AtomicReference;Ljava/lang/Throwable;)Z
            pop
         2: .line 185
            aload 3 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.clear:()V
         3: .line 186
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelAll:()V
         4: .line 187
            aload 0 /* this */
            aload 2 /* a */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
         5: .line 188
            return
        end local 3 // io.reactivex.internal.fuseable.SimpleQueue q
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // java.lang.Throwable exc
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    6     1   exc  Ljava/lang/Throwable;
            0    6     2     a  Lorg/reactivestreams/Subscriber<*>;
            0    6     3     q  Lio/reactivex/internal/fuseable/SimpleQueue<*>;
    Signature: (Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber<*>;Lio/reactivex/internal/fuseable/SimpleQueue<*>;)V
    MethodParameters:
      Name  Flags
      exc   
      a     
      q     

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=17, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
         0: .line 191
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.getAndIncrement:()I
            ifeq 2
         1: .line 192
            return
         2: .line 195
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         3: .line 196
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            astore 2 /* q */
        start local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
         4: .line 197
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.downstream:Lorg/reactivestreams/Subscriber;
            astore 3 /* a */
        start local 3 // org.reactivestreams.Subscriber a
         5: .line 201
      StackMap locals: int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelled:Z
            ifeq 8
         6: .line 202
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
         7: .line 203
            return
         8: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast java.lang.Throwable
            astore 4 /* ex */
        start local 4 // java.lang.Throwable ex
         9: .line 207
            aload 4 /* ex */
            ifnull 14
        10: .line 208
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
        11: .line 209
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelAll:()V
        12: .line 210
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        13: .line 211
            return
        14: .line 214
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.active:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.get:()I
            ifne 15
            iconst_1
            goto 16
      StackMap locals:
      StackMap stack:
        15: iconst_0
      StackMap locals:
      StackMap stack: int
        16: istore 5 /* d */
        start local 5 // boolean d
        17: .line 216
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 6 /* mode */
        start local 6 // java.lang.Integer mode
        18: .line 218
            aload 6 /* mode */
            ifnonnull 19
            iconst_1
            goto 20
      StackMap locals: int java.lang.Integer
      StackMap stack:
        19: iconst_0
      StackMap locals:
      StackMap stack: int
        20: istore 7 /* empty */
        start local 7 // boolean empty
        21: .line 220
            iload 5 /* d */
            ifeq 31
            iload 7 /* empty */
            ifeq 31
        22: .line 221
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 9
            goto 25
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int top java.util.Iterator
      StackMap stack:
        23: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 8 /* up */
        start local 8 // io.reactivex.processors.UnicastProcessor up
        24: .line 222
            aload 8 /* up */
            invokevirtual io.reactivex.processors.UnicastProcessor.onComplete:()V
        end local 8 // io.reactivex.processors.UnicastProcessor up
        25: .line 221
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 23
        26: .line 225
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        27: .line 226
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        28: .line 227
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            invokevirtual io.reactivex.disposables.CompositeDisposable.dispose:()V
        29: .line 229
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        30: .line 230
            return
        31: .line 233
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int
      StackMap stack:
            iload 7 /* empty */
            ifeq 33
        32: .line 234
            goto 104
        33: .line 237
      StackMap locals:
      StackMap stack:
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.poll:()Ljava/lang/Object;
            astore 8 /* val */
        start local 8 // java.lang.Object val
        34: .line 239
            aload 6 /* mode */
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
            if_acmpne 69
        35: .line 241
            aload 8 /* val */
            astore 9 /* left */
        start local 9 // java.lang.Object left
        36: .line 243
            invokestatic io.reactivex.processors.UnicastProcessor.create:()Lio/reactivex/processors/UnicastProcessor;
            astore 10 /* up */
        start local 10 // io.reactivex.processors.UnicastProcessor up
        37: .line 244
            aload 0 /* this */
            dup
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.leftIndex:I
            dup_x1
            iconst_1
            iadd
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.leftIndex:I
            istore 11 /* idx */
        start local 11 // int idx
        38: .line 245
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            iload 11 /* idx */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 10 /* up */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        39: .line 250
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.leftEnd:Lio/reactivex/functions/Function;
            aload 9 /* left */
            invokeinterface io.reactivex.functions.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            ldc "The leftEnd returned a null Publisher"
            invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            astore 12 /* p */
        start local 12 // org.reactivestreams.Publisher p
        40: .line 251
            goto 44
        end local 12 // org.reactivestreams.Publisher p
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object io.reactivex.processors.UnicastProcessor int
      StackMap stack: java.lang.Throwable
        41: astore 13 /* exc */
        start local 13 // java.lang.Throwable exc
        42: .line 252
            aload 0 /* this */
            aload 13 /* exc */
            aload 3 /* a */
            aload 2 /* q */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.fail:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimpleQueue;)V
        43: .line 253
            return
        end local 13 // java.lang.Throwable exc
        start local 12 // org.reactivestreams.Publisher p
        44: .line 256
      StackMap locals: org.reactivestreams.Publisher
      StackMap stack:
            new io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
            dup
            aload 0 /* this */
            iconst_1
            iload 11 /* idx */
            invokespecial io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber.<init>:(Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$JoinSupport;ZI)V
            astore 13 /* end */
        start local 13 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        45: .line 257
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            aload 13 /* end */
            invokevirtual io.reactivex.disposables.CompositeDisposable.add:(Lio/reactivex/disposables/Disposable;)Z
            pop
        46: .line 259
            aload 12 /* p */
            aload 13 /* end */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
        47: .line 261
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast java.lang.Throwable
            astore 4 /* ex */
        48: .line 262
            aload 4 /* ex */
            ifnull 53
        49: .line 263
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
        50: .line 264
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelAll:()V
        51: .line 265
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        52: .line 266
            return
        53: .line 272
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.resultSelector:Lio/reactivex/functions/BiFunction;
            aload 9 /* left */
            aload 10 /* up */
            invokeinterface io.reactivex.functions.BiFunction.apply:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            ldc "The resultSelector returned a null value"
            invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 14 /* w */
        start local 14 // java.lang.Object w
        54: .line 273
            goto 58
        end local 14 // java.lang.Object w
      StackMap locals:
      StackMap stack: java.lang.Throwable
        55: astore 15 /* exc */
        start local 15 // java.lang.Throwable exc
        56: .line 274
            aload 0 /* this */
            aload 15 /* exc */
            aload 3 /* a */
            aload 2 /* q */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.fail:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimpleQueue;)V
        57: .line 275
            return
        end local 15 // java.lang.Throwable exc
        start local 14 // java.lang.Object w
        58: .line 279
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.requested:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lconst_0
            lcmp
            ifeq 62
        59: .line 280
            aload 3 /* a */
            aload 14 /* w */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        60: .line 281
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lconst_1
            invokestatic io.reactivex.internal.util.BackpressureHelper.produced:(Ljava/util/concurrent/atomic/AtomicLong;J)J
            pop2
        61: .line 282
            goto 64
        62: .line 283
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new io.reactivex.exceptions.MissingBackpressureException
            dup
            ldc "Could not emit value due to lack of requests"
            invokespecial io.reactivex.exceptions.MissingBackpressureException.<init>:(Ljava/lang/String;)V
            aload 3 /* a */
            aload 2 /* q */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.fail:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimpleQueue;)V
        63: .line 284
            return
        64: .line 287
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 16
            goto 67
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object io.reactivex.processors.UnicastProcessor int org.reactivestreams.Publisher io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber java.lang.Object top java.util.Iterator
      StackMap stack:
        65: aload 16
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 15 /* right */
        start local 15 // java.lang.Object right
        66: .line 288
            aload 10 /* up */
            aload 15 /* right */
            invokevirtual io.reactivex.processors.UnicastProcessor.onNext:(Ljava/lang/Object;)V
        end local 15 // java.lang.Object right
        67: .line 287
      StackMap locals:
      StackMap stack:
            aload 16
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 65
        end local 14 // java.lang.Object w
        end local 13 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        end local 12 // org.reactivestreams.Publisher p
        end local 11 // int idx
        end local 10 // io.reactivex.processors.UnicastProcessor up
        end local 9 // java.lang.Object left
        68: .line 290
            goto 5
        69: .line 291
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
      StackMap stack:
            aload 6 /* mode */
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
            if_acmpne 92
        70: .line 293
            aload 8 /* val */
            astore 9 /* right */
        start local 9 // java.lang.Object right
        71: .line 295
            aload 0 /* this */
            dup
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rightIndex:I
            dup_x1
            iconst_1
            iadd
            putfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rightIndex:I
            istore 10 /* idx */
        start local 10 // int idx
        72: .line 297
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
            iload 10 /* idx */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 9 /* right */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        73: .line 302
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rightEnd:Lio/reactivex/functions/Function;
            aload 9 /* right */
            invokeinterface io.reactivex.functions.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            ldc "The rightEnd returned a null Publisher"
            invokestatic io.reactivex.internal.functions.ObjectHelper.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            astore 11 /* p */
        start local 11 // org.reactivestreams.Publisher p
        74: .line 303
            goto 78
        end local 11 // org.reactivestreams.Publisher p
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int
      StackMap stack: java.lang.Throwable
        75: astore 12 /* exc */
        start local 12 // java.lang.Throwable exc
        76: .line 304
            aload 0 /* this */
            aload 12 /* exc */
            aload 3 /* a */
            aload 2 /* q */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.fail:(Ljava/lang/Throwable;Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimpleQueue;)V
        77: .line 305
            return
        end local 12 // java.lang.Throwable exc
        start local 11 // org.reactivestreams.Publisher p
        78: .line 308
      StackMap locals: org.reactivestreams.Publisher
      StackMap stack:
            new io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
            dup
            aload 0 /* this */
            iconst_0
            iload 10 /* idx */
            invokespecial io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber.<init>:(Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$JoinSupport;ZI)V
            astore 12 /* end */
        start local 12 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        79: .line 309
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            aload 12 /* end */
            invokevirtual io.reactivex.disposables.CompositeDisposable.add:(Lio/reactivex/disposables/Disposable;)Z
            pop
        80: .line 311
            aload 11 /* p */
            aload 12 /* end */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
        81: .line 313
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            invokevirtual java.util.concurrent.atomic.AtomicReference.get:()Ljava/lang/Object;
            checkcast java.lang.Throwable
            astore 4 /* ex */
        82: .line 314
            aload 4 /* ex */
            ifnull 87
        83: .line 315
            aload 2 /* q */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.clear:()V
        84: .line 316
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.cancelAll:()V
        85: .line 317
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        86: .line 318
            return
        87: .line 321
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 14
            goto 90
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber top java.util.Iterator
      StackMap stack:
        88: aload 14
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 13 /* up */
        start local 13 // io.reactivex.processors.UnicastProcessor up
        89: .line 322
            aload 13 /* up */
            aload 9 /* right */
            invokevirtual io.reactivex.processors.UnicastProcessor.onNext:(Ljava/lang/Object;)V
        end local 13 // io.reactivex.processors.UnicastProcessor up
        90: .line 321
      StackMap locals:
      StackMap stack:
            aload 14
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 88
        end local 12 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        end local 11 // org.reactivestreams.Publisher p
        end local 10 // int idx
        end local 9 // java.lang.Object right
        91: .line 324
            goto 5
        92: .line 325
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
      StackMap stack:
            aload 6 /* mode */
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
            if_acmpne 99
        93: .line 326
            aload 8 /* val */
            checkcast io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
            astore 9 /* end */
        start local 9 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        94: .line 328
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.lefts:Ljava/util/Map;
            aload 9 /* end */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber.index:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 10 /* up */
        start local 10 // io.reactivex.processors.UnicastProcessor up
        95: .line 329
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            aload 9 /* end */
            invokevirtual io.reactivex.disposables.CompositeDisposable.remove:(Lio/reactivex/disposables/Disposable;)Z
            pop
        96: .line 330
            aload 10 /* up */
            ifnull 5
        97: .line 331
            aload 10 /* up */
            invokevirtual io.reactivex.processors.UnicastProcessor.onComplete:()V
        end local 10 // io.reactivex.processors.UnicastProcessor up
        end local 9 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        98: .line 333
            goto 5
        99: .line 334
      StackMap locals:
      StackMap stack:
            aload 6 /* mode */
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
            if_acmpne 5
       100: .line 335
            aload 8 /* val */
            checkcast io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber
            astore 9 /* end */
        start local 9 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
       101: .line 337
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.rights:Ljava/util/Map;
            aload 9 /* end */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber.index:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
       102: .line 338
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            aload 9 /* end */
            invokevirtual io.reactivex.disposables.CompositeDisposable.remove:(Lio/reactivex/disposables/Disposable;)Z
            pop
        end local 9 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber end
        end local 8 // java.lang.Object val
        end local 7 // boolean empty
        end local 6 // java.lang.Integer mode
        end local 5 // boolean d
        end local 4 // java.lang.Throwable ex
       103: .line 200
            goto 5
       104: .line 342
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.queue.SpscLinkedArrayQueue org.reactivestreams.Subscriber
      StackMap stack:
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.addAndGet:(I)I
            istore 1 /* missed */
       105: .line 343
            iload 1 /* missed */
            ifne 5
       106: .line 347
            return
        end local 3 // org.reactivestreams.Subscriber a
        end local 2 // io.reactivex.internal.queue.SpscLinkedArrayQueue q
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0  107     0    this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            3  107     1  missed  I
            4  107     2       q  Lio/reactivex/internal/queue/SpscLinkedArrayQueue<Ljava/lang/Object;>;
            5  107     3       a  Lorg/reactivestreams/Subscriber<-TR;>;
            9  103     4      ex  Ljava/lang/Throwable;
           17  103     5       d  Z
           18  103     6    mode  Ljava/lang/Integer;
           21  103     7   empty  Z
           24   25     8      up  Lio/reactivex/processors/UnicastProcessor<*>;
           34  103     8     val  Ljava/lang/Object;
           36   68     9    left  TTLeft;
           37   68    10      up  Lio/reactivex/processors/UnicastProcessor<TTRight;>;
           38   68    11     idx  I
           40   41    12       p  Lorg/reactivestreams/Publisher<TTLeftEnd;>;
           44   68    12       p  Lorg/reactivestreams/Publisher<TTLeftEnd;>;
           42   44    13     exc  Ljava/lang/Throwable;
           45   68    13     end  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;
           54   55    14       w  TR;
           58   68    14       w  TR;
           56   58    15     exc  Ljava/lang/Throwable;
           66   67    15   right  TTRight;
           71   91     9   right  TTRight;
           72   91    10     idx  I
           74   75    11       p  Lorg/reactivestreams/Publisher<TTRightEnd;>;
           78   91    11       p  Lorg/reactivestreams/Publisher<TTRightEnd;>;
           76   78    12     exc  Ljava/lang/Throwable;
           79   91    12     end  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;
           89   90    13      up  Lio/reactivex/processors/UnicastProcessor<TTRight;>;
           94   98     9     end  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;
           95   98    10      up  Lio/reactivex/processors/UnicastProcessor<TTRight;>;
          101  103     9     end  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;
      Exception table:
        from    to  target  type
          39    40      41  Class java.lang.Throwable
          53    54      55  Class java.lang.Throwable
          73    74      75  Class java.lang.Throwable

  public void innerError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // java.lang.Throwable ex
         0: .line 351
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* ex */
            invokestatic io.reactivex.internal.util.ExceptionHelper.addThrowable:(Ljava/util/concurrent/atomic/AtomicReference;Ljava/lang/Throwable;)Z
            ifeq 4
         1: .line 352
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.active:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            pop
         2: .line 353
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.drain:()V
         3: .line 354
            goto 5
         4: .line 355
      StackMap locals:
      StackMap stack:
            aload 1 /* ex */
            invokestatic io.reactivex.plugins.RxJavaPlugins.onError:(Ljava/lang/Throwable;)V
         5: .line 357
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable ex
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    6     1    ex  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      ex    

  public void innerComplete(io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightSubscriber);
    descriptor: (Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightSubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightSubscriber sender
         0: .line 361
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.disposables:Lio/reactivex/disposables/CompositeDisposable;
            aload 1 /* sender */
            invokevirtual io.reactivex.disposables.CompositeDisposable.delete:(Lio/reactivex/disposables/Disposable;)Z
            pop
         1: .line 362
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.active:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            pop
         2: .line 363
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.drain:()V
         3: .line 364
            return
        end local 1 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightSubscriber sender
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    4     1  sender  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightSubscriber;
    MethodParameters:
        Name  Flags
      sender  

  public void innerValue(boolean, java.lang.Object);
    descriptor: (ZLjava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // boolean isLeft
        start local 2 // java.lang.Object o
         0: .line 368
            aload 0 /* this */
            dup
            astore 3
            monitorenter
         1: .line 369
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            iload 1 /* isLeft */
            ifeq 2
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
            goto 3
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int java.lang.Object io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription
      StackMap stack: io.reactivex.internal.queue.SpscLinkedArrayQueue
         2: getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int java.lang.Object io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription
      StackMap stack: io.reactivex.internal.queue.SpscLinkedArrayQueue java.lang.Integer
         3: aload 2 /* o */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.offer:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
         4: .line 368
            aload 3
            monitorexit
         5: goto 8
      StackMap locals:
      StackMap stack: java.lang.Throwable
         6: aload 3
            monitorexit
         7: athrow
         8: .line 371
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.drain:()V
         9: .line 372
            return
        end local 2 // java.lang.Object o
        end local 1 // boolean isLeft
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0   10     1  isLeft  Z
            0   10     2       o  Ljava/lang/Object;
      Exception table:
        from    to  target  type
           1     5       6  any
           6     7       6  any
    MethodParameters:
        Name  Flags
      isLeft  
      o       

  public void innerClose(boolean, io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber);
    descriptor: (ZLio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // boolean isLeft
        start local 2 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber index
         0: .line 376
            aload 0 /* this */
            dup
            astore 3
            monitorenter
         1: .line 377
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.queue:Lio/reactivex/internal/queue/SpscLinkedArrayQueue;
            iload 1 /* isLeft */
            ifeq 2
            getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
            goto 3
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription
      StackMap stack: io.reactivex.internal.queue.SpscLinkedArrayQueue
         2: getstatic io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription int io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription
      StackMap stack: io.reactivex.internal.queue.SpscLinkedArrayQueue java.lang.Integer
         3: aload 2 /* index */
            invokevirtual io.reactivex.internal.queue.SpscLinkedArrayQueue.offer:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
         4: .line 376
            aload 3
            monitorexit
         5: goto 8
      StackMap locals:
      StackMap stack: java.lang.Throwable
         6: aload 3
            monitorexit
         7: athrow
         8: .line 379
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.drain:()V
         9: .line 380
            return
        end local 2 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber index
        end local 1 // boolean isLeft
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   10     0    this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0   10     1  isLeft  Z
            0   10     2   index  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$LeftRightEndSubscriber;
      Exception table:
        from    to  target  type
           1     5       6  any
           6     7       6  any
    MethodParameters:
        Name  Flags
      isLeft  
      index   

  public void innerCloseError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
        start local 1 // java.lang.Throwable ex
         0: .line 384
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.error:Ljava/util/concurrent/atomic/AtomicReference;
            aload 1 /* ex */
            invokestatic io.reactivex.internal.util.ExceptionHelper.addThrowable:(Ljava/util/concurrent/atomic/AtomicReference;Ljava/lang/Throwable;)Z
            ifeq 3
         1: .line 385
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription.drain:()V
         2: .line 386
            goto 4
         3: .line 387
      StackMap locals:
      StackMap stack:
            aload 1 /* ex */
            invokestatic io.reactivex.plugins.RxJavaPlugins.onError:(Ljava/lang/Throwable;)V
         4: .line 389
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable ex
        end local 0 // io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$GroupJoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    5     1    ex  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      ex    
}
Signature: <TLeft:Ljava/lang/Object;TRight:Ljava/lang/Object;TLeftEnd:Ljava/lang/Object;TRightEnd:Ljava/lang/Object;R:Ljava/lang/Object;>Ljava/util/concurrent/atomic/AtomicInteger;Lorg/reactivestreams/Subscription;Lio/reactivex/internal/operators/flowable/FlowableGroupJoin$JoinSupport;
SourceFile: "FlowableGroupJoin.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableGroupJoin
InnerClasses:
  final GroupJoinSubscription = io.reactivex.internal.operators.flowable.FlowableGroupJoin$GroupJoinSubscription of io.reactivex.internal.operators.flowable.FlowableGroupJoin
  abstract JoinSupport = io.reactivex.internal.operators.flowable.FlowableGroupJoin$JoinSupport of io.reactivex.internal.operators.flowable.FlowableGroupJoin
  final LeftRightEndSubscriber = io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightEndSubscriber of io.reactivex.internal.operators.flowable.FlowableGroupJoin
  final LeftRightSubscriber = io.reactivex.internal.operators.flowable.FlowableGroupJoin$LeftRightSubscriber of io.reactivex.internal.operators.flowable.FlowableGroupJoin