public abstract class reactor.util.concurrent.WaitStrategy
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: reactor.util.concurrent.WaitStrategy
  super_class: java.lang.Object
{
  public static final java.lang.Runnable NOOP_SPIN_OBSERVER;
    descriptor: Ljava/lang/Runnable;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 36
            invokedynamic run()Ljava/lang/Runnable;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()V
                  reactor/util/concurrent/WaitStrategy.lambda$0()V (6)
                  ()V
            putstatic reactor.util.concurrent.WaitStrategy.NOOP_SPIN_OBSERVER:Ljava/lang/Runnable;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.util.concurrent.WaitStrategy this
         0: .line 30
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // reactor.util.concurrent.WaitStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/util/concurrent/WaitStrategy;

  public static reactor.util.concurrent.WaitStrategy blocking();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 45
            new reactor.util.concurrent.WaitStrategy$Blocking
            dup
            invokespecial reactor.util.concurrent.WaitStrategy$Blocking.<init>:()V
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static reactor.util.concurrent.WaitStrategy busySpin();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 56
            getstatic reactor.util.concurrent.WaitStrategy$BusySpin.INSTANCE:Lreactor/util/concurrent/WaitStrategy$BusySpin;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static boolean isAlert(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)Z
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.Throwable t
         0: .line 65
            aload 0 /* t */
            getstatic reactor.util.concurrent.WaitStrategy$AlertException.INSTANCE:Lreactor/util/concurrent/WaitStrategy$AlertException;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // java.lang.Throwable t
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public static reactor.util.concurrent.WaitStrategy liteBlocking();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 75
            new reactor.util.concurrent.WaitStrategy$LiteBlocking
            dup
            invokespecial reactor.util.concurrent.WaitStrategy$LiteBlocking.<init>:()V
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static reactor.util.concurrent.WaitStrategy parking();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 88
            getstatic reactor.util.concurrent.WaitStrategy$Parking.INSTANCE:Lreactor/util/concurrent/WaitStrategy$Parking;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static reactor.util.concurrent.WaitStrategy parking(int);
    descriptor: (I)Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // int retries
         0: .line 103
            new reactor.util.concurrent.WaitStrategy$Parking
            dup
            iload 0 /* retries */
            invokespecial reactor.util.concurrent.WaitStrategy$Parking.<init>:(I)V
            areturn
        end local 0 // int retries
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  retries  I
    MethodParameters:
         Name  Flags
      retries  

  public static reactor.util.concurrent.WaitStrategy phasedOff(long, long, java.util.concurrent.TimeUnit, reactor.util.concurrent.WaitStrategy);
    descriptor: (JJLjava/util/concurrent/TimeUnit;Lreactor/util/concurrent/WaitStrategy;)Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=6, args_size=4
        start local 0 // long spinTimeout
        start local 2 // long yieldTimeout
        start local 4 // java.util.concurrent.TimeUnit units
        start local 5 // reactor.util.concurrent.WaitStrategy delegate
         0: .line 119
            new reactor.util.concurrent.WaitStrategy$PhasedOff
            dup
            lload 0 /* spinTimeout */
            lload 2 /* yieldTimeout */
            aload 4 /* units */
            aload 5 /* delegate */
            invokespecial reactor.util.concurrent.WaitStrategy$PhasedOff.<init>:(JJLjava/util/concurrent/TimeUnit;Lreactor/util/concurrent/WaitStrategy;)V
            areturn
        end local 5 // reactor.util.concurrent.WaitStrategy delegate
        end local 4 // java.util.concurrent.TimeUnit units
        end local 2 // long yieldTimeout
        end local 0 // long spinTimeout
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0   spinTimeout  J
            0    1     2  yieldTimeout  J
            0    1     4         units  Ljava/util/concurrent/TimeUnit;
            0    1     5      delegate  Lreactor/util/concurrent/WaitStrategy;
    MethodParameters:
              Name  Flags
      spinTimeout   
      yieldTimeout  
      units         
      delegate      

  public static reactor.util.concurrent.WaitStrategy phasedOffLiteLock(long, long, java.util.concurrent.TimeUnit);
    descriptor: (JJLjava/util/concurrent/TimeUnit;)Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // long spinTimeout
        start local 2 // long yieldTimeout
        start local 4 // java.util.concurrent.TimeUnit units
         0: .line 130
            lload 0 /* spinTimeout */
            lload 2 /* yieldTimeout */
            aload 4 /* units */
            invokestatic reactor.util.concurrent.WaitStrategy.liteBlocking:()Lreactor/util/concurrent/WaitStrategy;
            invokestatic reactor.util.concurrent.WaitStrategy.phasedOff:(JJLjava/util/concurrent/TimeUnit;Lreactor/util/concurrent/WaitStrategy;)Lreactor/util/concurrent/WaitStrategy;
            areturn
        end local 4 // java.util.concurrent.TimeUnit units
        end local 2 // long yieldTimeout
        end local 0 // long spinTimeout
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0   spinTimeout  J
            0    1     2  yieldTimeout  J
            0    1     4         units  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
              Name  Flags
      spinTimeout   
      yieldTimeout  
      units         

  public static reactor.util.concurrent.WaitStrategy phasedOffLock(long, long, java.util.concurrent.TimeUnit);
    descriptor: (JJLjava/util/concurrent/TimeUnit;)Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // long spinTimeout
        start local 2 // long yieldTimeout
        start local 4 // java.util.concurrent.TimeUnit units
         0: .line 141
            lload 0 /* spinTimeout */
            lload 2 /* yieldTimeout */
            aload 4 /* units */
            invokestatic reactor.util.concurrent.WaitStrategy.blocking:()Lreactor/util/concurrent/WaitStrategy;
            invokestatic reactor.util.concurrent.WaitStrategy.phasedOff:(JJLjava/util/concurrent/TimeUnit;Lreactor/util/concurrent/WaitStrategy;)Lreactor/util/concurrent/WaitStrategy;
            areturn
        end local 4 // java.util.concurrent.TimeUnit units
        end local 2 // long yieldTimeout
        end local 0 // long spinTimeout
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0   spinTimeout  J
            0    1     2  yieldTimeout  J
            0    1     4         units  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
              Name  Flags
      spinTimeout   
      yieldTimeout  
      units         

  public static reactor.util.concurrent.WaitStrategy phasedOffSleep(long, long, java.util.concurrent.TimeUnit);
    descriptor: (JJLjava/util/concurrent/TimeUnit;)Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=5, args_size=3
        start local 0 // long spinTimeout
        start local 2 // long yieldTimeout
        start local 4 // java.util.concurrent.TimeUnit units
         0: .line 152
            lload 0 /* spinTimeout */
            lload 2 /* yieldTimeout */
            aload 4 /* units */
            iconst_0
            invokestatic reactor.util.concurrent.WaitStrategy.parking:(I)Lreactor/util/concurrent/WaitStrategy;
            invokestatic reactor.util.concurrent.WaitStrategy.phasedOff:(JJLjava/util/concurrent/TimeUnit;Lreactor/util/concurrent/WaitStrategy;)Lreactor/util/concurrent/WaitStrategy;
            areturn
        end local 4 // java.util.concurrent.TimeUnit units
        end local 2 // long yieldTimeout
        end local 0 // long spinTimeout
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0   spinTimeout  J
            0    1     2  yieldTimeout  J
            0    1     4         units  Ljava/util/concurrent/TimeUnit;
    MethodParameters:
              Name  Flags
      spinTimeout   
      yieldTimeout  
      units         

  public static reactor.util.concurrent.WaitStrategy sleeping();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 164
            getstatic reactor.util.concurrent.WaitStrategy$Sleeping.INSTANCE:Lreactor/util/concurrent/WaitStrategy$Sleeping;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static reactor.util.concurrent.WaitStrategy yielding();
    descriptor: ()Lreactor/util/concurrent/WaitStrategy;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 176
            getstatic reactor.util.concurrent.WaitStrategy$Yielding.INSTANCE:Lreactor/util/concurrent/WaitStrategy$Yielding;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void signalAllWhenBlocking();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=1, args_size=1
        start local 0 // reactor.util.concurrent.WaitStrategy this
         0: .line 183
            return
        end local 0 // reactor.util.concurrent.WaitStrategy this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/util/concurrent/WaitStrategy;

  public abstract long waitFor(long, java.util.function.LongSupplier, java.lang.Runnable);
    descriptor: (JLjava/util/function/LongSupplier;Ljava/lang/Runnable;)J
    flags: (0x0401) ACC_PUBLIC, ACC_ABSTRACT
    Exceptions:
      throws java.lang.InterruptedException
    MethodParameters:
              Name  Flags
      sequence      
      cursor        
      spinObserver  

  public static void alert();
    descriptor: ()V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 205
            getstatic reactor.util.concurrent.WaitStrategy$AlertException.INSTANCE:Lreactor/util/concurrent/WaitStrategy$AlertException;
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static void lambda$0();
    descriptor: ()V
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=0, locals=0, args_size=0
         0: .line 36
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "WaitStrategy.java"
NestMembers:
  reactor.util.concurrent.WaitStrategy$AlertException  reactor.util.concurrent.WaitStrategy$Blocking  reactor.util.concurrent.WaitStrategy$BusySpin  reactor.util.concurrent.WaitStrategy$LiteBlocking  reactor.util.concurrent.WaitStrategy$Parking  reactor.util.concurrent.WaitStrategy$PhasedOff  reactor.util.concurrent.WaitStrategy$Sleeping  reactor.util.concurrent.WaitStrategy$Yielding
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  final AlertException = reactor.util.concurrent.WaitStrategy$AlertException of reactor.util.concurrent.WaitStrategy
  final Blocking = reactor.util.concurrent.WaitStrategy$Blocking of reactor.util.concurrent.WaitStrategy
  final BusySpin = reactor.util.concurrent.WaitStrategy$BusySpin of reactor.util.concurrent.WaitStrategy
  final LiteBlocking = reactor.util.concurrent.WaitStrategy$LiteBlocking of reactor.util.concurrent.WaitStrategy
  final Parking = reactor.util.concurrent.WaitStrategy$Parking of reactor.util.concurrent.WaitStrategy
  final PhasedOff = reactor.util.concurrent.WaitStrategy$PhasedOff of reactor.util.concurrent.WaitStrategy
  final Sleeping = reactor.util.concurrent.WaitStrategy$Sleeping of reactor.util.concurrent.WaitStrategy
  final Yielding = reactor.util.concurrent.WaitStrategy$Yielding of reactor.util.concurrent.WaitStrategy