final class reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber<T> extends reactor.core.publisher.Operators$MultiSubscriptionSubscriber<T, T> implements reactor.util.retry.Retry$RetrySignal
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber
  super_class: reactor.core.publisher.Operators$MultiSubscriptionSubscriber
{
  final reactor.core.publisher.Operators$DeferredSubscription otherArbiter;
    descriptor: Lreactor/core/publisher/Operators$DeferredSubscription;
    flags: (0x0010) ACC_FINAL

  final reactor.core.publisher.Sinks$Many<reactor.util.retry.Retry$RetrySignal> signaller;
    descriptor: Lreactor/core/publisher/Sinks$Many;
    flags: (0x0010) ACC_FINAL
    Signature: Lreactor/core/publisher/Sinks$Many<Lreactor/util/retry/Retry$RetrySignal;>;

  final reactor.core.CorePublisher<? extends T> source;
    descriptor: Lreactor/core/CorePublisher;
    flags: (0x0010) ACC_FINAL
    Signature: Lreactor/core/CorePublisher<+TT;>;

  long totalFailureIndex;
    descriptor: J
    flags: (0x0000) 

  long subsequentFailureIndex;
    descriptor: J
    flags: (0x0000) 

  java.lang.Throwable lastFailure;
    descriptor: Ljava/lang/Throwable;
    flags: (0x0000) 
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()

  final reactor.util.context.ContextView retryContext;
    descriptor: Lreactor/util/context/ContextView;
    flags: (0x0010) ACC_FINAL

  reactor.util.context.Context context;
    descriptor: Lreactor/util/context/Context;
    flags: (0x0000) 

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

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

  long produced;
    descriptor: J
    flags: (0x0000) 

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 92
            ldc Lreactor/core/publisher/FluxRetryWhen;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.$assertionsDisabled:Z
         3: .line 111
            ldc Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber;
            ldc "wip"
            invokestatic java.util.concurrent.atomic.AtomicIntegerFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         4: .line 110
            putstatic reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
         5: .line 111
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(reactor.core.CoreSubscriber<? super T>, reactor.core.publisher.Sinks$Many<reactor.util.retry.Retry$RetrySignal>, reactor.core.CorePublisher<? extends T>, reactor.util.context.ContextView);
    descriptor: (Lreactor/core/CoreSubscriber;Lreactor/core/publisher/Sinks$Many;Lreactor/core/CorePublisher;Lreactor/util/context/ContextView;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // reactor.core.CoreSubscriber actual
        start local 2 // reactor.core.publisher.Sinks$Many signaller
        start local 3 // reactor.core.CorePublisher source
        start local 4 // reactor.util.context.ContextView retryContext
         0: .line 119
            aload 0 /* this */
            aload 1 /* actual */
            invokespecial reactor.core.publisher.Operators$MultiSubscriptionSubscriber.<init>:(Lreactor/core/CoreSubscriber;)V
         1: .line 101
            aload 0 /* this */
            lconst_0
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.totalFailureIndex:J
         2: .line 102
            aload 0 /* this */
            lconst_0
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.subsequentFailureIndex:J
         3: .line 104
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.lastFailure:Ljava/lang/Throwable;
         4: .line 120
            aload 0 /* this */
            aload 2 /* signaller */
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.signaller:Lreactor/core/publisher/Sinks$Many;
         5: .line 121
            aload 0 /* this */
            aload 3 /* source */
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.source:Lreactor/core/CorePublisher;
         6: .line 122
            aload 0 /* this */
            new reactor.core.publisher.Operators$DeferredSubscription
            dup
            invokespecial reactor.core.publisher.Operators$DeferredSubscription.<init>:()V
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
         7: .line 123
            aload 0 /* this */
            aload 1 /* actual */
            invokeinterface reactor.core.CoreSubscriber.currentContext:()Lreactor/util/context/Context;
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.context:Lreactor/util/context/Context;
         8: .line 124
            aload 0 /* this */
            aload 4 /* retryContext */
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.retryContext:Lreactor/util/context/ContextView;
         9: .line 125
            return
        end local 4 // reactor.util.context.ContextView retryContext
        end local 3 // reactor.core.CorePublisher source
        end local 2 // reactor.core.publisher.Sinks$Many signaller
        end local 1 // reactor.core.CoreSubscriber actual
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   10     0          this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0   10     1        actual  Lreactor/core/CoreSubscriber<-TT;>;
            0   10     2     signaller  Lreactor/core/publisher/Sinks$Many<Lreactor/util/retry/Retry$RetrySignal;>;
            0   10     3        source  Lreactor/core/CorePublisher<+TT;>;
            0   10     4  retryContext  Lreactor/util/context/ContextView;
    Signature: (Lreactor/core/CoreSubscriber<-TT;>;Lreactor/core/publisher/Sinks$Many<Lreactor/util/retry/Retry$RetrySignal;>;Lreactor/core/CorePublisher<+TT;>;Lreactor/util/context/ContextView;)V
    MethodParameters:
              Name  Flags
      actual        
      signaller     
      source        
      retryContext  

  public long totalRetries();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 129
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.totalFailureIndex:J
            lconst_1
            lsub
            lreturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  public long totalRetriesInARow();
    descriptor: ()J
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 134
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.subsequentFailureIndex:J
            lconst_1
            lsub
            lreturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  public java.lang.Throwable failure();
    descriptor: ()Ljava/lang/Throwable;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 139
            getstatic reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.lastFailure:Ljava/lang/Throwable;
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 140
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.lastFailure:Ljava/lang/Throwable;
            areturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  public reactor.util.context.ContextView retryContextView();
    descriptor: ()Lreactor/util/context/ContextView;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 145
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.retryContext:Lreactor/util/context/ContextView;
            areturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  public reactor.util.context.Context currentContext();
    descriptor: ()Lreactor/util/context/Context;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 150
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.context:Lreactor/util/context/Context;
            areturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  public java.util.stream.Stream<? extends reactor.core.Scannable> inners();
    descriptor: ()Ljava/util/stream/Stream;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 155
            iconst_2
            anewarray reactor.core.Scannable
            dup
            iconst_0
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.signaller:Lreactor/core/publisher/Sinks$Many;
            invokestatic reactor.core.Scannable.from:(Ljava/lang/Object;)Lreactor/core/Scannable;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
            aastore
            invokestatic java.util.stream.Stream.of:([Ljava/lang/Object;)Ljava/util/stream/Stream;
            areturn
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
    Signature: ()Ljava/util/stream/Stream<+Lreactor/core/Scannable;>;

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 160
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.cancelled:Z
            ifne 3
         1: .line 161
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
            invokevirtual reactor.core.publisher.Operators$DeferredSubscription.cancel:()V
         2: .line 162
            aload 0 /* this */
            invokespecial reactor.core.publisher.Operators$MultiSubscriptionSubscriber.cancel:()V
         3: .line 164
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  void swap(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // org.reactivestreams.Subscription w
         0: .line 167
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
            aload 1 /* w */
            invokevirtual reactor.core.publisher.Operators$DeferredSubscription.set:(Lorg/reactivestreams/Subscription;)Z
            pop
         1: .line 168
            return
        end local 1 // org.reactivestreams.Subscription w
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0    2     1     w  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      w     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // java.lang.Object t
         0: .line 172
            aload 0 /* this */
            lconst_0
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.subsequentFailureIndex:J
         1: .line 173
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* t */
            invokeinterface reactor.core.CoreSubscriber.onNext:(Ljava/lang/Object;)V
         2: .line 175
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.produced:J
            lconst_1
            ladd
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.produced:J
         3: .line 176
            return
        end local 1 // java.lang.Object t
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0    4     1     t  TT;
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 180
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.totalFailureIndex:J
            lconst_1
            ladd
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.totalFailureIndex:J
         1: .line 181
            aload 0 /* this */
            dup
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.subsequentFailureIndex:J
            lconst_1
            ladd
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.subsequentFailureIndex:J
         2: .line 182
            aload 0 /* this */
            aload 1 /* t */
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.lastFailure:Ljava/lang/Throwable;
         3: .line 183
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.produced:J
            lstore 2 /* p */
        start local 2 // long p
         4: .line 184
            lload 2 /* p */
            lconst_0
            lcmp
            ifeq 7
         5: .line 185
            aload 0 /* this */
            lconst_0
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.produced:J
         6: .line 186
            aload 0 /* this */
            lload 2 /* p */
            invokevirtual reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.produced:(J)V
         7: .line 189
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.signaller:Lreactor/core/publisher/Sinks$Many;
            aload 0 /* this */
            getstatic reactor.core.publisher.Sinks$EmitFailureHandler.FAIL_FAST:Lreactor/core/publisher/Sinks$EmitFailureHandler;
            invokeinterface reactor.core.publisher.Sinks$Many.emitNext:(Ljava/lang/Object;Lreactor/core/publisher/Sinks$EmitFailureHandler;)V
         8: .line 191
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
            lconst_1
            invokevirtual reactor.core.publisher.Operators$DeferredSubscription.request:(J)V
         9: .line 192
            return
        end local 2 // long p
        end local 1 // java.lang.Throwable t
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   10     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0   10     1     t  Ljava/lang/Throwable;
            4   10     2     p  J
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 196
            aload 0 /* this */
            aconst_null
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.lastFailure:Ljava/lang/Throwable;
         1: .line 197
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.otherArbiter:Lreactor/core/publisher/Operators$DeferredSubscription;
            invokevirtual reactor.core.publisher.Operators$DeferredSubscription.cancel:()V
         2: .line 199
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.onComplete:()V
         3: .line 200
            return
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;

  void resubscribe(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // java.lang.Object trigger
         0: .line 203
            getstatic reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.getAndIncrement:(Ljava/lang/Object;)I
            ifne 7
         1: .line 205
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.cancelled:Z
            ifeq 3
         2: .line 206
            return
         3: .line 211
      StackMap locals:
      StackMap stack:
            aload 1 /* trigger */
            instanceof reactor.util.context.ContextView
            ifeq 5
         4: .line 212
            aload 0 /* this */
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.context:Lreactor/util/context/Context;
            aload 1 /* trigger */
            checkcast reactor.util.context.ContextView
            invokeinterface reactor.util.context.Context.putAll:(Lreactor/util/context/ContextView;)Lreactor/util/context/Context;
            putfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.context:Lreactor/util/context/Context;
         5: .line 215
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.source:Lreactor/core/CorePublisher;
            aload 0 /* this */
            invokeinterface reactor.core.CorePublisher.subscribe:(Lreactor/core/CoreSubscriber;)V
         6: .line 217
            getstatic reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.WIP:Ljava/util/concurrent/atomic/AtomicIntegerFieldUpdater;
            aload 0 /* this */
            invokevirtual java.util.concurrent.atomic.AtomicIntegerFieldUpdater.decrementAndGet:(Ljava/lang/Object;)I
            ifne 1
         7: .line 219
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Object trigger
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    8     0     this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0    8     1  trigger  Ljava/lang/Object;
    MethodParameters:
         Name  Flags
      trigger  

  void whenError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // java.lang.Throwable e
         0: .line 222
            aload 0 /* this */
            invokespecial reactor.core.publisher.Operators$MultiSubscriptionSubscriber.cancel:()V
         1: .line 224
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            aload 1 /* e */
            invokeinterface reactor.core.CoreSubscriber.onError:(Ljava/lang/Throwable;)V
         2: .line 225
            return
        end local 1 // java.lang.Throwable e
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0    3     1     e  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      e     

  void whenComplete();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
         0: .line 228
            aload 0 /* this */
            invokespecial reactor.core.publisher.Operators$MultiSubscriptionSubscriber.cancel:()V
         1: .line 230
            aload 0 /* this */
            getfield reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber.actual:Lreactor/core/CoreSubscriber;
            invokeinterface reactor.core.CoreSubscriber.onComplete:()V
         2: .line 231
            return
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<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.FluxRetryWhen$RetryWhenMainSubscriber this
        start local 1 // reactor.core.Scannable$Attr key
         0: .line 235
            aload 1 /* key */
            getstatic reactor.core.Scannable$Attr.RUN_STYLE:Lreactor/core/Scannable$Attr;
            if_acmpne 1
            getstatic reactor.core.Scannable$Attr$RunStyle.SYNC:Lreactor/core/Scannable$Attr$RunStyle;
            areturn
         1: .line 236
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* key */
            invokespecial reactor.core.publisher.Operators$MultiSubscriptionSubscriber.scanUnsafe:(Lreactor/core/Scannable$Attr;)Ljava/lang/Object;
            areturn
        end local 1 // reactor.core.Scannable$Attr key
        end local 0 // reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/publisher/FluxRetryWhen$RetryWhenMainSubscriber<TT;>;
            0    2     1   key  Lreactor/core/Scannable$Attr;
    MethodParameters:
      Name  Flags
      key   
}
Signature: <T:Ljava/lang/Object;>Lreactor/core/publisher/Operators$MultiSubscriptionSubscriber<TT;TT;>;Lreactor/util/retry/Retry$RetrySignal;
SourceFile: "FluxRetryWhen.java"
NestHost: reactor.core.publisher.FluxRetryWhen
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 RetryWhenMainSubscriber = reactor.core.publisher.FluxRetryWhen$RetryWhenMainSubscriber of reactor.core.publisher.FluxRetryWhen
  public DeferredSubscription = reactor.core.publisher.Operators$DeferredSubscription of reactor.core.publisher.Operators
  abstract MultiSubscriptionSubscriber = reactor.core.publisher.Operators$MultiSubscriptionSubscriber of reactor.core.publisher.Operators
  public abstract EmitFailureHandler = reactor.core.publisher.Sinks$EmitFailureHandler of reactor.core.publisher.Sinks
  public abstract Many = reactor.core.publisher.Sinks$Many of reactor.core.publisher.Sinks
  public abstract RetrySignal = reactor.util.retry.Retry$RetrySignal of reactor.util.retry.Retry