final class reactor.core.publisher.FluxJoin$JoinSubscription<TLeft, TRight, TLeftEnd, TRightEnd, R> implements reactor.core.publisher.FluxGroupJoin$JoinSupport<R>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.FluxJoin$JoinSubscription
  super_class: java.lang.Object
{
  final java.util.Queue<java.lang.Object> queue;
    descriptor: Ljava/util/Queue;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Queue<Ljava/lang/Object;>;

  final java.util.function.BiPredicate<java.lang.Object, java.lang.Object> queueBiOffer;
    descriptor: Ljava/util/function/BiPredicate;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/BiPredicate<Ljava/lang/Object;Ljava/lang/Object;>;

  final reactor.core.Disposable$Composite cancellations;
    descriptor: Lreactor/core/Disposable$Composite;
    flags: (0x0010) ACC_FINAL

  final java.util.Map<java.lang.Integer, TLeft> lefts;
    descriptor: Ljava/util/Map;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/Integer;TTLeft;>;

  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.function.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>> leftEnd;
    descriptor: Ljava/util/function/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;

  final java.util.function.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>> rightEnd;
    descriptor: Ljava/util/function/Function;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;

  final java.util.function.BiFunction<? super TLeft, ? super TRight, ? extends R> resultSelector;
    descriptor: Ljava/util/function/BiFunction;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/BiFunction<-TTLeft;-TTRight;+TR;>;

  final reactor.core.CoreSubscriber<? super R> actual;
    descriptor: Lreactor/core/CoreSubscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lreactor/core/CoreSubscriber<-TR;>;

  volatile int wip;
    descriptor: I
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.FluxJoin$JoinSubscription> WIP;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/FluxJoin$JoinSubscription;>;

  volatile int active;
    descriptor: I
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicIntegerFieldUpdater<reactor.core.publisher.FluxJoin$JoinSubscription> ACTIVE;
    descriptor: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater<Lreactor/core/publisher/FluxJoin$JoinSubscription;>;

  volatile long requested;
    descriptor: J
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicLongFieldUpdater<reactor.core.publisher.FluxJoin$JoinSubscription> REQUESTED;
    descriptor: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicLongFieldUpdater<Lreactor/core/publisher/FluxJoin$JoinSubscription;>;

  volatile java.lang.Throwable error;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.FluxJoin$JoinSubscription, java.lang.Throwable> ERROR;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/publisher/FluxJoin$JoinSubscription;Ljava/lang/Throwable;>;

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

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

  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=3, locals=0, args_size=0
         0: .line 121
            ldc Lreactor/core/publisher/FluxJoin$JoinSubscription;
            ldc "wip"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         1: .line 120
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         2: .line 126
            ldc Lreactor/core/publisher/FluxJoin$JoinSubscription;
         3: .line 127
            ldc "active"
         4: .line 126
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         5: .line 125
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         6: .line 132
            ldc Lreactor/core/publisher/FluxJoin$JoinSubscription;
         7: .line 133
            ldc "requested"
         8: .line 132
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         9: .line 131
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
        10: .line 138
            ldc Lreactor/core/publisher/FluxJoin$JoinSubscription;
        11: .line 139
            ldc Ljava/lang/Throwable;
        12: .line 140
            ldc "error"
        13: .line 138
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        14: .line 137
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        15: .line 146
            iconst_1
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
        16: .line 148
            iconst_2
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
        17: .line 150
            iconst_3
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
        18: .line 152
            iconst_4
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            putstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super R>, java.util.function.Function<? super TLeft, ? extends org.reactivestreams.Publisher<TLeftEnd>>, java.util.function.Function<? super TRight, ? extends org.reactivestreams.Publisher<TRightEnd>>, java.util.function.BiFunction<? super TLeft, ? super TRight, ? extends R>);
    descriptor: (Lreactor/core/CoreSubscriber;Ljava/util/function/Function;Ljava/util/function/Function;Ljava/util/function/BiFunction;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // java.util.function.Function leftEnd
        start local 3 // java.util.function.Function rightEnd
        start local 4 // java.util.function.BiFunction resultSelector
         0: .line 155
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 159
            aload 0 /* this */
            aload 1 /* actual */
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
         2: .line 160
            aload 0 /* this */
            invokestatic reactor.core.Disposables.composite:()Lreactor/core/Disposable$Composite;
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
         3: .line 161
            aload 0 /* this */
            invokestatic reactor.util.concurrent.Queues.unboundedMultiproducer:()Ljava/util/function/Supplier;
            invokeinterface java.util.function.Supplier.get:()Ljava/lang/Object;
            checkcast java.util.Queue
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.queue:Ljava/util/Queue;
         4: .line 162
            aload 0 /* this */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queue:Ljava/util/Queue;
            checkcast java.util.function.BiPredicate
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
         5: .line 163
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
         6: .line 164
            aload 0 /* this */
            new java.util.LinkedHashMap
            dup
            invokespecial java.util.LinkedHashMap.<init>:()V
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.rights:Ljava/util/Map;
         7: .line 165
            aload 0 /* this */
            aload 2 /* leftEnd */
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.leftEnd:Ljava/util/function/Function;
         8: .line 166
            aload 0 /* this */
            aload 3 /* rightEnd */
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.rightEnd:Ljava/util/function/Function;
         9: .line 167
            aload 0 /* this */
            aload 4 /* resultSelector */
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.resultSelector:Ljava/util/function/BiFunction;
        10: .line 168
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iconst_2
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        11: .line 169
            return
        end local 4 // java.util.function.BiFunction resultSelector
        end local 3 // java.util.function.Function rightEnd
        end local 2 // java.util.function.Function leftEnd
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0            this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0   12     1          actual  Lreactor/core/CoreSubscriber<-TR;>;
            0   12     2         leftEnd  Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;
            0   12     3        rightEnd  Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;
            0   12     4  resultSelector  Ljava/util/function/BiFunction<-TTLeft;-TTRight;+TR;>;
    Signature: (Lreactor/core/CoreSubscriber<-TR;>;Ljava/util/function/Function<-TTLeft;+Lorg/reactivestreams/Publisher<TTLeftEnd;>;>;Ljava/util/function/Function<-TTRight;+Lorg/reactivestreams/Publisher<TTRightEnd;>;>;Ljava/util/function/BiFunction<-TTLeft;-TTRight;+TR;>;)V
    MethodParameters:
                Name  Flags
      actual          
      leftEnd         
      rightEnd        
      resultSelector  

  public final reactor.core.CoreSubscriber<? super R> actual();
    descriptor: ()Lreactor/core/CoreSubscriber;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
         0: .line 173
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            areturn
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
    Signature: ()Lreactor/core/CoreSubscriber<-TR;>;

  public java.util.stream.Stream<? extends reactor.core.Scannable> inners();
    descriptor: ()Ljava/util/stream/Stream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
         0: .line 178
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokestatic reactor.core.Scannable.from:(Ljava/lang/Object;)Lreactor/core/Scannable;
            invokeinterface reactor.core.Scannable.inners:()Ljava/util/stream/Stream;
            areturn
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
    Signature: ()Ljava/util/stream/Stream<+Lreactor/core/Scannable;>;

  public java.lang.Object scanUnsafe(reactor.core.Scannable$Attr);
    descriptor: (Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 184
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.requested:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         1: .line 185
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
            if_acmpne 2
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         2: .line 186
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.BUFFERED:Lreactor/core/Scannable$Attr;
            if_acmpne 3
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.size:()I
            iconst_2
            idiv
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         3: .line 187
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
            if_acmpne 5
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.active:I
            ifne 4
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      StackMap locals:
      StackMap stack:
         4: iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         5: .line 188
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 6
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.error:Ljava/lang/Throwable;
            areturn
         6: .line 189
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 7
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         7: .line 191
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* key */
            invokespecial reactor.core.publisher.FluxGroupJoin$JoinSupport.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    8     1   key  Lreactor/core/Scannable$Attr;
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()
    MethodParameters:
      Name  Flags
      key   

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // long n
         0: .line 196
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.validate:(J)Z
            ifeq 2
         1: .line 197
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.addCap:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
            pop2
         2: .line 199
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<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 // reactor.core.publisher.FluxJoin$JoinSubscription this
         0: .line 203
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
            ifeq 2
         1: .line 204
            return
         2: .line 206
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
         3: .line 207
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 5
         4: .line 208
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
         5: .line 210
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;

  void errorAll(org.reactivestreams.Subscriber<?>);
    descriptor: (Lorg/reactivestreams/Subscriber;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // org.reactivestreams.Subscriber a
         0: .line 213
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            invokestatic reactor.core.Exceptions.terminate:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Ljava/lang/Throwable;
            astore 2 /* ex */
        start local 2 // java.lang.Throwable ex
         1: .line 215
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         2: .line 216
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         3: .line 218
            aload 1 /* a */
            aload 2 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         4: .line 219
            return
        end local 2 // java.lang.Throwable ex
        end local 1 // org.reactivestreams.Subscriber a
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    5     1     a  Lorg/reactivestreams/Subscriber<*>;
            1    5     2    ex  Ljava/lang/Throwable;
    Signature: (Lorg/reactivestreams/Subscriber<*>;)V
    MethodParameters:
      Name  Flags
      a     

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=21, args_size=1
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
         0: .line 222
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifeq 2
         1: .line 223
            return
         2: .line 226
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         3: .line 227
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queue:Ljava/util/Queue;
            astore 2 /* q */
        start local 2 // java.util.Queue q
         4: .line 228
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            astore 3 /* a */
        start local 3 // org.reactivestreams.Subscriber a
         5: .line 232
      StackMap locals: int java.util.Queue org.reactivestreams.Subscriber
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.isDisposed:()Z
            ifeq 8
         6: .line 233
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
         7: .line 234
            return
         8: .line 237
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.error:Ljava/lang/Throwable;
            astore 4 /* ex */
        start local 4 // java.lang.Throwable ex
         9: .line 238
            aload 4 /* ex */
            ifnull 14
        10: .line 239
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
        11: .line 240
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
        12: .line 241
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        13: .line 242
            return
        14: .line 245
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.active: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 247
            aload 2 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 6 /* mode */
        start local 6 // java.lang.Integer mode
        18: .line 249
            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 251
            iload 5 /* d */
            ifeq 27
            iload 7 /* empty */
            ifeq 27
        22: .line 253
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        23: .line 254
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
        24: .line 255
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
        25: .line 257
            aload 3 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        26: .line 258
            return
        27: .line 261
      StackMap locals: int
      StackMap stack:
            iload 7 /* empty */
            ifeq 29
        28: .line 262
            goto 164
        29: .line 265
      StackMap locals:
      StackMap stack:
            aload 2 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 8 /* val */
        start local 8 // java.lang.Object val
        30: .line 267
            aload 6 /* mode */
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
            if_acmpne 92
        31: .line 268
            aload 8 /* val */
            astore 9 /* left */
        start local 9 // java.lang.Object left
        32: .line 270
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.leftIndex:I
            dup_x1
            iconst_1
            iadd
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.leftIndex:I
            istore 10 /* idx */
        start local 10 // int idx
        33: .line 271
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
            iload 10 /* idx */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 9 /* left */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        34: .line 276
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.leftEnd:Ljava/util/function/Function;
            aload 9 /* left */
            invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
        35: .line 277
            ldc "The leftEnd returned a null Publisher"
        36: .line 276
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            astore 11 /* p */
        start local 11 // org.reactivestreams.Publisher p
        37: .line 278
            goto 47
        end local 11 // org.reactivestreams.Publisher p
        38: .line 279
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int
      StackMap stack: java.lang.Throwable
            astore 12 /* exc */
        start local 12 // java.lang.Throwable exc
        39: .line 280
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        40: .line 281
            aload 0 /* this */
        41: .line 282
            aload 0 /* this */
            aload 12 /* exc */
            aload 9 /* left */
        42: .line 283
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        43: .line 282
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
        44: .line 280
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
        45: .line 284
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        46: .line 285
            return
        end local 12 // java.lang.Throwable exc
        start local 11 // org.reactivestreams.Publisher p
        47: .line 289
      StackMap locals: org.reactivestreams.Publisher
      StackMap stack:
            new reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
            dup
            aload 0 /* this */
            iconst_1
            iload 10 /* idx */
            invokespecial reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.<init>:(Lreactor/core/publisher/FluxGroupJoin$JoinSupport;ZI)V
        48: .line 288
            astore 12 /* end */
        start local 12 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
        49: .line 290
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            aload 12 /* end */
            invokeinterface reactor.core.Disposable$Composite.add:(Lreactor/core/Disposable;)Z
            pop
        50: .line 292
            aload 11 /* p */
            aload 12 /* end */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
        51: .line 294
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.error:Ljava/lang/Throwable;
            astore 4 /* ex */
        52: .line 295
            aload 4 /* ex */
            ifnull 57
        53: .line 296
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
        54: .line 297
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
        55: .line 298
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        56: .line 299
            return
        57: .line 302
      StackMap locals: reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.requested:J
            lstore 13 /* r */
        start local 13 // long r
        58: .line 303
            lconst_0
            lstore 15 /* e */
        start local 15 // long e
        59: .line 305
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rights:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 18
            goto 88
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long top java.util.Iterator
      StackMap stack:
        60: aload 18
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 17 /* right */
        start local 17 // java.lang.Object right
        61: .line 310
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.resultSelector:Ljava/util/function/BiFunction;
            aload 9 /* left */
        62: .line 311
            aload 17 /* right */
        63: .line 310
            invokeinterface java.util.function.BiFunction.apply:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
        64: .line 312
            ldc "The resultSelector returned a null value"
        65: .line 310
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 19 /* w */
        start local 19 // java.lang.Object w
        66: .line 313
            goto 76
        end local 19 // java.lang.Object w
        67: .line 314
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long java.lang.Object java.util.Iterator
      StackMap stack: java.lang.Throwable
            astore 20 /* exc */
        start local 20 // java.lang.Throwable exc
        68: .line 315
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        69: .line 316
            aload 0 /* this */
        70: .line 317
            aload 0 /* this */
        71: .line 318
            aload 20 /* exc */
            aload 17 /* right */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        72: .line 317
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
        73: .line 315
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
        74: .line 319
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        75: .line 320
            return
        end local 20 // java.lang.Throwable exc
        start local 19 // java.lang.Object w
        76: .line 323
      StackMap locals: java.lang.Object
      StackMap stack:
            lload 15 /* e */
            lload 13 /* r */
            lcmp
            ifeq 80
        77: .line 324
            aload 3 /* a */
            aload 19 /* w */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        78: .line 326
            lload 15 /* e */
            lconst_1
            ladd
            lstore 15 /* e */
        79: .line 327
            goto 88
        80: .line 329
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
        81: .line 330
            aload 0 /* this */
        82: .line 331
            ldc "Could not emit value due to lack of requests"
            invokestatic reactor.core.Exceptions.failWithOverflow:(Ljava/lang/String;)Ljava/lang/IllegalStateException;
        83: .line 329
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
        84: .line 332
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
        85: .line 333
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
        86: .line 334
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
        87: .line 335
            return
        end local 19 // java.lang.Object w
        end local 17 // java.lang.Object right
        88: .line 305
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long top java.util.Iterator
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 60
        89: .line 339
            lload 15 /* e */
            lconst_0
            lcmp
            ifeq 5
        90: .line 340
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 15 /* e */
            invokestatic reactor.core.publisher.Operators.produced:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
            pop2
        end local 15 // long e
        end local 13 // long r
        end local 12 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
        end local 11 // org.reactivestreams.Publisher p
        end local 10 // int idx
        end local 9 // java.lang.Object left
        91: .line 342
            goto 5
        92: .line 343
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
      StackMap stack:
            aload 6 /* mode */
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
            if_acmpne 154
        93: .line 344
            aload 8 /* val */
            astore 9 /* right */
        start local 9 // java.lang.Object right
        94: .line 346
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rightIndex:I
            dup_x1
            iconst_1
            iadd
            putfield reactor.core.publisher.FluxJoin$JoinSubscription.rightIndex:I
            istore 10 /* idx */
        start local 10 // int idx
        95: .line 348
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.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
        96: .line 353
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rightEnd:Ljava/util/function/Function;
            aload 9 /* right */
            invokeinterface java.util.function.Function.apply:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
        97: .line 354
            ldc "The rightEnd returned a null Publisher"
        98: .line 353
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
            astore 11 /* p */
        start local 11 // org.reactivestreams.Publisher p
        99: .line 355
            goto 109
        end local 11 // org.reactivestreams.Publisher p
       100: .line 356
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int
      StackMap stack: java.lang.Throwable
            astore 12 /* exc */
        start local 12 // java.lang.Throwable exc
       101: .line 357
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
       102: .line 358
            aload 0 /* this */
       103: .line 359
            aload 0 /* this */
            aload 12 /* exc */
            aload 9 /* right */
       104: .line 360
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
       105: .line 359
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
       106: .line 357
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
       107: .line 361
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
       108: .line 362
            return
        end local 12 // java.lang.Throwable exc
        start local 11 // org.reactivestreams.Publisher p
       109: .line 366
      StackMap locals: org.reactivestreams.Publisher
      StackMap stack:
            new reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
            dup
            aload 0 /* this */
            iconst_0
            iload 10 /* idx */
            invokespecial reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.<init>:(Lreactor/core/publisher/FluxGroupJoin$JoinSupport;ZI)V
       110: .line 365
            astore 12 /* end */
        start local 12 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
       111: .line 367
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            aload 12 /* end */
            invokeinterface reactor.core.Disposable$Composite.add:(Lreactor/core/Disposable;)Z
            pop
       112: .line 369
            aload 11 /* p */
            aload 12 /* end */
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
       113: .line 371
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.error:Ljava/lang/Throwable;
            astore 4 /* ex */
       114: .line 372
            aload 4 /* ex */
            ifnull 119
       115: .line 373
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
       116: .line 374
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
       117: .line 375
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
       118: .line 376
            return
       119: .line 379
      StackMap locals: reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.requested:J
            lstore 13 /* r */
        start local 13 // long r
       120: .line 380
            lconst_0
            lstore 15 /* e */
        start local 15 // long e
       121: .line 382
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 18
            goto 150
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long top java.util.Iterator
      StackMap stack:
       122: aload 18
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 17 /* left */
        start local 17 // java.lang.Object left
       123: .line 387
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.resultSelector:Ljava/util/function/BiFunction;
            aload 17 /* left */
       124: .line 388
            aload 9 /* right */
       125: .line 387
            invokeinterface java.util.function.BiFunction.apply:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
       126: .line 389
            ldc "The resultSelector returned a null value"
       127: .line 387
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            astore 19 /* w */
        start local 19 // java.lang.Object w
       128: .line 390
            goto 138
        end local 19 // java.lang.Object w
       129: .line 391
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long java.lang.Object java.util.Iterator
      StackMap stack: java.lang.Throwable
            astore 20 /* exc */
        start local 20 // java.lang.Throwable exc
       130: .line 392
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
       131: .line 393
            aload 0 /* this */
       132: .line 394
            aload 0 /* this */
            aload 20 /* exc */
            aload 17 /* left */
       133: .line 395
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
       134: .line 394
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
       135: .line 392
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
       136: .line 396
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
       137: .line 397
            return
        end local 20 // java.lang.Throwable exc
        start local 19 // java.lang.Object w
       138: .line 400
      StackMap locals: java.lang.Object
      StackMap stack:
            lload 15 /* e */
            lload 13 /* r */
            lcmp
            ifeq 142
       139: .line 401
            aload 3 /* a */
            aload 19 /* w */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
       140: .line 403
            lload 15 /* e */
            lconst_1
            ladd
            lstore 15 /* e */
       141: .line 404
            goto 150
       142: .line 406
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
       143: .line 407
            aload 0 /* this */
       144: .line 408
            ldc "Could not emit value due to lack of requests"
            invokestatic reactor.core.Exceptions.failWithOverflow:(Ljava/lang/String;)Ljava/lang/IllegalStateException;
       145: .line 406
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
       146: .line 409
            aload 2 /* q */
            invokeinterface java.util.Queue.clear:()V
       147: .line 410
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            invokeinterface reactor.core.Disposable$Composite.dispose:()V
       148: .line 411
            aload 0 /* this */
            aload 3 /* a */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.errorAll:(Lorg/reactivestreams/Subscriber;)V
       149: .line 412
            return
        end local 19 // java.lang.Object w
        end local 17 // java.lang.Object left
       150: .line 382
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object java.lang.Object int org.reactivestreams.Publisher reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber long long top java.util.Iterator
      StackMap stack:
            aload 18
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 122
       151: .line 416
            lload 15 /* e */
            lconst_0
            lcmp
            ifeq 5
       152: .line 417
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 15 /* e */
            invokestatic reactor.core.publisher.Operators.produced:(Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;Ljava/lang/Object;J)J
            pop2
        end local 15 // long e
        end local 13 // long r
        end local 12 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
        end local 11 // org.reactivestreams.Publisher p
        end local 10 // int idx
        end local 9 // java.lang.Object right
       153: .line 419
            goto 5
       154: .line 420
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber java.lang.Throwable int java.lang.Integer int java.lang.Object
      StackMap stack:
            aload 6 /* mode */
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
            if_acmpne 159
       155: .line 421
            aload 8 /* val */
            checkcast reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
            astore 9 /* end */
        start local 9 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
       156: .line 423
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.lefts:Ljava/util/Map;
            aload 9 /* end */
            getfield reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.index:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
       157: .line 424
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            aload 9 /* end */
            invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
            pop
        end local 9 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
       158: .line 425
            goto 5
       159: .line 426
      StackMap locals:
      StackMap stack:
            aload 6 /* mode */
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
            if_acmpne 5
       160: .line 427
            aload 8 /* val */
            checkcast reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
            astore 9 /* end */
        start local 9 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber end
       161: .line 429
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.rights:Ljava/util/Map;
            aload 9 /* end */
            getfield reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber.index:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
       162: .line 430
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            aload 9 /* end */
            invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
            pop
        end local 9 // reactor.core.publisher.FluxGroupJoin$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
       163: .line 231
            goto 5
       164: .line 434
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.util.Queue org.reactivestreams.Subscriber
      StackMap stack:
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.addAndGet:(Ljava/lang/Object;I)I
            istore 1 /* missed */
       165: .line 435
            iload 1 /* missed */
            ifne 5
       166: .line 439
            return
        end local 3 // org.reactivestreams.Subscriber a
        end local 2 // java.util.Queue q
        end local 1 // int missed
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0  167     0    this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            3  167     1  missed  I
            4  167     2       q  Ljava/util/Queue<Ljava/lang/Object;>;
            5  167     3       a  Lorg/reactivestreams/Subscriber<-TR;>;
            9  163     4      ex  Ljava/lang/Throwable;
           17  163     5       d  Z
           18  163     6    mode  Ljava/lang/Integer;
           21  163     7   empty  Z
           30  163     8     val  Ljava/lang/Object;
           32   91     9    left  TTLeft;
           33   91    10     idx  I
           37   38    11       p  Lorg/reactivestreams/Publisher<TTLeftEnd;>;
           47   91    11       p  Lorg/reactivestreams/Publisher<TTLeftEnd;>;
           39   47    12     exc  Ljava/lang/Throwable;
           49   91    12     end  Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
           58   91    13       r  J
           59   91    15       e  J
           61   88    17   right  TTRight;
           66   67    19       w  TR;
           76   88    19       w  TR;
           68   76    20     exc  Ljava/lang/Throwable;
           94  153     9   right  TTRight;
           95  153    10     idx  I
           99  100    11       p  Lorg/reactivestreams/Publisher<TTRightEnd;>;
          109  153    11       p  Lorg/reactivestreams/Publisher<TTRightEnd;>;
          101  109    12     exc  Ljava/lang/Throwable;
          111  153    12     end  Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
          120  153    13       r  J
          121  153    15       e  J
          123  150    17    left  TTLeft;
          128  129    19       w  TR;
          138  150    19       w  TR;
          130  138    20     exc  Ljava/lang/Throwable;
          156  158     9     end  Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
          161  163     9     end  Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
      Exception table:
        from    to  target  type
          34    37      38  Class java.lang.Throwable
          61    66      67  Class java.lang.Throwable
          96    99     100  Class java.lang.Throwable
         123   128     129  Class java.lang.Throwable

  public void innerError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // java.lang.Throwable ex
         0: .line 443
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* ex */
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            ifeq 4
         1: .line 444
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            pop
         2: .line 445
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.drain:()V
         3: .line 446
            goto 5
         4: .line 448
      StackMap locals:
      StackMap stack:
            aload 1 /* ex */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            invokestatic reactor.core.publisher.Operators.onErrorDropped:(Ljava/lang/Throwable;Lreactor/util/context/Context;)V
         5: .line 450
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable ex
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    6     1    ex  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      ex    

  public void innerComplete(reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber);
    descriptor: (Lreactor/core/publisher/FluxGroupJoin$LeftRightSubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber sender
         0: .line 454
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.cancellations:Lreactor/core/Disposable$Composite;
            aload 1 /* sender */
            invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
            pop
         1: .line 455
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ACTIVE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            pop
         2: .line 456
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.drain:()V
         3: .line 457
            return
        end local 1 // reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber sender
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    4     1  sender  Lreactor/core/publisher/FluxGroupJoin$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=3, args_size=3
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // boolean isLeft
        start local 2 // java.lang.Object o
         0: .line 461
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
            iload 1 /* isLeft */
            ifeq 1
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_VALUE:Ljava/lang/Integer;
            goto 2
      StackMap locals:
      StackMap stack: java.util.function.BiPredicate
         1: getstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_VALUE:Ljava/lang/Integer;
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int java.lang.Object
      StackMap stack: java.util.function.BiPredicate java.lang.Integer
         2: aload 2 /* o */
            invokeinterface java.util.function.BiPredicate.test:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
         3: .line 462
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.drain:()V
         4: .line 463
            return
        end local 2 // java.lang.Object o
        end local 1 // boolean isLeft
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    5     1  isLeft  Z
            0    5     2       o  Ljava/lang/Object;
    MethodParameters:
        Name  Flags
      isLeft  
      o       

  public void innerClose(boolean, reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber);
    descriptor: (ZLreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // boolean isLeft
        start local 2 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber index
         0: .line 467
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.queueBiOffer:Ljava/util/function/BiPredicate;
            iload 1 /* isLeft */
            ifeq 1
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.LEFT_CLOSE:Ljava/lang/Integer;
            goto 2
      StackMap locals:
      StackMap stack: java.util.function.BiPredicate
         1: getstatic reactor.core.publisher.FluxJoin$JoinSubscription.RIGHT_CLOSE:Ljava/lang/Integer;
      StackMap locals: reactor.core.publisher.FluxJoin$JoinSubscription int reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber
      StackMap stack: java.util.function.BiPredicate java.lang.Integer
         2: aload 2 /* index */
            invokeinterface java.util.function.BiPredicate.test:(Ljava/lang/Object;Ljava/lang/Object;)Z
            pop
         3: .line 468
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.drain:()V
         4: .line 469
            return
        end local 2 // reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber index
        end local 1 // boolean isLeft
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    5     0    this  Lreactor/core/publisher/FluxJoin$JoinSubscription<TTLeft;TTRight;TTLeftEnd;TTRightEnd;TR;>;
            0    5     1  isLeft  Z
            0    5     2   index  Lreactor/core/publisher/FluxGroupJoin$LeftRightEndSubscriber;
    MethodParameters:
        Name  Flags
      isLeft  
      index   

  public void innerCloseError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
        start local 1 // java.lang.Throwable ex
         0: .line 473
            getstatic reactor.core.publisher.FluxJoin$JoinSubscription.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* ex */
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            ifeq 3
         1: .line 474
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxJoin$JoinSubscription.drain:()V
         2: .line 475
            goto 4
         3: .line 477
      StackMap locals:
      StackMap stack:
            aload 1 /* ex */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxJoin$JoinSubscription.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            invokestatic reactor.core.publisher.Operators.onErrorDropped:(Ljava/lang/Throwable;Lreactor/util/context/Context;)V
         4: .line 479
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable ex
        end local 0 // reactor.core.publisher.FluxJoin$JoinSubscription this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lreactor/core/publisher/FluxJoin$JoinSubscription<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/lang/Object;Lreactor/core/publisher/FluxGroupJoin$JoinSupport<TR;>;
SourceFile: "FluxJoin.java"
NestHost: reactor.core.publisher.FluxJoin
InnerClasses:
  public abstract Composite = reactor.core.Disposable$Composite of reactor.core.Disposable
  public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
  public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
  abstract JoinSupport = reactor.core.publisher.FluxGroupJoin$JoinSupport of reactor.core.publisher.FluxGroupJoin
  final LeftRightEndSubscriber = reactor.core.publisher.FluxGroupJoin$LeftRightEndSubscriber of reactor.core.publisher.FluxGroupJoin
  final LeftRightSubscriber = reactor.core.publisher.FluxGroupJoin$LeftRightSubscriber of reactor.core.publisher.FluxGroupJoin
  final JoinSubscription = reactor.core.publisher.FluxJoin$JoinSubscription of reactor.core.publisher.FluxJoin