final class reactor.core.publisher.FluxMerge<T> extends reactor.core.publisher.Flux<T> implements reactor.core.publisher.SourceProducer<T>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.FluxMerge
  super_class: reactor.core.publisher.Flux
{
  final org.reactivestreams.Publisher<? extends T>[] sources;
    descriptor: [Lorg/reactivestreams/Publisher;
    flags: (0x0010) ACC_FINAL
    Signature: [Lorg/reactivestreams/Publisher<+TT;>;

  final boolean delayError;
    descriptor: Z
    flags: (0x0010) ACC_FINAL

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

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

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

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

  void <init>(org.reactivestreams.Publisher<? extends T>[], boolean, int, java.util.function.Supplier<? extends java.util.Queue<T>>, int, java.util.function.Supplier<? extends java.util.Queue<T>>);
    descriptor: ([Lorg/reactivestreams/Publisher;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=7, args_size=7
        start local 0 // reactor.core.publisher.FluxMerge this
        start local 1 // org.reactivestreams.Publisher[] sources
        start local 2 // boolean delayError
        start local 3 // int maxConcurrency
        start local 4 // java.util.function.Supplier mainQueueSupplier
        start local 5 // int prefetch
        start local 6 // java.util.function.Supplier innerQueueSupplier
         0: .line 45
            aload 0 /* this */
            invokespecial reactor.core.publisher.Flux.<init>:()V
         1: .line 49
            iload 5 /* prefetch */
            ifgt 3
         2: .line 50
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "prefetch > 0 required but it was "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 5 /* prefetch */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 52
      StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher[] int int java.util.function.Supplier int java.util.function.Supplier
      StackMap stack:
            iload 3 /* maxConcurrency */
            ifgt 5
         4: .line 53
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "maxConcurrency > 0 required but it was "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            iload 3 /* maxConcurrency */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 55
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* sources */
            ldc "sources"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast org.reactivestreams.Publisher[]
            putfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
         6: .line 56
            aload 0 /* this */
            iload 2 /* delayError */
            putfield reactor.core.publisher.FluxMerge.delayError:Z
         7: .line 57
            aload 0 /* this */
            iload 3 /* maxConcurrency */
            putfield reactor.core.publisher.FluxMerge.maxConcurrency:I
         8: .line 58
            aload 0 /* this */
            iload 5 /* prefetch */
            putfield reactor.core.publisher.FluxMerge.prefetch:I
         9: .line 59
            aload 0 /* this */
            aload 4 /* mainQueueSupplier */
            ldc "mainQueueSupplier"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.util.function.Supplier
            putfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
        10: .line 60
            aload 0 /* this */
            aload 6 /* innerQueueSupplier */
            ldc "innerQueueSupplier"
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.util.function.Supplier
            putfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
        11: .line 61
            return
        end local 6 // java.util.function.Supplier innerQueueSupplier
        end local 5 // int prefetch
        end local 4 // java.util.function.Supplier mainQueueSupplier
        end local 3 // int maxConcurrency
        end local 2 // boolean delayError
        end local 1 // org.reactivestreams.Publisher[] sources
        end local 0 // reactor.core.publisher.FluxMerge this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   12     0                this  Lreactor/core/publisher/FluxMerge<TT;>;
            0   12     1             sources  [Lorg/reactivestreams/Publisher;
            0   12     2          delayError  Z
            0   12     3      maxConcurrency  I
            0   12     4   mainQueueSupplier  Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
            0   12     5            prefetch  I
            0   12     6  innerQueueSupplier  Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
    Signature: ([Lorg/reactivestreams/Publisher<+TT;>;ZILjava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;ILjava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;)V
    MethodParameters:
                    Name  Flags
      sources             
      delayError          
      maxConcurrency      
      mainQueueSupplier   
      prefetch            
      innerQueueSupplier  

  public void subscribe(reactor.core.CoreSubscriber<? super T>);
    descriptor: (Lreactor/core/CoreSubscriber;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=3, args_size=2
        start local 0 // reactor.core.publisher.FluxMerge this
        start local 1 // reactor.core.CoreSubscriber actual
         0: .line 65
            new reactor.core.publisher.FluxFlatMap$FlatMapMain
            dup
         1: .line 66
            aload 1 /* actual */
            invokestatic reactor.core.publisher.FluxMerge.identityFunction:()Ljava/util/function/Function;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.delayError:Z
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.maxConcurrency:I
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.prefetch:I
         2: .line 67
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
         3: .line 65
            invokespecial reactor.core.publisher.FluxFlatMap$FlatMapMain.<init>:(Lreactor/core/CoreSubscriber;Ljava/util/function/Function;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
            astore 2 /* merger */
        start local 2 // reactor.core.publisher.FluxFlatMap$FlatMapMain merger
         4: .line 69
            aload 2 /* merger */
            new reactor.core.publisher.FluxArray$ArraySubscription
            dup
            aload 2 /* merger */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
            invokespecial reactor.core.publisher.FluxArray$ArraySubscription.<init>:(Lreactor/core/CoreSubscriber;[Ljava/lang/Object;)V
            invokevirtual reactor.core.publisher.FluxFlatMap$FlatMapMain.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         5: .line 70
            return
        end local 2 // reactor.core.publisher.FluxFlatMap$FlatMapMain merger
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxMerge this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lreactor/core/publisher/FluxMerge<TT;>;
            0    6     1  actual  Lreactor/core/CoreSubscriber<-TT;>;
            4    6     2  merger  Lreactor/core/publisher/FluxFlatMap$FlatMapMain<Lorg/reactivestreams/Publisher<+TT;>;TT;>;
    Signature: (Lreactor/core/CoreSubscriber<-TT;>;)V
    MethodParameters:
        Name  Flags
      actual  

  reactor.core.publisher.FluxMerge<T> mergeAdditionalSource(org.reactivestreams.Publisher<? extends T>, java.util.function.IntFunction<java.util.function.Supplier<? extends java.util.Queue<T>>>);
    descriptor: (Lorg/reactivestreams/Publisher;Ljava/util/function/IntFunction;)Lreactor/core/publisher/FluxMerge;
    flags: (0x0000) 
    Code:
      stack=8, locals=7, args_size=3
        start local 0 // reactor.core.publisher.FluxMerge this
        start local 1 // org.reactivestreams.Publisher source
        start local 2 // java.util.function.IntFunction newQueueSupplier
         0: .line 83
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
            arraylength
            istore 3 /* n */
        start local 3 // int n
         1: .line 85
            iload 3 /* n */
            iconst_1
            iadd
            anewarray org.reactivestreams.Publisher
            astore 4 /* newArray */
        start local 4 // org.reactivestreams.Publisher[] newArray
         2: .line 86
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.sources:[Lorg/reactivestreams/Publisher;
            iconst_0
            aload 4 /* newArray */
            iconst_0
            iload 3 /* n */
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
         3: .line 87
            aload 4 /* newArray */
            iload 3 /* n */
            aload 1 /* source */
            aastore
         4: .line 91
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.maxConcurrency:I
            istore 6 /* mc */
        start local 6 // int mc
         5: .line 92
            iload 6 /* mc */
            ldc 2147483647
            if_icmpeq 9
         6: .line 93
            iinc 6 /* mc */ 1
         7: .line 94
            aload 2 /* newQueueSupplier */
            iload 6 /* mc */
            invokeinterface java.util.function.IntFunction.apply:(I)Ljava/lang/Object;
            checkcast java.util.function.Supplier
            astore 5 /* newMainQueue */
        start local 5 // java.util.function.Supplier newMainQueue
         8: .line 95
            goto 10
        end local 5 // java.util.function.Supplier newMainQueue
         9: .line 96
      StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher java.util.function.IntFunction int org.reactivestreams.Publisher[] top int
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.mainQueueSupplier:Ljava/util/function/Supplier;
            astore 5 /* newMainQueue */
        start local 5 // java.util.function.Supplier newMainQueue
        10: .line 99
      StackMap locals: reactor.core.publisher.FluxMerge org.reactivestreams.Publisher java.util.function.IntFunction int org.reactivestreams.Publisher[] java.util.function.Supplier int
      StackMap stack:
            new reactor.core.publisher.FluxMerge
            dup
            aload 4 /* newArray */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.delayError:Z
            iload 6 /* mc */
            aload 5 /* newMainQueue */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.prefetch:I
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.innerQueueSupplier:Ljava/util/function/Supplier;
            invokespecial reactor.core.publisher.FluxMerge.<init>:([Lorg/reactivestreams/Publisher;ZILjava/util/function/Supplier;ILjava/util/function/Supplier;)V
            areturn
        end local 6 // int mc
        end local 5 // java.util.function.Supplier newMainQueue
        end local 4 // org.reactivestreams.Publisher[] newArray
        end local 3 // int n
        end local 2 // java.util.function.IntFunction newQueueSupplier
        end local 1 // org.reactivestreams.Publisher source
        end local 0 // reactor.core.publisher.FluxMerge this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   11     0              this  Lreactor/core/publisher/FluxMerge<TT;>;
            0   11     1            source  Lorg/reactivestreams/Publisher<+TT;>;
            0   11     2  newQueueSupplier  Ljava/util/function/IntFunction<Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;>;
            1   11     3                 n  I
            2   11     4          newArray  [Lorg/reactivestreams/Publisher;
            8    9     5      newMainQueue  Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
           10   11     5      newMainQueue  Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;
            5   11     6                mc  I
    Signature: (Lorg/reactivestreams/Publisher<+TT;>;Ljava/util/function/IntFunction<Ljava/util/function/Supplier<+Ljava/util/Queue<TT;>;>;>;)Lreactor/core/publisher/FluxMerge<TT;>;
    MethodParameters:
                  Name  Flags
      source            
      newQueueSupplier  

  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.FluxMerge this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 104
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.DELAY_ERROR:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.delayError:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            areturn
         1: .line 105
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.PREFETCH:Lreactor/core/Scannable$Attr;
            if_acmpne 2
            aload 0 /* this */
            getfield reactor.core.publisher.FluxMerge.prefetch:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            areturn
         2: .line 106
      StackMap locals:
      StackMap stack:
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 3
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         3: .line 108
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxMerge this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxMerge<TT;>;
            0    4     1   key  Lreactor/core/Scannable$Attr;
    MethodParameters:
      Name  Flags
      key   
}
Signature: <T:Ljava/lang/Object;>Lreactor/core/publisher/Flux<TT;>;Lreactor/core/publisher/SourceProducer<TT;>;
SourceFile: "FluxMerge.java"
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 ArraySubscription = reactor.core.publisher.FluxArray$ArraySubscription of reactor.core.publisher.FluxArray
  final FlatMapMain = reactor.core.publisher.FluxFlatMap$FlatMapMain of reactor.core.publisher.FluxFlatMap