final class io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber<T> extends java.util.concurrent.atomic.AtomicLong implements io.reactivex.FlowableSubscriber<T>, org.reactivestreams.Subscription, io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSupport
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber
  super_class: java.util.concurrent.atomic.AtomicLong
{
  private static final long serialVersionUID;
    descriptor: J
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 3764492702657003550

  final org.reactivestreams.Subscriber<? super T> downstream;
    descriptor: Lorg/reactivestreams/Subscriber;
    flags: (0x0010) ACC_FINAL
    Signature: Lorg/reactivestreams/Subscriber<-TT;>;

  final long timeout;
    descriptor: J
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.TimeUnit unit;
    descriptor: Ljava/util/concurrent/TimeUnit;
    flags: (0x0010) ACC_FINAL

  final io.reactivex.Scheduler$Worker worker;
    descriptor: Lio/reactivex/Scheduler$Worker;
    flags: (0x0010) ACC_FINAL

  final io.reactivex.internal.disposables.SequentialDisposable task;
    descriptor: Lio/reactivex/internal/disposables/SequentialDisposable;
    flags: (0x0010) ACC_FINAL

  final java.util.concurrent.atomic.AtomicReference<org.reactivestreams.Subscription> upstream;
    descriptor: Ljava/util/concurrent/atomic/AtomicReference;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/concurrent/atomic/AtomicReference<Lorg/reactivestreams/Subscription;>;

  final java.util.concurrent.atomic.AtomicLong requested;
    descriptor: Ljava/util/concurrent/atomic/AtomicLong;
    flags: (0x0010) ACC_FINAL

  void <init>(org.reactivestreams.Subscriber<? super T>, long, java.util.concurrent.TimeUnit, io.reactivex.Scheduler$Worker);
    descriptor: (Lorg/reactivestreams/Subscriber;JLjava/util/concurrent/TimeUnit;Lio/reactivex/Scheduler$Worker;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=6, args_size=5
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // long timeout
        start local 4 // java.util.concurrent.TimeUnit unit
        start local 5 // io.reactivex.Scheduler$Worker worker
         0: .line 77
            aload 0 /* this */
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
         1: .line 78
            aload 0 /* this */
            aload 1 /* actual */
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.downstream:Lorg/reactivestreams/Subscriber;
         2: .line 79
            aload 0 /* this */
            lload 2 /* timeout */
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.timeout:J
         3: .line 80
            aload 0 /* this */
            aload 4 /* unit */
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.unit:Ljava/util/concurrent/TimeUnit;
         4: .line 81
            aload 0 /* this */
            aload 5 /* worker */
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
         5: .line 82
            aload 0 /* this */
            new io.reactivex.internal.disposables.SequentialDisposable
            dup
            invokespecial io.reactivex.internal.disposables.SequentialDisposable.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.task:Lio/reactivex/internal/disposables/SequentialDisposable;
         6: .line 83
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicReference
            dup
            invokespecial java.util.concurrent.atomic.AtomicReference.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
         7: .line 84
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
         8: .line 85
            return
        end local 5 // io.reactivex.Scheduler$Worker worker
        end local 4 // java.util.concurrent.TimeUnit unit
        end local 2 // long timeout
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    9     0     this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    9     1   actual  Lorg/reactivestreams/Subscriber<-TT;>;
            0    9     2  timeout  J
            0    9     4     unit  Ljava/util/concurrent/TimeUnit;
            0    9     5   worker  Lio/reactivex/Scheduler$Worker;
    Signature: (Lorg/reactivestreams/Subscriber<-TT;>;JLjava/util/concurrent/TimeUnit;Lio/reactivex/Scheduler$Worker;)V
    MethodParameters:
         Name  Flags
      actual   
      timeout  
      unit     
      worker   

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 89
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.deferredSetOnce:(Ljava/util/concurrent/atomic/AtomicReference;Ljava/util/concurrent/atomic/AtomicLong;Lorg/reactivestreams/Subscription;)Z
            pop
         1: .line 90
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    2     1     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=4, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // java.lang.Object t
         0: .line 94
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.get:()J
            lstore 2 /* idx */
        start local 2 // long idx
         1: .line 95
            lload 2 /* idx */
            ldc 9223372036854775807
            lcmp
            ifeq 2
            aload 0 /* this */
            lload 2 /* idx */
            lload 2 /* idx */
            lconst_1
            ladd
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.compareAndSet:(JJ)Z
            ifne 3
         2: .line 96
      StackMap locals: long
      StackMap stack:
            return
         3: .line 99
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.task:Lio/reactivex/internal/disposables/SequentialDisposable;
            invokevirtual io.reactivex.internal.disposables.SequentialDisposable.get:()Ljava/lang/Object;
            checkcast io.reactivex.disposables.Disposable
            invokeinterface io.reactivex.disposables.Disposable.dispose:()V
         4: .line 101
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
         5: .line 103
            aload 0 /* this */
            lload 2 /* idx */
            lconst_1
            ladd
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.startTimeout:(J)V
         6: .line 104
            return
        end local 2 // long idx
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    7     1     t  TT;
            1    7     2   idx  J
    Signature: (TT;)V
    MethodParameters:
      Name  Flags
      t     

  void startTimeout(long);
    descriptor: (J)V
    flags: (0x0000) 
    Code:
      stack=7, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // long nextIndex
         0: .line 107
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.task:Lio/reactivex/internal/disposables/SequentialDisposable;
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            new io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutTask
            dup
            lload 1 /* nextIndex */
            aload 0 /* this */
            invokespecial io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutTask.<init>:(JLio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSupport;)V
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.timeout:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.unit:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
            invokevirtual io.reactivex.internal.disposables.SequentialDisposable.replace:(Lio/reactivex/disposables/Disposable;)Z
            pop
         1: .line 108
            return
        end local 1 // long nextIndex
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    2     1  nextIndex  J
    MethodParameters:
           Name  Flags
      nextIndex  

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 112
            aload 0 /* this */
            ldc 9223372036854775807
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.getAndSet:(J)J
            ldc 9223372036854775807
            lcmp
            ifeq 5
         1: .line 113
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.task:Lio/reactivex/internal/disposables/SequentialDisposable;
            invokevirtual io.reactivex.internal.disposables.SequentialDisposable.dispose:()V
         2: .line 115
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         3: .line 117
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         4: .line 118
            goto 6
         5: .line 119
      StackMap locals:
      StackMap stack:
            aload 1 /* t */
            invokestatic io.reactivex.plugins.RxJavaPlugins.onError:(Ljava/lang/Throwable;)V
         6: .line 121
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    7     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
         0: .line 125
            aload 0 /* this */
            ldc 9223372036854775807
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.getAndSet:(J)J
            ldc 9223372036854775807
            lcmp
            ifeq 4
         1: .line 126
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.task:Lio/reactivex/internal/disposables/SequentialDisposable;
            invokevirtual io.reactivex.internal.disposables.SequentialDisposable.dispose:()V
         2: .line 128
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
         3: .line 130
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         4: .line 132
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;

  public void onTimeout(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // long idx
         0: .line 136
            aload 0 /* this */
            lload 1 /* idx */
            ldc 9223372036854775807
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.compareAndSet:(JJ)Z
            ifeq 4
         1: .line 137
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.cancel:(Ljava/util/concurrent/atomic/AtomicReference;)Z
            pop
         2: .line 139
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            new java.util.concurrent.TimeoutException
            dup
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.timeout:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.unit:Ljava/util/concurrent/TimeUnit;
            invokestatic io.reactivex.internal.util.ExceptionHelper.timeoutMessage:(JLjava/util/concurrent/TimeUnit;)Ljava/lang/String;
            invokespecial java.util.concurrent.TimeoutException.<init>:(Ljava/lang/String;)V
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         3: .line 141
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         4: .line 143
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long idx
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    5     1   idx  J
    MethodParameters:
      Name  Flags
      idx   

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
        start local 1 // long n
         0: .line 147
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 1 /* n */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.deferredRequest:(Ljava/util/concurrent/atomic/AtomicReference;Ljava/util/concurrent/atomic/AtomicLong;J)V
         1: .line 148
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
            0    2     1     n  J
    MethodParameters:
      Name  Flags
      n     

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
         0: .line 152
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.upstream:Ljava/util/concurrent/atomic/AtomicReference;
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.cancel:(Ljava/util/concurrent/atomic/AtomicReference;)Z
            pop
         1: .line 153
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         2: .line 154
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSubscriber<TT;>;
}
Signature: <T:Ljava/lang/Object;>Ljava/util/concurrent/atomic/AtomicLong;Lio/reactivex/FlowableSubscriber<TT;>;Lorg/reactivestreams/Subscription;Lio/reactivex/internal/operators/flowable/FlowableTimeoutTimed$TimeoutSupport;
SourceFile: "FlowableTimeoutTimed.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableTimeoutTimed
InnerClasses:
  public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
  final TimeoutSubscriber = io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSubscriber of io.reactivex.internal.operators.flowable.FlowableTimeoutTimed
  abstract TimeoutSupport = io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutSupport of io.reactivex.internal.operators.flowable.FlowableTimeoutTimed
  final TimeoutTask = io.reactivex.internal.operators.flowable.FlowableTimeoutTimed$TimeoutTask of io.reactivex.internal.operators.flowable.FlowableTimeoutTimed