final class reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable extends java.util.concurrent.atomic.AtomicBoolean implements java.lang.Runnable, reactor.core.Disposable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable
  super_class: java.util.concurrent.atomic.AtomicBoolean
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 3503344795919906192

  final java.lang.Runnable task;
    descriptor: Ljava/lang/Runnable;
    flags: (0x0010) ACC_FINAL

  final reactor.core.scheduler.ExecutorScheduler$WorkerDelete parent;
    descriptor: Lreactor/core/scheduler/ExecutorScheduler$WorkerDelete;
    flags: (0x0010) ACC_FINAL

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

  void <init>(java.lang.Runnable, reactor.core.scheduler.ExecutorScheduler$WorkerDelete, boolean);
    descriptor: (Ljava/lang/Runnable;Lreactor/core/scheduler/ExecutorScheduler$WorkerDelete;Z)V
    flags: (0x0000) 
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
        start local 1 // java.lang.Runnable task
        start local 2 // reactor.core.scheduler.ExecutorScheduler$WorkerDelete parent
        start local 3 // boolean callRemoveOnFinish
         0: .line 177
            aload 0 /* this */
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:()V
         1: .line 180
            aload 0 /* this */
            aload 1 /* task */
            putfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.task:Ljava/lang/Runnable;
         2: .line 181
            aload 0 /* this */
            aload 2 /* parent */
            putfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.parent:Lreactor/core/scheduler/ExecutorScheduler$WorkerDelete;
         3: .line 182
            aload 0 /* this */
            iload 3 /* callRemoveOnFinish */
            putfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.callRemoveOnFinish:Z
         4: .line 183
            return
        end local 3 // boolean callRemoveOnFinish
        end local 2 // reactor.core.scheduler.ExecutorScheduler$WorkerDelete parent
        end local 1 // java.lang.Runnable task
        end local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    5     0                this  Lreactor/core/scheduler/ExecutorScheduler$ExecutorTrackedRunnable;
            0    5     1                task  Ljava/lang/Runnable;
            0    5     2              parent  Lreactor/core/scheduler/ExecutorScheduler$WorkerDelete;
            0    5     3  callRemoveOnFinish  Z
    MethodParameters:
                    Name  Flags
      task                
      parent              
      callRemoveOnFinish  

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=1
        start local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
         0: .line 187
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.get:()Z
            ifne 19
         1: .line 189
            aload 0 /* this */
            getfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.task:Ljava/lang/Runnable;
            invokeinterface java.lang.Runnable.run:()V
         2: .line 190
            goto 15
         3: .line 191
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 1 /* ex */
        start local 1 // java.lang.Throwable ex
         4: .line 192
            aload 1 /* ex */
            invokestatic reactor.core.scheduler.Schedulers.handleError:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Throwable ex
         5: .line 195
            aload 0 /* this */
            getfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.callRemoveOnFinish:Z
            ifeq 8
         6: .line 196
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.dispose:()V
         7: .line 197
            goto 19
         8: .line 199
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.lazySet:(Z)V
            goto 19
         9: .line 194
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 2
        10: .line 195
            aload 0 /* this */
            getfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.callRemoveOnFinish:Z
            ifeq 13
        11: .line 196
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.dispose:()V
        12: .line 197
            goto 14
        13: .line 199
      StackMap locals: reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable top java.lang.Throwable
      StackMap stack:
            aload 0 /* this */
            iconst_1
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.lazySet:(Z)V
        14: .line 201
      StackMap locals:
      StackMap stack:
            aload 2
            athrow
        15: .line 195
      StackMap locals: reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable
      StackMap stack:
            aload 0 /* this */
            getfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.callRemoveOnFinish:Z
            ifeq 18
        16: .line 196
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.dispose:()V
        17: .line 197
            goto 19
        18: .line 199
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.lazySet:(Z)V
        19: .line 203
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   20     0  this  Lreactor/core/scheduler/ExecutorScheduler$ExecutorTrackedRunnable;
            4    5     1    ex  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1     2       3  Class java.lang.Throwable
           1     5       9  any

  public void dispose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
         0: .line 207
            aload 0 /* this */
            iconst_0
            iconst_1
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.compareAndSet:(ZZ)Z
            ifeq 2
         1: .line 208
            aload 0 /* this */
            getfield reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.parent:Lreactor/core/scheduler/ExecutorScheduler$WorkerDelete;
            aload 0 /* this */
            invokeinterface reactor.core.scheduler.ExecutorScheduler$WorkerDelete.delete:(Lreactor/core/scheduler/ExecutorScheduler$ExecutorTrackedRunnable;)V
         2: .line 210
      StackMap locals:
      StackMap stack:
            return
        end local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lreactor/core/scheduler/ExecutorScheduler$ExecutorTrackedRunnable;

  public boolean isDisposed();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
         0: .line 214
            aload 0 /* this */
            invokevirtual reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable.get:()Z
            ireturn
        end local 0 // reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lreactor/core/scheduler/ExecutorScheduler$ExecutorTrackedRunnable;
}
SourceFile: "ExecutorScheduler.java"
NestHost: reactor.core.scheduler.ExecutorScheduler
InnerClasses:
  final ExecutorTrackedRunnable = reactor.core.scheduler.ExecutorScheduler$ExecutorTrackedRunnable of reactor.core.scheduler.ExecutorScheduler
  abstract WorkerDelete = reactor.core.scheduler.ExecutorScheduler$WorkerDelete of reactor.core.scheduler.ExecutorScheduler