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

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

  final int count;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  org.reactivestreams.Subscription upstream;
    descriptor: Lorg/reactivestreams/Subscription;
    flags: (0x0000) 

  volatile boolean done;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

  volatile boolean cancelled;
    descriptor: Z
    flags: (0x0040) ACC_VOLATILE

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

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

  void <init>(org.reactivestreams.Subscriber<? super T>, );
    descriptor: (Lorg/reactivestreams/Subscriber;I)V
    flags: (0x0000) 
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // int count
         0: .line 52
            aload 0 /* this */
            invokespecial java.util.ArrayDeque.<init>:()V
         1: .line 48
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicLong
            dup
            invokespecial java.util.concurrent.atomic.AtomicLong.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
         2: .line 50
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicInteger
            dup
            invokespecial java.util.concurrent.atomic.AtomicInteger.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.wip:Ljava/util/concurrent/atomic/AtomicInteger;
         3: .line 53
            aload 0 /* this */
            aload 1 /* actual */
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.downstream:Lorg/reactivestreams/Subscriber;
         4: .line 54
            aload 0 /* this */
            iload 2 /* count */
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.count:I
         5: .line 55
            return
        end local 2 // int count
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;
            0    6     1  actual  Lorg/reactivestreams/Subscriber<-TT;>;
            0    6     2   count  I
    Signature: (Lorg/reactivestreams/Subscriber<-TT;>;I)V
    MethodParameters:
        Name  Flags
      actual  
      count   

  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.FlowableTakeLast$TakeLastSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 59
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.upstream:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 4
         1: .line 60
            aload 0 /* this */
            aload 1 /* s */
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.upstream:Lorg/reactivestreams/Subscription;
         2: .line 61
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         3: .line 62
            aload 1 /* s */
            ldc 9223372036854775807
            invokeinterface org.reactivestreams.Subscription.request:(J)V
         4: .line 64
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;
            0    5     1     s  Lorg/reactivestreams/Subscription;
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
        start local 1 // java.lang.Object t
         0: .line 68
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.count:I
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.size:()I
            if_icmpne 2
         1: .line 69
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.poll:()Ljava/lang/Object;
            pop
         2: .line 71
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* t */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.offer:(Ljava/lang/Object;)Z
            pop
         3: .line 72
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<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=2, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 76
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         1: .line 77
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;
            0    2     1     t  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      t     

  public void onComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
         0: .line 81
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.done:Z
         1: .line 82
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.drain:()V
         2: .line 83
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;

  public void request(long);
    descriptor: (J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
        start local 1 // long n
         0: .line 87
            lload 1 /* n */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(J)Z
            ifeq 3
         1: .line 88
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 1 /* n */
            invokestatic io.reactivex.internal.util.BackpressureHelper.add:(Ljava/util/concurrent/atomic/AtomicLong;J)J
            pop2
         2: .line 89
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.drain:()V
         3: .line 91
      StackMap locals:
      StackMap stack:
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;
            0    4     1     n  J
    MethodParameters:
      Name  Flags
      n     

  public void cancel();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
         0: .line 95
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.cancelled:Z
         1: .line 96
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         2: .line 97
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;

  void drain();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=4, locals=7, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
         0: .line 100
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.wip:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.getAndIncrement:()I
            ifne 20
         1: .line 101
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            astore 1 /* a */
        start local 1 // org.reactivestreams.Subscriber a
         2: .line 102
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            invokevirtual java.util.concurrent.atomic.AtomicLong.get:()J
            lstore 2 /* r */
        start local 2 // long r
         3: .line 104
      StackMap locals: org.reactivestreams.Subscriber long
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.cancelled:Z
            ifeq 5
         4: .line 105
            return
         5: .line 107
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.done:Z
            ifeq 19
         6: .line 108
            lconst_0
            lstore 4 /* e */
        start local 4 // long e
         7: .line 110
            goto 16
         8: .line 111
      StackMap locals: long
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.cancelled:Z
            ifeq 10
         9: .line 112
            return
        10: .line 114
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.poll:()Ljava/lang/Object;
            astore 6 /* v */
        start local 6 // java.lang.Object v
        11: .line 115
            aload 6 /* v */
            ifnonnull 14
        12: .line 116
            aload 1 /* a */
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
        13: .line 117
            return
        14: .line 119
      StackMap locals: java.lang.Object
      StackMap stack:
            aload 1 /* a */
            aload 6 /* v */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        15: .line 120
            lload 4 /* e */
            lconst_1
            ladd
            lstore 4 /* e */
        end local 6 // java.lang.Object v
        16: .line 110
      StackMap locals:
      StackMap stack:
            lload 4 /* e */
            lload 2 /* r */
            lcmp
            ifne 8
        17: .line 122
            lload 4 /* e */
            lconst_0
            lcmp
            ifeq 19
            lload 2 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 19
        18: .line 123
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.requested:Ljava/util/concurrent/atomic/AtomicLong;
            lload 4 /* e */
            lneg
            invokevirtual java.util.concurrent.atomic.AtomicLong.addAndGet:(J)J
            lstore 2 /* r */
        end local 4 // long e
        19: .line 126
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber.wip:Ljava/util/concurrent/atomic/AtomicInteger;
            invokevirtual java.util.concurrent.atomic.AtomicInteger.decrementAndGet:()I
            ifne 3
        end local 2 // long r
        end local 1 // org.reactivestreams.Subscriber a
        20: .line 128
      StackMap locals:
      StackMap stack:
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   21     0  this  Lio/reactivex/internal/operators/flowable/FlowableTakeLast$TakeLastSubscriber<TT;>;
            2   20     1     a  Lorg/reactivestreams/Subscriber<-TT;>;
            3   20     2     r  J
            7   19     4     e  J
           11   16     6     v  TT;
}
Signature: <T:Ljava/lang/Object;>Ljava/util/ArrayDeque<TT;>;Lio/reactivex/FlowableSubscriber<TT;>;Lorg/reactivestreams/Subscription;
SourceFile: "FlowableTakeLast.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableTakeLast
InnerClasses:
  final TakeLastSubscriber = io.reactivex.internal.operators.flowable.FlowableTakeLast$TakeLastSubscriber of io.reactivex.internal.operators.flowable.FlowableTakeLast