final class reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer<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.FluxMergeOrdered$MergeOrderedMainProducer
  super_class: java.lang.Object
{
  static final java.lang.Object DONE;
    descriptor: Ljava/lang/Object;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

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

  final reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber<T>[] subscribers;
    descriptor: [Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
    flags: (0x0010) ACC_FINAL
    Signature: [Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;

  final java.util.Comparator<? super T> comparator;
    descriptor: Ljava/util/Comparator;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Comparator<-TT;>;

  final java.lang.Object[] values;
    descriptor: [Ljava/lang/Object;
    flags: (0x0010) ACC_FINAL

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

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

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

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

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

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

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

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

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

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 129
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.DONE:Ljava/lang/Object;
         1: .line 138
            ldc Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;
            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;
         2: .line 137
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         3: .line 142
            ldc Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;
            ldc "cancelled"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         4: .line 141
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.CANCELLED:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         5: .line 146
            ldc Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;
            ldc "requested"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         6: .line 145
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.REQUESTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         7: .line 150
            ldc Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;
            ldc "emitted"
            invokestatic java.util.concurrent.atomic.AtomicLongFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         8: .line 149
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.EMITTED:Ljava/util/concurrent/atomic/AtomicLongFieldUpdater;
         9: .line 154
            ldc Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;
            ldc "wip"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        10: .line 153
            putstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
        11: .line 154
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super T>, java.util.Comparator<? super T>, int, );
    descriptor: (Lreactor/core/CoreSubscriber;Ljava/util/Comparator;II)V
    flags: (0x0000) 
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // java.util.Comparator comparator
        start local 3 // int prefetch
        start local 4 // int n
         0: .line 156
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 158
            aload 0 /* this */
            aload 1 /* actual */
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.actual:Lreactor/core/CoreSubscriber;
         2: .line 159
            aload 0 /* this */
            aload 2 /* comparator */
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.comparator:Ljava/util/Comparator;
         3: .line 163
            iload 4 /* n */
            anewarray reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber
         4: .line 162
            astore 5 /* mergeOrderedInnerSub */
        start local 5 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] mergeOrderedInnerSub
         5: .line 164
            aload 0 /* this */
            aload 5 /* mergeOrderedInnerSub */
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
         6: .line 166
            iconst_0
            istore 6 /* i */
        start local 6 // int i
         7: goto 10
         8: .line 167
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer reactor.core.CoreSubscriber java.util.Comparator int int reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            iload 6 /* i */
            new reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber
            dup
            aload 0 /* this */
            iload 3 /* prefetch */
            invokespecial reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.<init>:(Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer;I)V
            aastore
         9: .line 166
            iinc 6 /* i */ 1
      StackMap locals:
      StackMap stack:
        10: iload 6 /* i */
            iload 4 /* n */
            if_icmplt 8
        end local 6 // int i
        11: .line 169
            aload 0 /* this */
            iload 4 /* n */
            anewarray java.lang.Object
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.values:[Ljava/lang/Object;
        12: .line 170
            return
        end local 5 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] mergeOrderedInnerSub
        end local 4 // int n
        end local 3 // int prefetch
        end local 2 // java.util.Comparator comparator
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   13     0                  this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            0   13     1                actual  Lreactor/core/CoreSubscriber<-TT;>;
            0   13     2            comparator  Ljava/util/Comparator<-TT;>;
            0   13     3              prefetch  I
            0   13     4                     n  I
            5   13     5  mergeOrderedInnerSub  [Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            7   11     6                     i  I
    Signature: (Lreactor/core/CoreSubscriber<-TT;>;Ljava/util/Comparator<-TT;>;II)V
    MethodParameters:
            Name  Flags
      actual      
      comparator  
      prefetch    
      n           

  void subscribe(org.reactivestreams.Publisher<? extends T>[]);
    descriptor: ([Lorg/reactivestreams/Publisher;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
        start local 1 // org.reactivestreams.Publisher[] sources
         0: .line 173
            aload 1 /* sources */
            arraylength
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            arraylength
            if_icmpeq 2
         1: .line 174
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "must subscribe with "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " sources"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 176
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 2 /* i */
        start local 2 // int i
         3: goto 7
         4: .line 177
      StackMap locals: int
      StackMap stack:
            aload 1 /* sources */
            iload 2 /* i */
            aaload
            new java.lang.StringBuilder
            dup
            ldc "subscribed with a null source: sources["
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 2 /* i */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc "]"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher
         5: .line 178
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            iload 2 /* i */
            aaload
            invokeinterface org.reactivestreams.Publisher.subscribe:(Lorg/reactivestreams/Subscriber;)V
         6: .line 176
            iinc 2 /* i */ 1
      StackMap locals:
      StackMap stack:
         7: iload 2 /* i */
            aload 1 /* sources */
            arraylength
            if_icmplt 4
        end local 2 // int i
         8: .line 180
            return
        end local 1 // org.reactivestreams.Publisher[] sources
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0     this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            0    9     1  sources  [Lorg/reactivestreams/Publisher;
            3    8     2        i  I
    Signature: ([Lorg/reactivestreams/Publisher<+TT;>;)V
    MethodParameters:
         Name  Flags
      sources  

  public reactor.core.CoreSubscriber<? super T> actual();
    descriptor: ()Lreactor/core/CoreSubscriber;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
         0: .line 184
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.actual:Lreactor/core/CoreSubscriber;
            areturn
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
    Signature: ()Lreactor/core/CoreSubscriber<-TT;>;

  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.FluxMergeOrdered$MergeOrderedMainProducer this
        start local 1 // long n
         0: .line 189
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.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
         1: .line 190
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.drain:()V
         2: .line 191
            return
        end local 1 // long n
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            0    3     1     n  J
    MethodParameters:
      Name  Flags
      n     

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
         0: .line 195
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.CANCELLED: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 13
         1: .line 196
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 5
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer top int int reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[]
      StackMap stack:
         2: aload 4
            iload 2
            aaload
            astore 1 /* subscriber */
        start local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber subscriber
         3: .line 197
            aload 1 /* subscriber */
            invokevirtual reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.cancel:()V
        end local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber subscriber
         4: .line 196
            iinc 2 1
      StackMap locals:
      StackMap stack:
         5: iload 2
            iload 3
            if_icmplt 2
         6: .line 200
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 13
         7: .line 201
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.values:[Ljava/lang/Object;
            aconst_null
            invokestatic java.util.Arrays.fill:([Ljava/lang/Object;Ljava/lang/Object;)V
         8: .line 202
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            dup
            astore 4
            arraylength
            istore 3
            iconst_0
            istore 2
            goto 12
      StackMap locals:
      StackMap stack:
         9: aload 4
            iload 2
            aaload
            astore 1 /* subscriber */
        start local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber subscriber
        10: .line 203
            aload 1 /* subscriber */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
        end local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber subscriber
        11: .line 202
            iinc 2 1
      StackMap locals:
      StackMap stack:
        12: iload 2
            iload 3
            if_icmplt 9
        13: .line 207
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            3    4     1  subscriber  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;
           10   11     1  subscriber  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;

  void onInnerError(reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber<T>, java.lang.Throwable);
    descriptor: (Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;Ljava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
        start local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber inner
        start local 2 // java.lang.Throwable ex
         0: .line 210
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 2 /* ex */
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
         1: .line 211
            aload 1 /* inner */
            iconst_1
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.done:Z
         2: .line 212
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.drain:()V
         3: .line 213
            return
        end local 2 // java.lang.Throwable ex
        end local 1 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber inner
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            0    4     1  inner  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;
            0    4     2     ex  Ljava/lang/Throwable;
    Signature: (Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;Ljava/lang/Throwable;)V
    MethodParameters:
       Name  Flags
      inner  
      ex     

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=22, args_size=1
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
         0: .line 216
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifeq 2
         1: .line 217
            return
         2: .line 220
      StackMap locals:
      StackMap stack:
            iconst_1
            istore 1 /* missed */
        start local 1 // int missed
         3: .line 221
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.actual:Lreactor/core/CoreSubscriber;
            astore 2 /* actual */
        start local 2 // reactor.core.CoreSubscriber actual
         4: .line 222
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.comparator:Ljava/util/Comparator;
            astore 3 /* comparator */
        start local 3 // java.util.Comparator comparator
         5: .line 224
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.subscribers:[Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            astore 4 /* subscribers */
        start local 4 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] subscribers
         6: .line 225
            aload 4 /* subscribers */
            arraylength
            istore 5 /* n */
        start local 5 // int n
         7: .line 227
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.values:[Ljava/lang/Object;
            astore 6 /* values */
        start local 6 // java.lang.Object[] values
         8: .line 229
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.emitted:J
            lstore 7 /* e */
        start local 7 // long e
         9: .line 232
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.requested:J
            lstore 9 /* r */
        start local 9 // long r
        10: .line 235
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.cancelled:I
            ifeq 18
        11: .line 236
            aload 6 /* values */
            aconst_null
            invokestatic java.util.Arrays.fill:([Ljava/lang/Object;Ljava/lang/Object;)V
        12: .line 238
            aload 4 /* subscribers */
            dup
            astore 14
            arraylength
            istore 13
            iconst_0
            istore 12
            goto 16
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long top int int reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[]
      StackMap stack:
        13: aload 14
            iload 12
            aaload
            astore 11 /* inner */
        start local 11 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber inner
        14: .line 239
            aload 11 /* inner */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.clear:()V
        end local 11 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber inner
        15: .line 238
            iinc 12 1
      StackMap locals:
      StackMap stack:
        16: iload 12
            iload 13
            if_icmplt 13
        17: .line 241
            return
        18: .line 244
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long
      StackMap stack:
            iconst_0
            istore 11 /* done */
        start local 11 // int done
        19: .line 245
            iconst_0
            istore 12 /* nonEmpty */
        start local 12 // int nonEmpty
        20: .line 246
            iconst_0
            istore 13 /* i */
        start local 13 // int i
        21: goto 41
        22: .line 247
      StackMap locals: int int int
      StackMap stack:
            aload 6 /* values */
            iload 13 /* i */
            aaload
            astore 14 /* o */
        start local 14 // java.lang.Object o
        23: .line 248
            aload 14 /* o */
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.DONE:Ljava/lang/Object;
            if_acmpne 27
        24: .line 249
            iinc 11 /* done */ 1
        25: .line 250
            iinc 12 /* nonEmpty */ 1
        26: .line 251
            goto 40
        27: .line 252
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 14 /* o */
            ifnonnull 39
        28: .line 253
            aload 4 /* subscribers */
            iload 13 /* i */
            aaload
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.done:Z
            istore 15 /* innerDone */
        start local 15 // boolean innerDone
        29: .line 254
            aload 4 /* subscribers */
            iload 13 /* i */
            aaload
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.queue:Ljava/util/Queue;
            invokeinterface java.util.Queue.poll:()Ljava/lang/Object;
            astore 14 /* o */
        30: .line 255
            aload 14 /* o */
            ifnull 34
        31: .line 256
            aload 6 /* values */
            iload 13 /* i */
            aload 14 /* o */
            aastore
        32: .line 257
            iinc 12 /* nonEmpty */ 1
        33: .line 258
            goto 40
        34: .line 259
      StackMap locals: int
      StackMap stack:
            iload 15 /* innerDone */
            ifeq 40
        35: .line 260
            aload 6 /* values */
            iload 13 /* i */
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.DONE:Ljava/lang/Object;
            aastore
        36: .line 261
            iinc 11 /* done */ 1
        37: .line 262
            iinc 12 /* nonEmpty */ 1
        end local 15 // boolean innerDone
        38: .line 264
            goto 40
        39: .line 266
      StackMap locals:
      StackMap stack:
            iinc 12 /* nonEmpty */ 1
        end local 14 // java.lang.Object o
        40: .line 246
      StackMap locals:
      StackMap stack:
            iinc 13 /* i */ 1
      StackMap locals:
      StackMap stack:
        41: iload 13 /* i */
            iload 5 /* n */
            if_icmplt 22
        end local 13 // int i
        42: .line 270
            iload 11 /* done */
            iload 5 /* n */
            if_icmpne 49
        43: .line 271
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.error:Ljava/lang/Throwable;
            astore 13 /* ex */
        start local 13 // java.lang.Throwable ex
        44: .line 272
            aload 13 /* ex */
            ifnonnull 47
        45: .line 273
            aload 2 /* actual */
            invokeinterface reactor.core.CoreSubscriber.onComplete:()V
        46: .line 274
            goto 48
        47: .line 275
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long int int java.lang.Throwable
      StackMap stack:
            aload 2 /* actual */
            aload 13 /* ex */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
        48: .line 277
      StackMap locals:
      StackMap stack:
            return
        end local 13 // java.lang.Throwable ex
        49: .line 280
      StackMap locals:
      StackMap stack:
            iload 12 /* nonEmpty */
            iload 5 /* n */
            if_icmpne 79
            lload 7 /* e */
            lload 9 /* r */
            lcmp
            iflt 51
        50: .line 281
            goto 79
        51: .line 284
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 13 /* min */
        start local 13 // java.lang.Object min
        52: .line 285
            iconst_m1
            istore 14 /* minIndex */
        start local 14 // int minIndex
        53: .line 287
            iconst_0
            istore 15 /* i */
        start local 15 // int i
        54: .line 288
            aload 6 /* values */
            dup
            astore 19
            arraylength
            istore 18
            iconst_0
            istore 17
            goto 73
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long int int java.lang.Object int int top int int java.lang.Object[]
      StackMap stack:
        55: aload 19
            iload 17
            aaload
            astore 16 /* o */
        start local 16 // java.lang.Object o
        56: .line 289
            aload 16 /* o */
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.DONE:Ljava/lang/Object;
            if_acmpeq 71
        57: .line 293
            aload 16 /* o */
            astore 21 /* t */
        start local 21 // java.lang.Object t
        58: .line 294
            aload 13 /* min */
            ifnull 59
            aload 3 /* comparator */
            aload 13 /* min */
            aload 21 /* t */
            invokeinterface java.util.Comparator.compare:(Ljava/lang/Object;Ljava/lang/Object;)I
            ifgt 59
            iconst_0
            goto 60
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long int int java.lang.Object int int java.lang.Object int int java.lang.Object[] top java.lang.Object
      StackMap stack:
        59: iconst_1
      StackMap locals:
      StackMap stack: int
        60: istore 20 /* smaller */
        end local 21 // java.lang.Object t
        start local 20 // boolean smaller
        61: .line 295
            goto 67
        end local 20 // boolean smaller
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long int int java.lang.Object int int java.lang.Object int int java.lang.Object[]
      StackMap stack: java.lang.Throwable
        62: astore 21 /* ex */
        start local 21 // java.lang.Throwable ex
        63: .line 296
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 21 /* ex */
            invokestatic reactor.core.Exceptions.addThrowable:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;Ljava/lang/Throwable;)Z
            pop
        64: .line 297
            aload 0 /* this */
            invokevirtual reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.cancel:()V
        65: .line 298
            aload 2 /* actual */
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.ERROR:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            invokestatic reactor.core.Exceptions.terminate:(Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;Ljava/lang/Object;)Ljava/lang/Throwable;
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
        66: .line 299
            return
        end local 21 // java.lang.Throwable ex
        start local 20 // boolean smaller
        67: .line 301
      StackMap locals: int
      StackMap stack:
            iload 20 /* smaller */
            ifeq 71
        68: .line 303
            aload 16 /* o */
            astore 21 /* t */
        start local 21 // java.lang.Object t
        69: .line 304
            aload 21 /* t */
            astore 13 /* min */
        70: .line 305
            iload 15 /* i */
            istore 14 /* minIndex */
        end local 21 // java.lang.Object t
        end local 20 // boolean smaller
        71: .line 308
      StackMap locals:
      StackMap stack:
            iinc 15 /* i */ 1
        end local 16 // java.lang.Object o
        72: .line 288
            iinc 17 1
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long int int java.lang.Object int int top int int java.lang.Object[]
      StackMap stack:
        73: iload 17
            iload 18
            if_icmplt 55
        74: .line 311
            aload 6 /* values */
            iload 14 /* minIndex */
            aconst_null
            aastore
        75: .line 313
            aload 2 /* actual */
            aload 13 /* min */
            invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
        76: .line 315
            lload 7 /* e */
            lconst_1
            ladd
            lstore 7 /* e */
        77: .line 316
            aload 4 /* subscribers */
            iload 14 /* minIndex */
            aaload
            lconst_1
            invokevirtual reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber.request:(J)V
        end local 15 // int i
        end local 14 // int minIndex
        end local 13 // java.lang.Object min
        end local 12 // int nonEmpty
        end local 11 // int done
        78: .line 234
            goto 10
        79: .line 319
      StackMap locals: reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer int reactor.core.CoreSubscriber java.util.Comparator reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] int java.lang.Object[] long long
      StackMap stack:
            aload 0 /* this */
            lload 7 /* e */
            putfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.emitted:J
        80: .line 320
            getstatic reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.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 */
        81: .line 321
            iload 1 /* missed */
            ifne 9
        end local 9 // long r
        82: .line 325
            return
        end local 7 // long e
        end local 6 // java.lang.Object[] values
        end local 5 // int n
        end local 4 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber[] subscribers
        end local 3 // java.util.Comparator comparator
        end local 2 // reactor.core.CoreSubscriber actual
        end local 1 // int missed
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   83     0         this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            3   83     1       missed  I
            4   83     2       actual  Lreactor/core/CoreSubscriber<-TT;>;
            5   83     3   comparator  Ljava/util/Comparator<-TT;>;
            6   83     4  subscribers  [Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber;
            7   83     5            n  I
            8   83     6       values  [Ljava/lang/Object;
            9   83     7            e  J
           10   82     9            r  J
           14   15    11        inner  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedInnerSubscriber<TT;>;
           19   78    11         done  I
           20   78    12     nonEmpty  I
           21   42    13            i  I
           23   40    14            o  Ljava/lang/Object;
           29   38    15    innerDone  Z
           44   49    13           ex  Ljava/lang/Throwable;
           52   78    13          min  TT;
           53   78    14     minIndex  I
           54   78    15            i  I
           56   72    16            o  Ljava/lang/Object;
           61   62    20      smaller  Z
           67   71    20      smaller  Z
           58   61    21            t  TT;
           63   67    21           ex  Ljava/lang/Throwable;
           69   71    21            t  TT;
      Exception table:
        from    to  target  type
          57    61      62  Class java.lang.Throwable

  public java.lang.Object scanUnsafe(reactor.core.Scannable$Attr);
    descriptor: (Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 329
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.ACTUAL:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.actual:Lreactor/core/CoreSubscriber;
            areturn
         1: .line 330
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.CANCELLED:Lreactor/core/Scannable$Attr;
            if_acmpne 3
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.cancelled:I
            ifle 2
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
      StackMap locals:
      StackMap stack:
         2: iconst_0
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         3: .line 331
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 4
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.error:Ljava/lang/Throwable;
            areturn
         4: .line 332
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.DELAY_ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 5
            iconst_1
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         5: .line 333
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.REQUESTED_FROM_DOWNSTREAM:Lreactor/core/Scannable$Attr;
            if_acmpne 6
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.requested:J
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer.emitted:J
            lsub
            invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
            areturn
         6: .line 334
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 7
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         7: .line 336
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lreactor/core/publisher/FluxMergeOrdered$MergeOrderedMainProducer<TT;>;
            0    8     1   key  Lreactor/core/Scannable$Attr;
    MethodParameters:
      Name  Flags
      key   
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;Lreactor/core/publisher/InnerProducer<TT;>;
SourceFile: "FluxMergeOrdered.java"
NestHost: reactor.core.publisher.FluxMergeOrdered
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 MergeOrderedInnerSubscriber = reactor.core.publisher.FluxMergeOrdered$MergeOrderedInnerSubscriber of reactor.core.publisher.FluxMergeOrdered
  final MergeOrderedMainProducer = reactor.core.publisher.FluxMergeOrdered$MergeOrderedMainProducer of reactor.core.publisher.FluxMergeOrdered