final class reactor.core.scheduler.PeriodicWorkerTask implements java.lang.Runnable, reactor.core.Disposable, java.util.concurrent.Callable<java.lang.Void>
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.scheduler.PeriodicWorkerTask
  super_class: java.lang.Object
{
  final java.lang.Runnable task;
    descriptor: Ljava/lang/Runnable;
    flags: (0x0010) ACC_FINAL

  static final reactor.core.Disposable$Composite DISPOSED;
    descriptor: Lreactor/core/Disposable$Composite;
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  static final java.util.concurrent.Future<java.lang.Void> CANCELLED;
    descriptor: Ljava/util/concurrent/Future;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/Future<Ljava/lang/Void;>;

  volatile java.util.concurrent.Future<?> future;
    descriptor: Ljava/util/concurrent/Future;
    flags: (0x0040) ACC_VOLATILE
    Signature: Ljava/util/concurrent/Future<*>;

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.scheduler.PeriodicWorkerTask, java.util.concurrent.Future> FUTURE;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/scheduler/PeriodicWorkerTask;Ljava/util/concurrent/Future;>;

  volatile reactor.core.Disposable$Composite parent;
    descriptor: Lreactor/core/Disposable$Composite;
    flags: (0x0040) ACC_VOLATILE

  static final java.util.concurrent.atomic.AtomicReferenceFieldUpdater<reactor.core.scheduler.PeriodicWorkerTask, reactor.core.Disposable$Composite> PARENT;
    descriptor: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater<Lreactor/core/scheduler/PeriodicWorkerTask;Lreactor/core/Disposable$Composite;>;

  java.lang.Thread thread;
    descriptor: Ljava/lang/Thread;
    flags: (0x0000) 

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 34
            new reactor.core.scheduler.EmptyCompositeDisposable
            dup
            invokespecial reactor.core.scheduler.EmptyCompositeDisposable.<init>:()V
            putstatic reactor.core.scheduler.PeriodicWorkerTask.DISPOSED:Lreactor/core/Disposable$Composite;
         1: .line 36
            new java.util.concurrent.FutureTask
            dup
            invokedynamic call()Ljava/util/concurrent/Callable;
              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:
                  ()Ljava/lang/Object;
                  reactor/core/scheduler/PeriodicWorkerTask.lambda$0()Ljava/lang/Void; (6)
                  ()Ljava/lang/Void;
            invokespecial java.util.concurrent.FutureTask.<init>:(Ljava/util/concurrent/Callable;)V
            putstatic reactor.core.scheduler.PeriodicWorkerTask.CANCELLED:Ljava/util/concurrent/Future;
         2: .line 40
            ldc Lreactor/core/scheduler/PeriodicWorkerTask;
            ldc Ljava/util/concurrent/Future;
            ldc "future"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         3: .line 39
            putstatic reactor.core.scheduler.PeriodicWorkerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         4: .line 44
            ldc Lreactor/core/scheduler/PeriodicWorkerTask;
            ldc Lreactor/core/Disposable$Composite;
            ldc "parent"
            invokestatic java.util.concurrent.atomic.AtomicReferenceFieldUpdater.newUpdater:(Ljava/lang/Class;Ljava/lang/Class;Ljava/lang/String;)Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         5: .line 43
            putstatic reactor.core.scheduler.PeriodicWorkerTask.PARENT:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
         6: .line 44
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.Runnable, reactor.core.Disposable$Composite);
    descriptor: (Ljava/lang/Runnable;Lreactor/core/Disposable$Composite;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
        start local 1 // java.lang.Runnable task
        start local 2 // reactor.core.Disposable$Composite parent
         0: .line 48
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 49
            aload 0 /* this */
            aload 1 /* task */
            putfield reactor.core.scheduler.PeriodicWorkerTask.task:Ljava/lang/Runnable;
         2: .line 50
            getstatic reactor.core.scheduler.PeriodicWorkerTask.PARENT:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 2 /* parent */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.lazySet:(Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 51
            return
        end local 2 // reactor.core.Disposable$Composite parent
        end local 1 // java.lang.Runnable task
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lreactor/core/scheduler/PeriodicWorkerTask;
            0    4     1    task  Ljava/lang/Runnable;
            0    4     2  parent  Lreactor/core/Disposable$Composite;
    MethodParameters:
        Name  Flags
      task    
      parent  

  public java.lang.Void call();
    descriptor: ()Ljava/lang/Void;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
         0: .line 56
            aload 0 /* this */
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            putfield reactor.core.scheduler.PeriodicWorkerTask.thread:Ljava/lang/Thread;
         1: .line 59
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.task:Ljava/lang/Runnable;
            invokeinterface java.lang.Runnable.run:()V
         2: .line 60
            goto 9
         3: .line 61
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1 /* ex */
        start local 1 // java.lang.Throwable ex
         4: .line 62
            aload 1 /* ex */
            invokestatic reactor.core.scheduler.Schedulers.handleError:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Throwable ex
         5: .line 64
            goto 9
         6: .line 65
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
         7: .line 66
            aload 0 /* this */
            aconst_null
            putfield reactor.core.scheduler.PeriodicWorkerTask.thread:Ljava/lang/Thread;
         8: .line 67
            aload 2
            athrow
         9: .line 66
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aconst_null
            putfield reactor.core.scheduler.PeriodicWorkerTask.thread:Ljava/lang/Thread;
        10: .line 68
            aconst_null
            areturn
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   11     0  this  Lreactor/core/scheduler/PeriodicWorkerTask;
            4    5     1    ex  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.Throwable
           1     6       6  any
    RuntimeVisibleAnnotations: 
      reactor.util.annotation.Nullable()

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
         0: .line 73
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.PeriodicWorkerTask.call:()Ljava/lang/Void;
            pop
         1: .line 74
            return
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/scheduler/PeriodicWorkerTask;

  void setFuture(java.util.concurrent.Future<?>);
    descriptor: (Ljava/util/concurrent/Future;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
        start local 1 // java.util.concurrent.Future f
         0: .line 78
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.future:Ljava/util/concurrent/Future;
            astore 2 /* o */
        start local 2 // java.util.concurrent.Future o
         1: .line 79
            aload 2 /* o */
            getstatic reactor.core.scheduler.PeriodicWorkerTask.CANCELLED:Ljava/util/concurrent/Future;
            if_acmpne 6
         2: .line 80
            aload 1 /* f */
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.thread:Ljava/lang/Thread;
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            if_acmpeq 3
            iconst_1
            goto 4
      StackMap locals: reactor.core.scheduler.PeriodicWorkerTask java.util.concurrent.Future java.util.concurrent.Future
      StackMap stack: java.util.concurrent.Future
         3: iconst_0
      StackMap locals: reactor.core.scheduler.PeriodicWorkerTask java.util.concurrent.Future java.util.concurrent.Future
      StackMap stack: java.util.concurrent.Future int
         4: invokeinterface java.util.concurrent.Future.cancel:(Z)Z
            pop
         5: .line 81
            return
         6: .line 83
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.scheduler.PeriodicWorkerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 2 /* o */
            aload 1 /* f */
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 0
         7: .line 84
            return
        end local 2 // java.util.concurrent.Future o
        end local 1 // java.util.concurrent.Future f
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lreactor/core/scheduler/PeriodicWorkerTask;
            0    8     1     f  Ljava/util/concurrent/Future<*>;
            1    8     2     o  Ljava/util/concurrent/Future;
    Signature: (Ljava/util/concurrent/Future<*>;)V
    MethodParameters:
      Name  Flags
      f     

  public boolean isDisposed();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
         0: .line 91
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.future:Ljava/util/concurrent/Future;
            getstatic reactor.core.scheduler.PeriodicWorkerTask.CANCELLED:Ljava/util/concurrent/Future;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lreactor/core/scheduler/PeriodicWorkerTask;

  public void dispose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // reactor.core.scheduler.PeriodicWorkerTask this
         0: .line 97
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.future:Ljava/util/concurrent/Future;
            astore 1 /* f */
        start local 1 // java.util.concurrent.Future f
         1: .line 98
            aload 1 /* f */
            getstatic reactor.core.scheduler.PeriodicWorkerTask.CANCELLED:Ljava/util/concurrent/Future;
            if_acmpne 3
         2: .line 99
            goto 8
         3: .line 101
      StackMap locals: java.util.concurrent.Future
      StackMap stack:
            getstatic reactor.core.scheduler.PeriodicWorkerTask.FUTURE:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* f */
            getstatic reactor.core.scheduler.PeriodicWorkerTask.CANCELLED:Ljava/util/concurrent/Future;
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 0
         4: .line 102
            aload 1 /* f */
            ifnull 8
         5: .line 103
            aload 1 /* f */
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.thread:Ljava/lang/Thread;
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            if_acmpeq 6
            iconst_1
            goto 7
      StackMap locals:
      StackMap stack: java.util.concurrent.Future
         6: iconst_0
      StackMap locals: reactor.core.scheduler.PeriodicWorkerTask java.util.concurrent.Future
      StackMap stack: java.util.concurrent.Future int
         7: invokeinterface java.util.concurrent.Future.cancel:(Z)Z
            pop
        end local 1 // java.util.concurrent.Future f
         8: .line 110
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.PeriodicWorkerTask.parent:Lreactor/core/Disposable$Composite;
            astore 1 /* o */
        start local 1 // reactor.core.Disposable$Composite o
         9: .line 111
            aload 1 /* o */
            getstatic reactor.core.scheduler.PeriodicWorkerTask.DISPOSED:Lreactor/core/Disposable$Composite;
            if_acmpeq 10
            aload 1 /* o */
            ifnonnull 11
        10: .line 112
      StackMap locals: reactor.core.Disposable$Composite
      StackMap stack:
            return
        11: .line 114
      StackMap locals:
      StackMap stack:
            getstatic reactor.core.scheduler.PeriodicWorkerTask.PARENT:Ljava/util/concurrent/atomic/AtomicReferenceFieldUpdater;
            aload 0 /* this */
            aload 1 /* o */
            getstatic reactor.core.scheduler.PeriodicWorkerTask.DISPOSED:Lreactor/core/Disposable$Composite;
            invokevirtual java.util.concurrent.atomic.AtomicReferenceFieldUpdater.compareAndSet:(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;)Z
            ifeq 8
        12: .line 115
            aload 1 /* o */
            aload 0 /* this */
            invokeinterface reactor.core.Disposable$Composite.remove:(Lreactor/core/Disposable;)Z
            pop
        13: .line 116
            return
        end local 1 // reactor.core.Disposable$Composite o
        end local 0 // reactor.core.scheduler.PeriodicWorkerTask this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   14     0  this  Lreactor/core/scheduler/PeriodicWorkerTask;
            1    8     1     f  Ljava/util/concurrent/Future;
            9   14     1     o  Lreactor/core/Disposable$Composite;

  public java.lang.Object call();
    descriptor: ()Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual reactor.core.scheduler.PeriodicWorkerTask.call:()Ljava/lang/Void;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception

  private static java.lang.Void lambda$0();
    descriptor: ()Ljava/lang/Void;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 36
            aconst_null
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception
}
Signature: Ljava/lang/Object;Ljava/lang/Runnable;Lreactor/core/Disposable;Ljava/util/concurrent/Callable<Ljava/lang/Void;>;
SourceFile: "PeriodicWorkerTask.java"
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public abstract Composite = reactor.core.Disposable$Composite of reactor.core.Disposable