TrampolineScheduler$TrampolineWorker.smali
.class final Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;
.super Lio/reactivex/Scheduler$Worker;
.source "TrampolineScheduler.java"
# interfaces
.implements Lio/reactivex/disposables/Disposable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lio/reactivex/internal/schedulers/TrampolineScheduler;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x18
name = "TrampolineWorker"
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker$AppendToQueueTask;
}
.end annotation
# instance fields
.field final counter:Ljava/util/concurrent/atomic/AtomicInteger;
.field volatile disposed:Z
.field final queue:Ljava/util/concurrent/PriorityBlockingQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/PriorityBlockingQueue<",
"Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;",
">;"
}
.end annotation
.end field
.field private final wip:Ljava/util/concurrent/atomic/AtomicInteger;
# direct methods
.method static constructor <clinit>()V
.registers 1
return-void
.end method
.method constructor <init>()V
.registers 2
.line 69
invoke-direct {p0}, Lio/reactivex/Scheduler$Worker;-><init>()V
.line 70
new-instance v0, Ljava/util/concurrent/PriorityBlockingQueue;
invoke-direct {v0}, Ljava/util/concurrent/PriorityBlockingQueue;-><init>()V
iput-object v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->queue:Ljava/util/concurrent/PriorityBlockingQueue;
.line 72
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V
iput-object v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->wip:Ljava/util/concurrent/atomic/AtomicInteger;
.line 74
new-instance v0, Ljava/util/concurrent/atomic/AtomicInteger;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicInteger;-><init>()V
iput-object v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->counter:Ljava/util/concurrent/atomic/AtomicInteger;
return-void
.end method
# virtual methods
.method public dispose()V
.registers 2
.line 130
const/4 v0, 0x1
iput-boolean v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->disposed:Z
.line 131
return-void
.end method
.method enqueue(Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
.registers 8
.param p1, "action" # Ljava/lang/Runnable;
.param p2, "execTime" # J
.line 93
iget-boolean v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->disposed:Z
if-eqz v0, :cond_7
.line 94
sget-object v0, Lio/reactivex/internal/disposables/EmptyDisposable;->INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
return-object v0
.line 96
:cond_7
new-instance v0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
iget-object v2, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->counter:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicInteger;->incrementAndGet()I
move-result v2
invoke-direct {v0, p1, v1, v2}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;-><init>(Ljava/lang/Runnable;Ljava/lang/Long;I)V
.line 97
.local v0, "timedRunnable":Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
iget-object v1, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->queue:Ljava/util/concurrent/PriorityBlockingQueue;
invoke-virtual {v1, v0}, Ljava/util/concurrent/PriorityBlockingQueue;->add(Ljava/lang/Object;)Z
.line 99
iget-object v1, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->wip:Ljava/util/concurrent/atomic/AtomicInteger;
invoke-virtual {v1}, Ljava/util/concurrent/atomic/AtomicInteger;->getAndIncrement()I
move-result v1
if-nez v1, :cond_52
.line 100
const/4 v1, 0x1
.line 103
.local v1, "missed":I
:cond_24
:goto_24
iget-boolean v2, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->disposed:Z
if-eqz v2, :cond_30
.line 104
iget-object v2, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->queue:Ljava/util/concurrent/PriorityBlockingQueue;
invoke-virtual {v2}, Ljava/util/concurrent/PriorityBlockingQueue;->clear()V
.line 105
sget-object v2, Lio/reactivex/internal/disposables/EmptyDisposable;->INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
return-object v2
.line 107
:cond_30
iget-object v2, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->queue:Ljava/util/concurrent/PriorityBlockingQueue;
invoke-virtual {v2}, Ljava/util/concurrent/PriorityBlockingQueue;->poll()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
.line 108
.local v2, "polled":Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
if-nez v2, :cond_48
.line 109
nop
.line 115
.end local v2 # "polled":Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
iget-object v2, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->wip:Ljava/util/concurrent/atomic/AtomicInteger;
neg-int v3, v1
invoke-virtual {v2, v3}, Ljava/util/concurrent/atomic/AtomicInteger;->addAndGet(I)I
move-result v1
.line 116
if-nez v1, :cond_24
.line 117
nop
.line 121
sget-object v2, Lio/reactivex/internal/disposables/EmptyDisposable;->INSTANCE:Lio/reactivex/internal/disposables/EmptyDisposable;
return-object v2
.line 111
.restart local v2 # "polled":Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
:cond_48
iget-boolean v3, v2, Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;->disposed:Z
if-nez v3, :cond_51
.line 112
iget-object v3, v2, Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;->run:Ljava/lang/Runnable;
invoke-interface {v3}, Ljava/lang/Runnable;->run()V
.line 114
.end local v2 # "polled":Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;
:cond_51
goto :goto_24
.line 124
.end local v1 # "missed":I
:cond_52
new-instance v1, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker$AppendToQueueTask;
invoke-direct {v1, p0, v0}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker$AppendToQueueTask;-><init>(Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;Lio/reactivex/internal/schedulers/TrampolineScheduler$TimedRunnable;)V
invoke-static {v1}, Lio/reactivex/disposables/Disposables;->fromRunnable(Ljava/lang/Runnable;)Lio/reactivex/disposables/Disposable;
move-result-object v1
return-object v1
.end method
.method public isDisposed()Z
.registers 2
.line 135
iget-boolean v0, p0, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->disposed:Z
return v0
.end method
.method public schedule(Ljava/lang/Runnable;)Lio/reactivex/disposables/Disposable;
.registers 4
.param p1, "action" # Ljava/lang/Runnable;
.line 81
sget-object v0, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {p0, v0}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->now(Ljava/util/concurrent/TimeUnit;)J
move-result-wide v0
invoke-virtual {p0, p1, v0, v1}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->enqueue(Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
move-result-object v0
return-object v0
.end method
.method public schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Lio/reactivex/disposables/Disposable;
.registers 9
.param p1, "action" # Ljava/lang/Runnable;
.param p2, "delayTime" # J
.param p4, "unit" # Ljava/util/concurrent/TimeUnit;
.line 87
sget-object v0, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {p0, v0}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->now(Ljava/util/concurrent/TimeUnit;)J
move-result-wide v0
invoke-virtual {p4, p2, p3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
move-result-wide v2
add-long/2addr v0, v2
.line 89
.local v0, "execTime":J
new-instance v2, Lio/reactivex/internal/schedulers/TrampolineScheduler$SleepingRunnable;
invoke-direct {v2, p1, p0, v0, v1}, Lio/reactivex/internal/schedulers/TrampolineScheduler$SleepingRunnable;-><init>(Ljava/lang/Runnable;Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;J)V
invoke-virtual {p0, v2, v0, v1}, Lio/reactivex/internal/schedulers/TrampolineScheduler$TrampolineWorker;->enqueue(Ljava/lang/Runnable;J)Lio/reactivex/disposables/Disposable;
move-result-object v2
return-object v2
.end method