final class io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber<T> extends io.reactivex.internal.subscribers.QueueDrainSubscriber<T, java.lang.Object, io.reactivex.Flowable<T>> implements org.reactivestreams.Subscription, java.lang.Runnable
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber
  super_class: io.reactivex.internal.subscribers.QueueDrainSubscriber
{
  final long timespan;
    descriptor: J
    flags: (0x0010) ACC_FINAL

  final long timeskip;
    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 int bufferSize;
    descriptor: I
    flags: (0x0010) ACC_FINAL

  final java.util.List<io.reactivex.processors.UnicastProcessor<T>> windows;
    descriptor: Ljava/util/List;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/List<Lio/reactivex/processors/UnicastProcessor<TT;>;>;

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

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

  void <init>(org.reactivestreams.Subscriber<? super io.reactivex.Flowable<T>>, long, long, java.util.concurrent.TimeUnit, io.reactivex.Scheduler$Worker, );
    descriptor: (Lorg/reactivestreams/Subscriber;JJLjava/util/concurrent/TimeUnit;Lio/reactivex/Scheduler$Worker;I)V
    flags: (0x0000) 
    Code:
      stack=4, locals=9, args_size=7
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // org.reactivestreams.Subscriber actual
        start local 2 // long timespan
        start local 4 // long timeskip
        start local 6 // java.util.concurrent.TimeUnit unit
        start local 7 // io.reactivex.Scheduler$Worker worker
        start local 8 // int bufferSize
         0: .line 615
            aload 0 /* this */
            aload 1 /* actual */
            new io.reactivex.internal.queue.MpscLinkedQueue
            dup
            invokespecial io.reactivex.internal.queue.MpscLinkedQueue.<init>:()V
            invokespecial io.reactivex.internal.subscribers.QueueDrainSubscriber.<init>:(Lorg/reactivestreams/Subscriber;Lio/reactivex/internal/fuseable/SimplePlainQueue;)V
         1: .line 616
            aload 0 /* this */
            lload 2 /* timespan */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timespan:J
         2: .line 617
            aload 0 /* this */
            lload 4 /* timeskip */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timeskip:J
         3: .line 618
            aload 0 /* this */
            aload 6 /* unit */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.unit:Ljava/util/concurrent/TimeUnit;
         4: .line 619
            aload 0 /* this */
            aload 7 /* worker */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.worker:Lio/reactivex/Scheduler$Worker;
         5: .line 620
            aload 0 /* this */
            iload 8 /* bufferSize */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.bufferSize:I
         6: .line 621
            aload 0 /* this */
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.windows:Ljava/util/List;
         7: .line 622
            return
        end local 8 // int bufferSize
        end local 7 // io.reactivex.Scheduler$Worker worker
        end local 6 // java.util.concurrent.TimeUnit unit
        end local 4 // long timeskip
        end local 2 // long timespan
        end local 1 // org.reactivestreams.Subscriber actual
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    8     0        this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0    8     1      actual  Lorg/reactivestreams/Subscriber<-Lio/reactivex/Flowable<TT;>;>;
            0    8     2    timespan  J
            0    8     4    timeskip  J
            0    8     6        unit  Ljava/util/concurrent/TimeUnit;
            0    8     7      worker  Lio/reactivex/Scheduler$Worker;
            0    8     8  bufferSize  I
    Signature: (Lorg/reactivestreams/Subscriber<-Lio/reactivex/Flowable<TT;>;>;JJLjava/util/concurrent/TimeUnit;Lio/reactivex/Scheduler$Worker;I)V
    MethodParameters:
            Name  Flags
      actual      
      timespan    
      timeskip    
      unit        
      worker      
      bufferSize  

  public void onSubscribe(org.reactivestreams.Subscription);
    descriptor: (Lorg/reactivestreams/Subscription;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=5, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // org.reactivestreams.Subscription s
         0: .line 626
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.upstream:Lorg/reactivestreams/Subscription;
            aload 1 /* s */
            invokestatic io.reactivex.internal.subscriptions.SubscriptionHelper.validate:(Lorg/reactivestreams/Subscription;Lorg/reactivestreams/Subscription;)Z
            ifeq 18
         1: .line 628
            aload 0 /* this */
            aload 1 /* s */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.upstream:Lorg/reactivestreams/Subscription;
         2: .line 630
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 0 /* this */
            invokeinterface org.reactivestreams.Subscriber.onSubscribe:(Lorg/reactivestreams/Subscription;)V
         3: .line 632
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.cancelled:Z
            ifeq 5
         4: .line 633
            return
         5: .line 636
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.requested:()J
            lstore 2 /* r */
        start local 2 // long r
         6: .line 637
            lload 2 /* r */
            lconst_0
            lcmp
            ifeq 16
         7: .line 638
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.bufferSize:I
            invokestatic io.reactivex.processors.UnicastProcessor.create:(I)Lio/reactivex/processors/UnicastProcessor;
            astore 4 /* w */
        start local 4 // io.reactivex.processors.UnicastProcessor w
         8: .line 639
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.windows:Ljava/util/List;
            aload 4 /* w */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         9: .line 641
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 4 /* w */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        10: .line 642
            lload 2 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 12
        11: .line 643
            aload 0 /* this */
            lconst_1
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.produced:(J)J
            pop2
        12: .line 645
      StackMap locals: long io.reactivex.processors.UnicastProcessor
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            new io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$Completion
            dup
            aload 0 /* this */
            aload 4 /* w */
            invokespecial io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$Completion.<init>:(Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber;Lio/reactivex/processors/UnicastProcessor;)V
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timespan:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.unit:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
            pop
        13: .line 647
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            aload 0 /* this */
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timeskip:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timeskip:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.unit:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.Scheduler$Worker.schedulePeriodically:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
            pop
        14: .line 649
            aload 1 /* s */
            ldc 9223372036854775807
            invokeinterface org.reactivestreams.Subscription.request:(J)V
        end local 4 // io.reactivex.processors.UnicastProcessor w
        15: .line 651
            goto 18
        16: .line 652
      StackMap locals:
      StackMap stack:
            aload 1 /* s */
            invokeinterface org.reactivestreams.Subscription.cancel:()V
        17: .line 653
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            new io.reactivex.exceptions.MissingBackpressureException
            dup
            ldc "Could not emit the first window due to lack of requests"
            invokespecial io.reactivex.exceptions.MissingBackpressureException.<init>:(Ljava/lang/String;)V
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        end local 2 // long r
        18: .line 656
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.reactivestreams.Subscription s
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   19     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0   19     1     s  Lorg/reactivestreams/Subscription;
            6   18     2     r  J
            8   15     4     w  Lio/reactivex/processors/UnicastProcessor<TT;>;
    MethodParameters:
      Name  Flags
      s     

  public void onNext();
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // java.lang.Object t
         0: .line 660
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.fastEnter:()Z
            ifeq 7
         1: .line 661
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.windows:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber java.lang.Object top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 2 /* w */
        start local 2 // io.reactivex.processors.UnicastProcessor w
         3: .line 662
            aload 2 /* w */
            aload 1 /* t */
            invokevirtual io.reactivex.processors.UnicastProcessor.onNext:(Ljava/lang/Object;)V
        end local 2 // io.reactivex.processors.UnicastProcessor w
         4: .line 661
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 664
            aload 0 /* this */
            iconst_m1
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.leave:(I)I
            ifne 10
         6: .line 665
            return
         7: .line 668
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber java.lang.Object
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
            aload 1 /* t */
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.offer:(Ljava/lang/Object;)Z
            pop
         8: .line 669
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.enter:()Z
            ifne 10
         9: .line 670
            return
        10: .line 673
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.drainLoop:()V
        11: .line 674
            return
        end local 1 // java.lang.Object t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   12     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0   12     1     t  TT;
            3    4     2     w  Lio/reactivex/processors/UnicastProcessor<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.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // java.lang.Throwable t
         0: .line 678
            aload 0 /* this */
            aload 1 /* t */
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.error:Ljava/lang/Throwable;
         1: .line 679
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.done:Z
         2: .line 680
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.enter:()Z
            ifeq 4
         3: .line 681
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.drainLoop:()V
         4: .line 684
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            aload 1 /* t */
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
         5: .line 685
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.dispose:()V
         6: .line 686
            return
        end local 1 // java.lang.Throwable t
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0    7     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.FlowableWindowTimed$WindowSkipSubscriber this
         0: .line 690
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.done:Z
         1: .line 691
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.enter:()Z
            ifeq 3
         2: .line 692
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.drainLoop:()V
         3: .line 695
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            invokeinterface org.reactivestreams.Subscriber.onComplete:()V
         4: .line 696
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.dispose:()V
         5: .line 697
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<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.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // long n
         0: .line 701
            aload 0 /* this */
            lload 1 /* n */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.requested:(J)V
         1: .line 702
            return
        end local 1 // long n
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0    2     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.FlowableWindowTimed$WindowSkipSubscriber this
         0: .line 706
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.cancelled:Z
         1: .line 707
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;

  public void dispose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
         0: .line 710
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            invokevirtual io.reactivex.Scheduler$Worker.dispose:()V
         1: .line 711
            return
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;

  void complete(io.reactivex.processors.UnicastProcessor<T>);
    descriptor: (Lio/reactivex/processors/UnicastProcessor;)V
    flags: (0x0000) 
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
        start local 1 // io.reactivex.processors.UnicastProcessor w
         0: .line 714
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
            new io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
            dup
            aload 1 /* w */
            iconst_0
            invokespecial io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork.<init>:(Lio/reactivex/processors/UnicastProcessor;Z)V
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.offer:(Ljava/lang/Object;)Z
            pop
         1: .line 715
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.enter:()Z
            ifeq 3
         2: .line 716
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.drainLoop:()V
         3: .line 718
      StackMap locals:
      StackMap stack:
            return
        end local 1 // io.reactivex.processors.UnicastProcessor w
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            0    4     1     w  Lio/reactivex/processors/UnicastProcessor<TT;>;
    Signature: (Lio/reactivex/processors/UnicastProcessor<TT;>;)V
    MethodParameters:
      Name  Flags
      w     

  void drainLoop();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=5, locals=13, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
         0: .line 722
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
            astore 1 /* q */
        start local 1 // io.reactivex.internal.fuseable.SimplePlainQueue q
         1: .line 723
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.downstream:Lorg/reactivestreams/Subscriber;
            astore 2 /* a */
        start local 2 // org.reactivestreams.Subscriber a
         2: .line 724
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.windows:Ljava/util/List;
            astore 3 /* ws */
        start local 3 // java.util.List ws
         3: .line 726
            iconst_1
            istore 4 /* missed */
        start local 4 // int missed
         4: .line 731
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.terminated:Z
            ifeq 10
         5: .line 732
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.upstream:Lorg/reactivestreams/Subscription;
            invokeinterface org.reactivestreams.Subscription.cancel:()V
         6: .line 733
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.dispose:()V
         7: .line 734
            aload 1 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.clear:()V
         8: .line 735
            aload 3 /* ws */
            invokeinterface java.util.List.clear:()V
         9: .line 736
            return
        10: .line 739
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.done:Z
            istore 5 /* d */
        start local 5 // boolean d
        11: .line 741
            aload 1 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.poll:()Ljava/lang/Object;
            astore 6 /* v */
        start local 6 // java.lang.Object v
        12: .line 743
            aload 6 /* v */
            ifnonnull 13
            iconst_1
            goto 14
      StackMap locals: int java.lang.Object
      StackMap stack:
        13: iconst_0
      StackMap locals:
      StackMap stack: int
        14: istore 7 /* empty */
        start local 7 // boolean empty
        15: .line 744
            aload 6 /* v */
            instanceof io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
            istore 8 /* sw */
        start local 8 // boolean sw
        16: .line 746
            iload 5 /* d */
            ifeq 32
            iload 7 /* empty */
            ifne 17
            iload 8 /* sw */
            ifeq 32
        17: .line 747
      StackMap locals: int int
      StackMap stack:
            aload 1 /* q */
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.clear:()V
        18: .line 748
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.error:Ljava/lang/Throwable;
            astore 9 /* e */
        start local 9 // java.lang.Throwable e
        19: .line 749
            aload 9 /* e */
            ifnull 25
        20: .line 750
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 11
            goto 23
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int int java.lang.Throwable top java.util.Iterator
      StackMap stack:
        21: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 10 /* w */
        start local 10 // io.reactivex.processors.UnicastProcessor w
        22: .line 751
            aload 10 /* w */
            aload 9 /* e */
            invokevirtual io.reactivex.processors.UnicastProcessor.onError:(Ljava/lang/Throwable;)V
        end local 10 // io.reactivex.processors.UnicastProcessor w
        23: .line 750
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 21
        24: .line 753
            goto 29
        25: .line 754
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int int java.lang.Throwable
      StackMap stack:
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 11
            goto 28
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int int java.lang.Throwable top java.util.Iterator
      StackMap stack:
        26: aload 11
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 10 /* w */
        start local 10 // io.reactivex.processors.UnicastProcessor w
        27: .line 755
            aload 10 /* w */
            invokevirtual io.reactivex.processors.UnicastProcessor.onComplete:()V
        end local 10 // io.reactivex.processors.UnicastProcessor w
        28: .line 754
      StackMap locals:
      StackMap stack:
            aload 11
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 26
        29: .line 758
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int int java.lang.Throwable
      StackMap stack:
            aload 3 /* ws */
            invokeinterface java.util.List.clear:()V
        30: .line 759
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.dispose:()V
        31: .line 760
            return
        end local 9 // java.lang.Throwable e
        32: .line 763
      StackMap locals:
      StackMap stack:
            iload 7 /* empty */
            ifeq 34
        33: .line 764
            goto 60
        34: .line 767
      StackMap locals:
      StackMap stack:
            iload 8 /* sw */
            ifeq 55
        35: .line 768
            aload 6 /* v */
            checkcast io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
            astore 9 /* work */
        start local 9 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork work
        36: .line 770
            aload 9 /* work */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork.open:Z
            ifeq 50
        37: .line 771
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.cancelled:Z
            ifeq 39
        38: .line 772
            goto 4
        39: .line 775
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.requested:()J
            lstore 10 /* r */
        start local 10 // long r
        40: .line 776
            lload 10 /* r */
            lconst_0
            lcmp
            ifeq 48
        41: .line 777
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.bufferSize:I
            invokestatic io.reactivex.processors.UnicastProcessor.create:(I)Lio/reactivex/processors/UnicastProcessor;
            astore 12 /* w */
        start local 12 // io.reactivex.processors.UnicastProcessor w
        42: .line 778
            aload 3 /* ws */
            aload 12 /* w */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        43: .line 779
            aload 2 /* a */
            aload 12 /* w */
            invokeinterface org.reactivestreams.Subscriber.onNext:(Ljava/lang/Object;)V
        44: .line 780
            lload 10 /* r */
            ldc 9223372036854775807
            lcmp
            ifeq 46
        45: .line 781
            aload 0 /* this */
            lconst_1
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.produced:(J)J
            pop2
        46: .line 784
      StackMap locals: long io.reactivex.processors.UnicastProcessor
      StackMap stack:
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.worker:Lio/reactivex/Scheduler$Worker;
            new io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$Completion
            dup
            aload 0 /* this */
            aload 12 /* w */
            invokespecial io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$Completion.<init>:(Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber;Lio/reactivex/processors/UnicastProcessor;)V
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.timespan:J
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.unit:Ljava/util/concurrent/TimeUnit;
            invokevirtual io.reactivex.Scheduler$Worker.schedule:(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
            pop
        end local 12 // io.reactivex.processors.UnicastProcessor w
        47: .line 785
            goto 4
        48: .line 786
      StackMap locals:
      StackMap stack:
            aload 2 /* a */
            new io.reactivex.exceptions.MissingBackpressureException
            dup
            ldc "Can't emit window due to lack of requests"
            invokespecial io.reactivex.exceptions.MissingBackpressureException.<init>:(Ljava/lang/String;)V
            invokeinterface org.reactivestreams.Subscriber.onError:(Ljava/lang/Throwable;)V
        end local 10 // long r
        49: .line 788
            goto 4
        50: .line 789
      StackMap locals:
      StackMap stack:
            aload 3 /* ws */
            aload 9 /* work */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork.w:Lio/reactivex/processors/UnicastProcessor;
            invokeinterface java.util.List.remove:(Ljava/lang/Object;)Z
            pop
        51: .line 790
            aload 9 /* work */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork.w:Lio/reactivex/processors/UnicastProcessor;
            invokevirtual io.reactivex.processors.UnicastProcessor.onComplete:()V
        52: .line 791
            aload 3 /* ws */
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 4
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.cancelled:Z
            ifeq 4
        53: .line 792
            aload 0 /* this */
            iconst_1
            putfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.terminated:Z
        end local 9 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork work
        54: .line 795
            goto 4
        55: .line 796
      StackMap locals:
      StackMap stack:
            aload 3 /* ws */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 10
            goto 58
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int int java.lang.Object int int top java.util.Iterator
      StackMap stack:
        56: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast io.reactivex.processors.UnicastProcessor
            astore 9 /* w */
        start local 9 // io.reactivex.processors.UnicastProcessor w
        57: .line 797
            aload 9 /* w */
            aload 6 /* v */
            invokevirtual io.reactivex.processors.UnicastProcessor.onNext:(Ljava/lang/Object;)V
        end local 9 // io.reactivex.processors.UnicastProcessor w
        58: .line 796
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 56
        end local 8 // boolean sw
        end local 7 // boolean empty
        end local 6 // java.lang.Object v
        end local 5 // boolean d
        59: .line 730
            goto 4
        60: .line 802
      StackMap locals: io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber io.reactivex.internal.fuseable.SimplePlainQueue org.reactivestreams.Subscriber java.util.List int
      StackMap stack:
            aload 0 /* this */
            iload 4 /* missed */
            ineg
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.leave:(I)I
            istore 4 /* missed */
        61: .line 803
            iload 4 /* missed */
            ifne 4
        62: .line 807
            return
        end local 4 // int missed
        end local 3 // java.util.List ws
        end local 2 // org.reactivestreams.Subscriber a
        end local 1 // io.reactivex.internal.fuseable.SimplePlainQueue q
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0   63     0    this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            1   63     1       q  Lio/reactivex/internal/fuseable/SimplePlainQueue<Ljava/lang/Object;>;
            2   63     2       a  Lorg/reactivestreams/Subscriber<-Lio/reactivex/Flowable<TT;>;>;
            3   63     3      ws  Ljava/util/List<Lio/reactivex/processors/UnicastProcessor<TT;>;>;
            4   63     4  missed  I
           11   59     5       d  Z
           12   59     6       v  Ljava/lang/Object;
           15   59     7   empty  Z
           16   59     8      sw  Z
           19   32     9       e  Ljava/lang/Throwable;
           22   23    10       w  Lio/reactivex/processors/UnicastProcessor<TT;>;
           27   28    10       w  Lio/reactivex/processors/UnicastProcessor<TT;>;
           36   54     9    work  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber$SubjectWork<TT;>;
           40   49    10       r  J
           42   47    12       w  Lio/reactivex/processors/UnicastProcessor<TT;>;
           57   58     9       w  Lio/reactivex/processors/UnicastProcessor<TT;>;

  public void run();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=1
        start local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
         0: .line 812
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.bufferSize:I
            invokestatic io.reactivex.processors.UnicastProcessor.create:(I)Lio/reactivex/processors/UnicastProcessor;
            astore 1 /* w */
        start local 1 // io.reactivex.processors.UnicastProcessor w
         1: .line 814
            new io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
            dup
            aload 1 /* w */
            iconst_1
            invokespecial io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork.<init>:(Lio/reactivex/processors/UnicastProcessor;Z)V
            astore 2 /* sw */
        start local 2 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork sw
         2: .line 815
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.cancelled:Z
            ifne 4
         3: .line 816
            aload 0 /* this */
            getfield io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.queue:Lio/reactivex/internal/fuseable/SimplePlainQueue;
            aload 2 /* sw */
            invokeinterface io.reactivex.internal.fuseable.SimplePlainQueue.offer:(Ljava/lang/Object;)Z
            pop
         4: .line 818
      StackMap locals: io.reactivex.processors.UnicastProcessor io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork
      StackMap stack:
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.enter:()Z
            ifeq 6
         5: .line 819
            aload 0 /* this */
            invokevirtual io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber.drainLoop:()V
         6: .line 821
      StackMap locals:
      StackMap stack:
            return
        end local 2 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork sw
        end local 1 // io.reactivex.processors.UnicastProcessor w
        end local 0 // io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    7     0  this  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber<TT;>;
            1    7     1     w  Lio/reactivex/processors/UnicastProcessor<TT;>;
            2    7     2    sw  Lio/reactivex/internal/operators/flowable/FlowableWindowTimed$WindowSkipSubscriber$SubjectWork<TT;>;
}
Signature: <T:Ljava/lang/Object;>Lio/reactivex/internal/subscribers/QueueDrainSubscriber<TT;Ljava/lang/Object;Lio/reactivex/Flowable<TT;>;>;Lorg/reactivestreams/Subscription;Ljava/lang/Runnable;
SourceFile: "FlowableWindowTimed.java"
NestHost: io.reactivex.internal.operators.flowable.FlowableWindowTimed
InnerClasses:
  public abstract Worker = io.reactivex.Scheduler$Worker of io.reactivex.Scheduler
  final WindowSkipSubscriber = io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber of io.reactivex.internal.operators.flowable.FlowableWindowTimed
  final Completion = io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$Completion of io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber
  final SubjectWork = io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber$SubjectWork of io.reactivex.internal.operators.flowable.FlowableWindowTimed$WindowSkipSubscriber