final class reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain<T> implements reactor.core.publisher.InnerProducer<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain
  super_class: java.lang.Object
{
  final reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner<T>[] subscribers;
    descriptor: [Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
    flags: (0x0010) ACC_FINAL
    Signature: [Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;

  final java.util.function.Supplier<java.util.Queue<T>> queueSupplier;
    descriptor: Ljava/util/function/Supplier;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/function/Supplier<Ljava/util/Queue<TT;>;>;

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

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain, 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/ParallelMergeSequential$MergeSequentialMain;Ljava/lang/Throwable;>;

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

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

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

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

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

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

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 85
            ldc Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain;
            ldc Ljava/lang/Throwable;
            ldc "error"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         1: .line 84
            putstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         2: .line 91
            ldc Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain;
            ldc "wip"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         3: .line 90
            putstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         4: .line 96
            ldc Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain;
            ldc "requested"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         5: .line 95
            putstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         6: .line 103
            ldc Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain;
            ldc "done"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         7: .line 102
            putstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.DONE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         8: .line 103
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super T>, int, int, java.util.function.Supplier<java.util.Queue<T>>);
    descriptor: (Lreactor/core/CoreSubscriber;IILjava/util/function/Supplier;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // int n
        start local 3 // int prefetch
        start local 4 // java.util.function.Supplier queueSupplier
         0: .line 106
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 109
            aload 0 /* this */
            aload 1 /* actual */
            putfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
         2: .line 110
            aload 0 /* this */
            aload 4 /* queueSupplier */
            putfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.queueSupplier:Ljava/util/function/Supplier;
         3: .line 112
            iload 2 /* n */
            anewarray reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner
            astore 5 /* a */
        start local 5 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] a
         4: .line 114
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         5: goto 8
         6: .line 115
      StackMap locals: reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain reactor.core.CoreSubscriber int int java.util.function.Supplier reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] int
      StackMap stack:
            aload 5 /* a */
            iload 6 /* i */
            new reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner
            dup
            aload 0 /* this */
            iload 3 /* prefetch */
            invokespecial reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.<init>:(Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain;I)V
            aastore
         7: .line 114
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
         8: iload 6 /* i */
            iload 2 /* n */
            if_icmplt 6
        end local 6 // int i
         9: .line 118
            aload 0 /* this */
            aload 5 /* a */
            putfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.subscribers:[Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
        10: .line 119
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.DONE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iload 2 /* n */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.lazySet:(Ljava/lang/Object;I)V
        11: .line 120
            return
        end local 5 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] a
        end local 4 // java.util.function.Supplier queueSupplier
        end local 3 // int prefetch
        end local 2 // int n
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            0   12     1         actual  Lreactor/core/CoreSubscriber<-TT;>;
            0   12     2              n  I
            0   12     3       prefetch  I
            0   12     4  queueSupplier  Ljava/util/function/Supplier<Ljava/util/Queue<TT;>;>;
            4   12     5              a  [Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            5    9     6              i  I
    Signature: (Lreactor/core/CoreSubscriber<-TT;>;IILjava/util/function/Supplier<Ljava/util/Queue<TT;>;>;)V
    MethodParameters:
               Name  Flags
      actual         
      n              
      prefetch       
      queueSupplier  

  public final reactor.core.CoreSubscriber<? super T> 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.ParallelMergeSequential$MergeSequentialMain this
         0: .line 124
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
            areturn
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
    Signature: ()Lreactor/core/CoreSubscriber<-TT;>;

  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.ParallelMergeSequential$MergeSequentialMain this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 130
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelled:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         1: .line 131
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
            if_acmpne 2
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.requested:J
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         2: .line 132
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.TERMINATED:Lreactor/core/Scannable$Attr;
            if_acmpne 4
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.done:I
            ifne 3
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      StackMap locals:
      StackMap stack:
         3: iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         4: .line 133
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 5
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.error:Ljava/lang/Throwable;
            areturn
         5: .line 134
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 6
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         6: .line 136
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* key */
            invokespecial reactor.core.publisher.InnerProducer.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            0    7     1   key  Lreactor/core/Scannable$Attr;
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()
    MethodParameters:
      Name  Flags
      key   

  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.ParallelMergeSequential$MergeSequentialMain this
         0: .line 141
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.subscribers:[Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            invokestatic java.util.stream.Stream.of:([Ljava/lang/Object;)Ljava/util/stream/Stream;
            areturn
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
    Signature: ()Ljava/util/stream/Stream<+Lreactor/core/Scannable;>;

  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.ParallelMergeSequential$MergeSequentialMain this
        start local 1 // long n
         0: .line 146
            lload 1 /* n */
            invokestatic reactor.core.publisher.Operators.validate:(J)Z
            ifeq 3
         1: .line 147
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.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 148
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.drain:()V
         3: .line 150
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            0    4     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.ParallelMergeSequential$MergeSequentialMain this
         0: .line 154
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelled:Z
            ifne 5
         1: .line 155
            aload 0 /* this */
            iconst_1
            putfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelled:Z
         2: .line 157
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelAll:()V
         3: .line 159
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 5
         4: .line 160
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cleanup:()V
         5: .line 163
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;

  void cancelAll();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
         0: .line 166
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.subscribers:[Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 4
      StackMap locals: reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain top int int reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[]
      StackMap stack:
         1: aload 4
            iload 2
            aaload
            astore 1 /* s */
        start local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner s
         2: .line 167
            aload 1 /* s */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.cancel:()V
        end local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner s
         3: .line 166
            iinc 2 1
      StackMap locals:
      StackMap stack:
         4: iload 2
            iload 3
            if_icmplt 1
         5: .line 169
            return
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            2    3     1     s  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;

  void cleanup();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
         0: .line 172
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.subscribers:[Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 4
      StackMap locals: reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain top int int reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[]
      StackMap stack:
         1: aload 4
            iload 2
            aaload
            astore 1 /* s */
        start local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner s
         2: .line 173
            aload 1 /* s */
            aconst_null
            putfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.queue:Ljava/util/Queue;
        end local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner s
         3: .line 172
            iinc 2 1
      StackMap locals:
      StackMap stack:
         4: iload 2
            iload 3
            if_icmplt 1
         5: .line 175
            return
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            2    3     1     s  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;

  void onNext(reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner<T>, );
    descriptor: (Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
        start local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        start local 2 // java.lang.Object value
         0: .line 178
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.wip:I
            ifne 15
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.compareAndSet:(Ljava/lang/Object;II)Z
            ifeq 15
         1: .line 179
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.requested:J
            lconst_0
            lcmp
            ifeq 7
         2: .line 180
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
            aload 2 /* value */
            invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
         3: .line 181
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.requested:J
            ldc 9223372036854775807
            lcmp
            ifeq 5
         4: .line 182
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.decrementAndGet:(Ljava/lang/Object;)J
            pop2
         5: .line 184
      StackMap locals:
      StackMap stack:
            aload 1 /* inner */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.requestOne:()V
         6: .line 185
            goto 13
         7: .line 186
      StackMap locals:
      StackMap stack:
            aload 1 /* inner */
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.queueSupplier:Ljava/util/function/Supplier;
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.getQueue:(Ljava/util/function/Supplier;)Ljava/util/Queue;
            astore 3 /* q */
        start local 3 // java.util.Queue q
         8: .line 188
            aload 3 /* q */
            aload 2 /* value */
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            ifne 13
         9: .line 189
            aload 0 /* this */
            aload 0 /* this */
            ldc "Queue is full: Reactive Streams source doesn't respect backpressure"
            invokestatic reactor.core.Exceptions.failWithOverflow:(Ljava/lang/String;)Ljava/lang/IllegalStateException;
            aload 2 /* value */
        10: .line 190
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        11: .line 189
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.onError:(Ljava/lang/Throwable;)V
        12: .line 191
            return
        end local 3 // java.util.Queue q
        13: .line 194
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 23
        14: .line 195
            return
        15: .line 198
      StackMap locals:
      StackMap stack:
            aload 1 /* inner */
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.queueSupplier:Ljava/util/function/Supplier;
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.getQueue:(Ljava/util/function/Supplier;)Ljava/util/Queue;
            astore 3 /* q */
        start local 3 // java.util.Queue q
        16: .line 200
            aload 3 /* q */
            aload 2 /* value */
            invokeinterface java.util.Queue.offer:(Ljava/lang/Object;)Z
            ifne 21
        17: .line 201
            aload 0 /* this */
            aload 0 /* this */
            ldc "Queue is full: Reactive Streams source doesn't respect backpressure"
            invokestatic reactor.core.Exceptions.failWithOverflow:(Ljava/lang/String;)Ljava/lang/IllegalStateException;
            aload 2 /* value */
        18: .line 202
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
        19: .line 201
            invokestatic reactor.core.publisher.Operators.onOperatorError:(Lorg/reactivestreams/Subscription;Ljava/lang/Throwable;Ljava/lang/Object;Lreactor/util/context/Context;)Ljava/lang/Throwable;
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.onError:(Ljava/lang/Throwable;)V
        20: .line 203
            return
        21: .line 206
      StackMap locals: java.util.Queue
      StackMap stack:
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifeq 23
        22: .line 207
            return
        end local 3 // java.util.Queue q
        23: .line 211
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.drainLoop:()V
        24: .line 212
            return
        end local 2 // java.lang.Object value
        end local 1 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0   25     0   this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            0   25     1  inner  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;
            0   25     2  value  TT;
            8   13     3      q  Ljava/util/Queue<TT;>;
           16   23     3      q  Ljava/util/Queue<TT;>;
    Signature: (Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;TT;)V
    MethodParameters:
       Name  Flags
      inner  
      value  

  void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
        start local 1 // java.lang.Throwable ex
         0: .line 215
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aconst_null
            aload 1 /* ex */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 4
         1: .line 216
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelAll:()V
         2: .line 217
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.drain:()V
         3: .line 218
            goto 6
         4: .line 219
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.error:Ljava/lang/Throwable;
            aload 1 /* ex */
            if_acmpeq 6
         5: .line 220
            aload 1 /* ex */
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.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
         6: .line 222
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable ex
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            0    7     1    ex  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      ex    

  void onComplete();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
         0: .line 225
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.DONE:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifge 2
         1: .line 226
            return
         2: .line 228
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.drain:()V
         3: .line 229
            return
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
         0: .line 232
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifeq 2
         1: .line 233
            return
         2: .line 236
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.drainLoop:()V
         3: .line 237
            return
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;

  void drainLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=16, args_size=1
        start local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
         0: .line 240
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         1: .line 242
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.subscribers:[Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            astore 2 /* s */
        start local 2 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] s
         2: .line 243
            aload 2 /* s */
            arraylength
            istore 3 /* n */
        start local 3 // int n
         3: .line 244
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.actual:Lreactor/core/CoreSubscriber;
            astore 4 /* a */
        start local 4 // org.reactivestreams.Subscriber a
         4: .line 248
      StackMap locals: reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain int reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] int org.reactivestreams.Subscriber
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.requested:J
            lstore 5 /* r */
        start local 5 // long r
         5: .line 249
            lconst_0
            lstore 7 /* e */
        start local 7 // long e
         6: .line 252
            goto 38
         7: .line 253
      StackMap locals: long long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelled:Z
            ifeq 10
         8: .line 254
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cleanup:()V
         9: .line 255
            return
        10: .line 258
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.error:Ljava/lang/Throwable;
            astore 9 /* ex */
        start local 9 // java.lang.Throwable ex
        11: .line 259
            aload 9 /* ex */
            ifnull 15
        12: .line 260
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cleanup:()V
        13: .line 261
            aload 4 /* a */
            aload 9 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        14: .line 262
            return
        15: .line 265
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.done:I
            ifne 16
            iconst_1
            goto 17
      StackMap locals:
      StackMap stack:
        16: iconst_0
      StackMap locals:
      StackMap stack: int
        17: istore 10 /* d */
        start local 10 // boolean d
        18: .line 267
            iconst_1
            istore 11 /* empty */
        start local 11 // boolean empty
        19: .line 269
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        20: goto 32
        21: .line 270
      StackMap locals: int int int
      StackMap stack:
            aload 2 /* s */
            iload 12 /* i */
            aaload
            astore 13 /* inner */
        start local 13 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        22: .line 272
            aload 13 /* inner */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.queue:Ljava/util/Queue;
            astore 14 /* q */
        start local 14 // java.util.Queue q
        23: .line 273
            aload 14 /* q */
            ifnull 31
        24: .line 274
            aload 14 /* q */
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 15 /* v */
        start local 15 // java.lang.Object v
        25: .line 276
            aload 15 /* v */
            ifnull 31
        26: .line 277
            iconst_0
            istore 11 /* empty */
        27: .line 278
            aload 4 /* a */
            aload 15 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        28: .line 279
            aload 13 /* inner */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.requestOne:()V
        29: .line 280
            lload 7 /* e */
            lconst_1
            ladd
            dup2
            lstore 7 /* e */
            lload 5 /* r */
            lcmp
            ifne 31
        30: .line 281
            goto 39
        end local 15 // java.lang.Object v
        end local 14 // java.util.Queue q
        end local 13 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        31: .line 269
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        32: iload 12 /* i */
            iload 3 /* n */
            if_icmplt 21
        end local 12 // int i
        33: .line 287
            iload 10 /* d */
            ifeq 36
            iload 11 /* empty */
            ifeq 36
        34: .line 288
            aload 4 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        35: .line 289
            return
        36: .line 292
      StackMap locals:
      StackMap stack:
            iload 11 /* empty */
            ifeq 38
        37: .line 293
            goto 39
        end local 11 // boolean empty
        end local 10 // boolean d
        end local 9 // java.lang.Throwable ex
        38: .line 252
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lload 5 /* r */
            lcmp
            ifne 7
        39: .line 297
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lload 5 /* r */
            lcmp
            ifne 64
        40: .line 298
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cancelled:Z
            ifeq 43
        41: .line 299
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cleanup:()V
        42: .line 300
            return
        43: .line 303
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.error:Ljava/lang/Throwable;
            astore 9 /* ex */
        start local 9 // java.lang.Throwable ex
        44: .line 304
            aload 9 /* ex */
            ifnull 48
        45: .line 305
            aload 0 /* this */
            invokevirtual reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.cleanup:()V
        46: .line 306
            aload 4 /* a */
            aload 9 /* ex */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        47: .line 307
            return
        48: .line 310
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.done:I
            ifne 49
            iconst_1
            goto 50
      StackMap locals:
      StackMap stack:
        49: iconst_0
      StackMap locals:
      StackMap stack: int
        50: istore 10 /* d */
        start local 10 // boolean d
        51: .line 312
            iconst_1
            istore 11 /* empty */
        start local 11 // boolean empty
        52: .line 314
            iconst_0
            istore 12 /* i */
        start local 12 // int i
        53: goto 60
        54: .line 315
      StackMap locals: int int int
      StackMap stack:
            aload 2 /* s */
            iload 12 /* i */
            aaload
            astore 13 /* inner */
        start local 13 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        55: .line 317
            aload 13 /* inner */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner.queue:Ljava/util/Queue;
            astore 14 /* q */
        start local 14 // java.util.Queue q
        56: .line 318
            aload 14 /* q */
            ifnull 59
            aload 14 /* q */
            invokeinterface java.util.Queue.isEmpty:()Z
            ifne 59
        57: .line 319
            iconst_0
            istore 11 /* empty */
        58: .line 320
            goto 61
        end local 14 // java.util.Queue q
        end local 13 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner inner
        59: .line 314
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        60: iload 12 /* i */
            iload 3 /* n */
            if_icmplt 54
        end local 12 // int i
        61: .line 324
      StackMap locals:
      StackMap stack:
            iload 10 /* d */
            ifeq 64
            iload 11 /* empty */
            ifeq 64
        62: .line 325
            aload 4 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        63: .line 326
            return
        end local 11 // boolean empty
        end local 10 // boolean d
        end local 9 // java.lang.Throwable ex
        64: .line 330
      StackMap locals:
      StackMap stack:
            lload 7 /* e */
            lconst_0
            lcmp
            ifeq 66
            lload 5 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 66
        65: .line 331
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
            aload 0 /* this */
            lload 7 /* e */
            lneg
            invokevirtual java.util.concurrent.atomic.AtomicLongFieldUpdater.addAndGet:(Ljava/lang/Object;J)J
            pop2
        66: .line 334
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.wip:I
            istore 9 /* w */
        start local 9 // int w
        67: .line 335
            iload 9 /* w */
            iload 1 /* missed */
            if_icmpne 71
        68: .line 336
            getstatic reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain.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 */
        69: .line 337
            iload 1 /* missed */
            ifne 4
        70: .line 338
            goto 73
        71: .line 341
      StackMap locals: int
      StackMap stack:
            iload 9 /* w */
            istore 1 /* missed */
        end local 9 // int w
        end local 7 // long e
        end local 5 // long r
        72: .line 246
            goto 4
        73: .line 344
      StackMap locals:
      StackMap stack:
            return
        end local 4 // org.reactivestreams.Subscriber a
        end local 3 // int n
        end local 2 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner[] s
        end local 1 // int missed
        end local 0 // reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   74     0    this  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialMain<TT;>;
            1   74     1  missed  I
            2   74     2       s  [Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner;
            3   74     3       n  I
            4   74     4       a  Lorg/reactivestreams/Subscriber<-TT;>;
            5   72     5       r  J
            6   72     7       e  J
           11   38     9      ex  Ljava/lang/Throwable;
           18   38    10       d  Z
           19   38    11   empty  Z
           20   33    12       i  I
           22   31    13   inner  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;
           23   31    14       q  Ljava/util/Queue<TT;>;
           25   31    15       v  TT;
           44   64     9      ex  Ljava/lang/Throwable;
           51   64    10       d  Z
           52   64    11   empty  Z
           53   61    12       i  I
           55   59    13   inner  Lreactor/core/publisher/ParallelMergeSequential$MergeSequentialInner<TT;>;
           56   59    14       q  Ljava/util/Queue<TT;>;
           67   72     9       w  I
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/publisher/InnerProducer<TT;>;
SourceFile: "ParallelMergeSequential.java"
NestHost: reactor.core.publisher.ParallelMergeSequential
InnerClasses:
  public Attr = reactor.core.Scannable$Attr of reactor.core.Scannable
  public final RunStyle = reactor.core.Scannable$Attr$RunStyle of reactor.core.Scannable$Attr
  final MergeSequentialInner = reactor.core.publisher.ParallelMergeSequential$MergeSequentialInner of reactor.core.publisher.ParallelMergeSequential
  final MergeSequentialMain = reactor.core.publisher.ParallelMergeSequential$MergeSequentialMain of reactor.core.publisher.ParallelMergeSequential