final class io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher<T> extends java.util.concurrent.atomic.AtomicInteger implements io.reactivex.FlowableSubscriber<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher
  super_class: java.util.concurrent.atomic.AtomicInteger
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: -4470634016609963609

  final org.reactivestreams.Subscriber<? super T>[] subscribers;
    descriptor: [Lorg/reactivestreams/Subscriber;
    flags: (0x0010) ACC_FINAL
    Signature: [Lorg/reactivestreams/Subscriber<-TT;>;

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

  final long[] emissions;
    descriptor: [J
    flags: (0x0010) ACC_FINAL

  final int prefetch;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  final int limit;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  org.reactivestreams.Subscription upstream;
    descriptor: Lorg/reactivestreams/Subscription;
    flags: (0x0000) 

  io.reactivex.internal.fuseable.SimpleQueue<T> queue;
    descriptor: Lio/reactivex/internal/fuseable/SimpleQueue;
    flags: (0x0000) 
    Signature: Lio/reactivex/internal/fuseable/SimpleQueue<TT;>;

  java.lang.Throwable error;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0000) 

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

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

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

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

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

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

  void <init>(org.reactivestreams.Subscriber<? super T>[], );
    descriptor: ([Lorg/reactivestreams/Subscriber;I)V
    flags: (0x0000) 
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
        start local 1 // org.reactivestreams.Subscriber[] subscribers
        start local 2 // int prefetch
         0: .line 99
            aload 0 /* this */
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
         1: .line 93
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscriberCount:Ljava/util/concurrent/atomic/AtomicInteger;
         2: .line 100
            aload 0 /* this */
            aload 1 /* subscribers */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscribers:[Lorg/reactivestreams/Subscriber;
         3: .line 101
            aload 0 /* this */
            iload 2 /* prefetch */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.prefetch:I
         4: .line 102
            aload 0 /* this */
            iload 2 /* prefetch */
            iload 2 /* prefetch */
            iconst_2
            ishr
            isub
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.limit:I
         5: .line 103
            aload 1 /* subscribers */
            arraylength
            istore 3 /* m */
        start local 3 // int m
         6: .line 104
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLongArray
            dup
            iload 3 /* m */
            iload 3 /* m */
            iadd
            iconst_1
            iadd
            invokespecial java.util.concurrent.atomic.AtomicLongArray.<init>:(I)V
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.requests:Ljava/util/concurrent/atomic/AtomicLongArray;
         7: .line 105
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.requests:Ljava/util/concurrent/atomic/AtomicLongArray;
            iload 3 /* m */
            iload 3 /* m */
            iadd
            iload 3 /* m */
            i2l
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.lazySet:(IJ)V
         8: .line 106
            aload 0 /* this */
            iload 3 /* m */
            newarray 11
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.emissions:[J
         9: .line 107
            return
        end local 3 // int m
        end local 2 // int prefetch
        end local 1 // org.reactivestreams.Subscriber[] subscribers
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   10     0         this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            0   10     1  subscribers  [Lorg/reactivestreams/Subscriber;
            0   10     2     prefetch  I
            6   10     3            m  I
    Signature: ([Lorg/reactivestreams/Subscriber<-TT;>;I)V
    MethodParameters:
             Name  Flags
      subscribers  
      prefetch     

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 111
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 21
         1: .line 112
            aload 0 /* this */
            aload 1 /* s */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
         2: .line 114
            aload 1 /* s */
            instanceof io.reactivex.internal.fuseable.QueueSubscription
            ifeq 18
         3: .line 116
            aload 1 /* s */
            checkcast io.reactivex.internal.fuseable.QueueSubscription
            astore 2 /* qs */
        start local 2 // io.reactivex.internal.fuseable.QueueSubscription qs
         4: .line 118
            aload 2 /* qs */
            bipush 7
            invokeinterface io.reactivex.internal.fuseable.QueueSubscription.requestFusion:(I)I
            istore 3 /* m */
        start local 3 // int m
         5: .line 120
            iload 3 /* m */
            iconst_1
            if_icmpne 12
         6: .line 121
            aload 0 /* this */
            iload 3 /* m */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.sourceMode:I
         7: .line 122
            aload 0 /* this */
            aload 2 /* qs */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
         8: .line 123
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.done:Z
         9: .line 124
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.setupSubscribers:()V
        10: .line 125
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drain:()V
        11: .line 126
            return
        12: .line 128
      StackMap locals: io.reactivex.internal.fuseable.QueueSubscription int
      StackMap stack:
            iload 3 /* m */
            iconst_2
            if_icmpne 18
        13: .line 129
            aload 0 /* this */
            iload 3 /* m */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.sourceMode:I
        14: .line 130
            aload 0 /* this */
            aload 2 /* qs */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
        15: .line 132
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.setupSubscribers:()V
        16: .line 134
            aload 1 /* s */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.prefetch:I
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        17: .line 136
            return
        end local 3 // int m
        end local 2 // io.reactivex.internal.fuseable.QueueSubscription qs
        18: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new io.reactivex.internal.queue.SpscArrayQueue
            dup
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.prefetch:I
            invokespecial io.reactivex.internal.queue.SpscArrayQueue.<init>:(I)V
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
        19: .line 142
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.setupSubscribers:()V
        20: .line 144
            aload 1 /* s */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.prefetch:I
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        21: .line 146
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   22     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            0   22     1     s  Lorg/reactivestreams/Subscription;
            4   18     2    qs  Lio/reactivex/internal/fuseable/QueueSubscription<TT;>;
            5   18     3     m  I
    MethodParameters:
      Name  Flags
      s     

  void setupSubscribers();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=4, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
         0: .line 149
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscribers:[Lorg/reactivestreams/Subscriber;
            astore 1 /* subs */
        start local 1 // org.reactivestreams.Subscriber[] subs
         1: .line 150
            aload 1 /* subs */
            arraylength
            istore 2 /* m */
        start local 2 // int m
         2: .line 152
            iconst_0
            istore 3 /* i */
        start local 3 // int i
         3: goto 9
         4: .line 153
      StackMap locals: org.reactivestreams.Subscriber[] int int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.cancelled:Z
            ifeq 6
         5: .line 154
            return
         6: .line 157
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscriberCount:Ljava/util/concurrent/atomic/AtomicInteger;
            iload 3 /* i */
            iconst_1
            iadd
            invokevirtual java.util.concurrent.atomic.AtomicInteger.lazySet:(I)V
         7: .line 159
            aload 1 /* subs */
            iload 3 /* i */
            aaload
            new io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher$RailSubscription
            dup
            aload 0 /* this */
            iload 3 /* i */
            iload 2 /* m */
            invokespecial io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher$RailSubscription.<init>:(Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher;II)V
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         8: .line 152
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
         9: iload 3 /* i */
            iload 2 /* m */
            if_icmplt 4
        end local 3 // int i
        10: .line 161
            return
        end local 2 // int m
        end local 1 // org.reactivestreams.Subscriber[] subs
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            1   11     1  subs  [Lorg/reactivestreams/Subscriber;
            2   11     2     m  I
            3   10     3     i  I

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
        start local 1 // java.lang.Object t
         0: .line 204
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.sourceMode:I
            ifne 5
         1: .line 205
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
            aload 1 /* t */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.offer:(Ljava/lang/Object;)Z
            ifne 5
         2: .line 206
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         3: .line 207
            aload 0 /* this */
            new io.reactivex.exceptions.MissingBackpressureException
            dup
            ldc "Queue is full?"
            invokespecial io.reactivex.exceptions.MissingBackpressureException.<init>:(Ljava/lang/String;)V
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.onError:(Ljava/lang/Throwable;)V
         4: .line 208
            return
         5: .line 211
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drain:()V
         6: .line 212
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            0    7     1     t  TT;
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
        start local 1 // java.lang.Throwable t
         0: .line 216
            aload 0 /* this */
            aload 1 /* t */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.error:Ljava/lang/Throwable;
         1: .line 217
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.done:Z
         2: .line 218
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drain:()V
         3: .line 219
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            0    4     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
         0: .line 223
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.done:Z
         1: .line 224
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drain:()V
         2: .line 225
            return
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;

  void cancel(int);
    descriptor: (I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
        start local 1 // int m
         0: .line 228
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.requests:Ljava/util/concurrent/atomic/AtomicLongArray;
            iload 1 /* m */
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.decrementAndGet:(I)J
            lconst_0
            lcmp
            ifne 5
         1: .line 229
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.cancelled:Z
         2: .line 230
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         3: .line 232
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.getAndIncrement:()I
            ifne 5
         4: .line 233
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.clear:()V
         5: .line 236
      StackMap locals:
      StackMap stack:
            return
        end local 1 // int m
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            0    6     1     m  I
    MethodParameters:
      Name  Flags
      m     

  void drainAsync();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=22, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
         0: .line 239
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 241
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
            astore 2 /* q */
        start local 2 // io.reactivex.internal.fuseable.SimpleQueue q
         2: .line 242
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscribers:[Lorg/reactivestreams/Subscriber;
            astore 3 /* a */
        start local 3 // org.reactivestreams.Subscriber[] a
         3: .line 243
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.requests:Ljava/util/concurrent/atomic/AtomicLongArray;
            astore 4 /* r */
        start local 4 // java.util.concurrent.atomic.AtomicLongArray r
         4: .line 244
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.emissions:[J
            astore 5 /* e */
        start local 5 // long[] e
         5: .line 245
            aload 5 /* e */
            arraylength
            istore 6 /* n */
        start local 6 // int n
         6: .line 246
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.index:I
            istore 7 /* idx */
        start local 7 // int idx
         7: .line 247
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.produced:I
            istore 8 /* consumed */
        start local 8 // int consumed
         8: .line 251
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int
      StackMap stack:
            iconst_0
            istore 9 /* notReady */
        start local 9 // int notReady
         9: .line 254
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.cancelled:Z
            ifeq 12
        10: .line 255
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.clear:()V
        11: .line 256
            return
        12: .line 259
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.done:Z
            istore 10 /* d */
        start local 10 // boolean d
        13: .line 260
            iload 10 /* d */
            ifeq 23
        14: .line 261
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.error:Ljava/lang/Throwable;
            astore 11 /* ex */
        start local 11 // java.lang.Throwable ex
        15: .line 262
            aload 11 /* ex */
            ifnull 23
        16: .line 263
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.clear:()V
        17: .line 264
            aload 3 /* a */
            dup
            astore 15
            arraylength
            istore 14
            iconst_0
            istore 13
            goto 21
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int java.lang.Throwable top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        18: aload 15
            iload 13
            aaload
            astore 12 /* s */
        start local 12 // org.reactivestreams.Subscriber s
        19: .line 265
            aload 12 /* s */
            aload 11 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        end local 12 // org.reactivestreams.Subscriber s
        20: .line 264
            iinc 13 1
      StackMap locals:
      StackMap stack:
        21: iload 13
            iload 14
            if_icmplt 18
        22: .line 267
            return
        end local 11 // java.lang.Throwable ex
        23: .line 271
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int
      StackMap stack:
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.isEmpty:()Z
            istore 11 /* empty */
        start local 11 // boolean empty
        24: .line 273
            iload 10 /* d */
            ifeq 31
            iload 11 /* empty */
            ifeq 31
        25: .line 274
            aload 3 /* a */
            dup
            astore 15
            arraylength
            istore 14
            iconst_0
            istore 13
            goto 29
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int int top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        26: aload 15
            iload 13
            aaload
            astore 12 /* s */
        start local 12 // org.reactivestreams.Subscriber s
        27: .line 275
            aload 12 /* s */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        end local 12 // org.reactivestreams.Subscriber s
        28: .line 274
            iinc 13 1
      StackMap locals:
      StackMap stack:
        29: iload 13
            iload 14
            if_icmplt 26
        30: .line 277
            return
        31: .line 280
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int int
      StackMap stack:
            iload 11 /* empty */
            ifeq 33
        32: .line 281
            goto 62
        33: .line 284
      StackMap locals:
      StackMap stack:
            aload 4 /* r */
            iload 7 /* idx */
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.get:(I)J
            lstore 12 /* requestAtIndex */
        start local 12 // long requestAtIndex
        34: .line 285
            aload 5 /* e */
            iload 7 /* idx */
            laload
            lstore 14 /* emissionAtIndex */
        start local 14 // long emissionAtIndex
        35: .line 286
            lload 12 /* requestAtIndex */
            lload 14 /* emissionAtIndex */
            lcmp
            ifeq 57
            aload 4 /* r */
            iload 6 /* n */
            iload 7 /* idx */
            iadd
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.get:(I)J
            lconst_0
            lcmp
            ifne 57
        36: .line 291
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.poll:()Ljava/lang/Object;
            astore 16 /* v */
        start local 16 // java.lang.Object v
        37: .line 292
            goto 47
        end local 16 // java.lang.Object v
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int int long long
      StackMap stack: java.lang.Throwable
        38: astore 17 /* ex */
        start local 17 // java.lang.Throwable ex
        39: .line 293
            aload 17 /* ex */
            invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
        40: .line 294
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
        41: .line 295
            aload 3 /* a */
            dup
            astore 21
            arraylength
            istore 20
            iconst_0
            istore 19
            goto 45
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int int long long top java.lang.Throwable top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        42: aload 21
            iload 19
            aaload
            astore 18 /* s */
        start local 18 // org.reactivestreams.Subscriber s
        43: .line 296
            aload 18 /* s */
            aload 17 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        end local 18 // org.reactivestreams.Subscriber s
        44: .line 295
            iinc 19 1
      StackMap locals:
      StackMap stack:
        45: iload 19
            iload 20
            if_icmplt 42
        46: .line 298
            return
        end local 17 // java.lang.Throwable ex
        start local 16 // java.lang.Object v
        47: .line 301
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int int int long long java.lang.Object
      StackMap stack:
            aload 16 /* v */
            ifnonnull 49
        48: .line 302
            goto 62
        49: .line 305
      StackMap locals:
      StackMap stack:
            aload 3 /* a */
            iload 7 /* idx */
            aaload
            aload 16 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        50: .line 307
            aload 5 /* e */
            iload 7 /* idx */
            lload 14 /* emissionAtIndex */
            lconst_1
            ladd
            lastore
        51: .line 309
            iinc 8 /* consumed */ 1
            iload 8 /* consumed */
            istore 17 /* c */
        start local 17 // int c
        52: .line 310
            iload 17 /* c */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.limit:I
            if_icmpne 55
        53: .line 311
            iconst_0
            istore 8 /* consumed */
        54: .line 312
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            iload 17 /* c */
            i2l
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        55: .line 314
      StackMap locals: int
      StackMap stack:
            iconst_0
            istore 9 /* notReady */
        end local 17 // int c
        end local 16 // java.lang.Object v
        56: .line 315
            goto 58
        57: .line 316
      StackMap locals:
      StackMap stack:
            iinc 9 /* notReady */ 1
        58: .line 319
      StackMap locals:
      StackMap stack:
            iinc 7 /* idx */ 1
        59: .line 320
            iload 7 /* idx */
            iload 6 /* n */
            if_icmpne 61
        60: .line 321
            iconst_0
            istore 7 /* idx */
        61: .line 324
      StackMap locals:
      StackMap stack:
            iload 9 /* notReady */
            iload 6 /* n */
            if_icmpne 9
        end local 14 // long emissionAtIndex
        end local 12 // long requestAtIndex
        end local 11 // boolean empty
        end local 10 // boolean d
        62: .line 329
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.get:()I
            istore 10 /* w */
        start local 10 // int w
        63: .line 330
            iload 10 /* w */
            iload 1 /* missed */
            if_icmpne 69
        64: .line 331
            aload 0 /* this */
            iload 7 /* idx */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.index:I
        65: .line 332
            aload 0 /* this */
            iload 8 /* consumed */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.produced:I
        66: .line 333
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.addAndGet:(I)I
            istore 1 /* missed */
        67: .line 334
            iload 1 /* missed */
            ifne 8
        68: .line 335
            goto 71
        69: .line 338
      StackMap locals: int
      StackMap stack:
            iload 10 /* w */
            istore 1 /* missed */
        end local 10 // int w
        end local 9 // int notReady
        70: .line 249
            goto 8
        71: .line 341
      StackMap locals:
      StackMap stack:
            return
        end local 8 // int consumed
        end local 7 // int idx
        end local 6 // int n
        end local 5 // long[] e
        end local 4 // java.util.concurrent.atomic.AtomicLongArray r
        end local 3 // org.reactivestreams.Subscriber[] a
        end local 2 // io.reactivex.internal.fuseable.SimpleQueue q
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   72     0             this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            1   72     1           missed  I
            2   72     2                q  Lio/reactivex/internal/fuseable/SimpleQueue<TT;>;
            3   72     3                a  [Lorg/reactivestreams/Subscriber;
            4   72     4                r  Ljava/util/concurrent/atomic/AtomicLongArray;
            5   72     5                e  [J
            6   72     6                n  I
            7   72     7              idx  I
            8   72     8         consumed  I
            9   70     9         notReady  I
           13   62    10                d  Z
           15   23    11               ex  Ljava/lang/Throwable;
           19   20    12                s  Lorg/reactivestreams/Subscriber<-TT;>;
           24   62    11            empty  Z
           27   28    12                s  Lorg/reactivestreams/Subscriber<-TT;>;
           34   62    12   requestAtIndex  J
           35   62    14  emissionAtIndex  J
           37   38    16                v  TT;
           47   56    16                v  TT;
           39   47    17               ex  Ljava/lang/Throwable;
           43   44    18                s  Lorg/reactivestreams/Subscriber<-TT;>;
           52   56    17                c  I
           63   70    10                w  I
      Exception table:
        from    to  target  type
          36    37      38  Class java.lang.Throwable

  void drainSync();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=6, locals=20, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
         0: .line 344
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 346
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.queue:Lio/reactivex/internal/fuseable/SimpleQueue;
            astore 2 /* q */
        start local 2 // io.reactivex.internal.fuseable.SimpleQueue q
         2: .line 347
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.subscribers:[Lorg/reactivestreams/Subscriber;
            astore 3 /* a */
        start local 3 // org.reactivestreams.Subscriber[] a
         3: .line 348
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.requests:Ljava/util/concurrent/atomic/AtomicLongArray;
            astore 4 /* r */
        start local 4 // java.util.concurrent.atomic.AtomicLongArray r
         4: .line 349
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.emissions:[J
            astore 5 /* e */
        start local 5 // long[] e
         5: .line 350
            aload 5 /* e */
            arraylength
            istore 6 /* n */
        start local 6 // int n
         6: .line 351
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.index:I
            istore 7 /* idx */
        start local 7 // int idx
         7: .line 355
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int
      StackMap stack:
            iconst_0
            istore 8 /* notReady */
        start local 8 // int notReady
         8: .line 358
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.cancelled:Z
            ifeq 11
         9: .line 359
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.clear:()V
        10: .line 360
            return
        11: .line 363
      StackMap locals:
      StackMap stack:
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.isEmpty:()Z
            istore 9 /* empty */
        start local 9 // boolean empty
        12: .line 365
            iload 9 /* empty */
            ifeq 19
        13: .line 366
            aload 3 /* a */
            dup
            astore 13
            arraylength
            istore 12
            iconst_0
            istore 11
            goto 17
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        14: aload 13
            iload 11
            aaload
            astore 10 /* s */
        start local 10 // org.reactivestreams.Subscriber s
        15: .line 367
            aload 10 /* s */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        end local 10 // org.reactivestreams.Subscriber s
        16: .line 366
            iinc 11 1
      StackMap locals:
      StackMap stack:
        17: iload 11
            iload 12
            if_icmplt 14
        18: .line 369
            return
        19: .line 372
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int
      StackMap stack:
            aload 4 /* r */
            iload 7 /* idx */
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.get:(I)J
            lstore 10 /* requestAtIndex */
        start local 10 // long requestAtIndex
        20: .line 373
            aload 5 /* e */
            iload 7 /* idx */
            laload
            lstore 12 /* emissionAtIndex */
        start local 12 // long emissionAtIndex
        21: .line 374
            lload 10 /* requestAtIndex */
            lload 12 /* emissionAtIndex */
            lcmp
            ifeq 44
            aload 4 /* r */
            iload 6 /* n */
            iload 7 /* idx */
            iadd
            invokevirtual java.util.concurrent.atomic.AtomicLongArray.get:(I)J
            lconst_0
            lcmp
            ifne 44
        22: .line 379
            aload 2 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimpleQueue.poll:()Ljava/lang/Object;
            astore 14 /* v */
        start local 14 // java.lang.Object v
        23: .line 380
            goto 33
        end local 14 // java.lang.Object v
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int long long
      StackMap stack: java.lang.Throwable
        24: astore 15 /* ex */
        start local 15 // java.lang.Throwable ex
        25: .line 381
            aload 15 /* ex */
            invokestatic io.reactivex.exceptions.Exceptions.throwIfFatal:(Ljava/lang/Throwable;)V
        26: .line 382
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
        27: .line 383
            aload 3 /* a */
            dup
            astore 19
            arraylength
            istore 18
            iconst_0
            istore 17
            goto 31
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int long long top java.lang.Throwable top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        28: aload 19
            iload 17
            aaload
            astore 16 /* s */
        start local 16 // org.reactivestreams.Subscriber s
        29: .line 384
            aload 16 /* s */
            aload 15 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        end local 16 // org.reactivestreams.Subscriber s
        30: .line 383
            iinc 17 1
      StackMap locals:
      StackMap stack:
        31: iload 17
            iload 18
            if_icmplt 28
        32: .line 386
            return
        end local 15 // java.lang.Throwable ex
        start local 14 // java.lang.Object v
        33: .line 389
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int long long java.lang.Object
      StackMap stack:
            aload 14 /* v */
            ifnonnull 40
        34: .line 390
            aload 3 /* a */
            dup
            astore 18
            arraylength
            istore 17
            iconst_0
            istore 16
            goto 38
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int long long java.lang.Object top int int org.reactivestreams.Subscriber[]
      StackMap stack:
        35: aload 18
            iload 16
            aaload
            astore 15 /* s */
        start local 15 // org.reactivestreams.Subscriber s
        36: .line 391
            aload 15 /* s */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        end local 15 // org.reactivestreams.Subscriber s
        37: .line 390
            iinc 16 1
      StackMap locals:
      StackMap stack:
        38: iload 16
            iload 17
            if_icmplt 35
        39: .line 393
            return
        40: .line 396
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int long long java.lang.Object
      StackMap stack:
            aload 3 /* a */
            iload 7 /* idx */
            aaload
            aload 14 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        41: .line 398
            aload 5 /* e */
            iload 7 /* idx */
            lload 12 /* emissionAtIndex */
            lconst_1
            ladd
            lastore
        42: .line 400
            iconst_0
            istore 8 /* notReady */
        end local 14 // java.lang.Object v
        43: .line 401
            goto 45
        44: .line 402
      StackMap locals:
      StackMap stack:
            iinc 8 /* notReady */ 1
        45: .line 405
      StackMap locals:
      StackMap stack:
            iinc 7 /* idx */ 1
        46: .line 406
            iload 7 /* idx */
            iload 6 /* n */
            if_icmpne 48
        47: .line 407
            iconst_0
            istore 7 /* idx */
        48: .line 410
      StackMap locals:
      StackMap stack:
            iload 8 /* notReady */
            iload 6 /* n */
            if_icmpne 8
        end local 12 // long emissionAtIndex
        end local 10 // long requestAtIndex
        end local 9 // boolean empty
        49: .line 415
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.get:()I
            istore 9 /* w */
        start local 9 // int w
        50: .line 416
            iload 9 /* w */
            iload 1 /* missed */
            if_icmpne 55
        51: .line 417
            aload 0 /* this */
            iload 7 /* idx */
            putfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.index:I
        52: .line 418
            aload 0 /* this */
            iload 1 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.addAndGet:(I)I
            istore 1 /* missed */
        53: .line 419
            iload 1 /* missed */
            ifne 7
        54: .line 420
            goto 57
        55: .line 423
      StackMap locals: io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher int io.reactivex.internal.fuseable.SimpleQueue org.reactivestreams.Subscriber[] java.util.concurrent.atomic.AtomicLongArray long[] int int int int
      StackMap stack:
            iload 9 /* w */
            istore 1 /* missed */
        end local 9 // int w
        end local 8 // int notReady
        56: .line 353
            goto 7
        57: .line 426
      StackMap locals:
      StackMap stack:
            return
        end local 7 // int idx
        end local 6 // int n
        end local 5 // long[] e
        end local 4 // java.util.concurrent.atomic.AtomicLongArray r
        end local 3 // org.reactivestreams.Subscriber[] a
        end local 2 // io.reactivex.internal.fuseable.SimpleQueue q
        end local 1 // int missed
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   58     0             this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
            1   58     1           missed  I
            2   58     2                q  Lio/reactivex/internal/fuseable/SimpleQueue<TT;>;
            3   58     3                a  [Lorg/reactivestreams/Subscriber;
            4   58     4                r  Ljava/util/concurrent/atomic/AtomicLongArray;
            5   58     5                e  [J
            6   58     6                n  I
            7   58     7              idx  I
            8   56     8         notReady  I
           12   49     9            empty  Z
           15   16    10                s  Lorg/reactivestreams/Subscriber<-TT;>;
           20   49    10   requestAtIndex  J
           21   49    12  emissionAtIndex  J
           23   24    14                v  TT;
           33   43    14                v  TT;
           25   33    15               ex  Ljava/lang/Throwable;
           29   30    16                s  Lorg/reactivestreams/Subscriber<-TT;>;
           36   37    15                s  Lorg/reactivestreams/Subscriber<-TT;>;
           50   56     9                w  I
      Exception table:
        from    to  target  type
          22    23      24  Class java.lang.Throwable

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
         0: .line 429
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.getAndIncrement:()I
            ifeq 2
         1: .line 430
            return
         2: .line 433
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.sourceMode:I
            iconst_1
            if_icmpne 5
         3: .line 434
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drainSync:()V
         4: .line 435
            goto 6
         5: .line 436
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher.drainAsync:()V
         6: .line 438
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/parallel/ParallelFromPublisher$ParallelDispatcher<TT;>;
}
Signature: <T:Ljava/lang/Object;>Ljava/util/concurrent/atomic/AtomicInteger;Lio/reactivex/FlowableSubscriber<TT;>;
SourceFile: "ParallelFromPublisher.java"
NestHost: io.reactivex.internal.operators.parallel.ParallelFromPublisher
InnerClasses:
  final ParallelDispatcher = io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher of io.reactivex.internal.operators.parallel.ParallelFromPublisher
  final RailSubscription = io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher$RailSubscription of io.reactivex.internal.operators.parallel.ParallelFromPublisher$ParallelDispatcher