TaskQueue.smali
.class public final Lokhttp3/internal/concurrent/TaskQueue;
.super Ljava/lang/Object;
# instance fields
.field private a:Z
.field private b:Lokhttp3/internal/concurrent/Task;
.field private final c:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lokhttp3/internal/concurrent/Task;",
">;"
}
.end annotation
.end field
.field private d:Z
.field private final e:Lokhttp3/internal/concurrent/TaskRunner;
.field private final f:Ljava/lang/String;
# direct methods
.method public constructor <init>(Lokhttp3/internal/concurrent/TaskRunner;Ljava/lang/String;)V
.registers 4
const-string v0, "taskRunner"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->c(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "name"
invoke-static {p2, v0}, Lkotlin/jvm/internal/Intrinsics;->c(Ljava/lang/Object;Ljava/lang/String;)V
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
iput-object p2, p0, Lokhttp3/internal/concurrent/TaskQueue;->f:Ljava/lang/String;
new-instance p1, Ljava/util/ArrayList;
invoke-direct {p1}, Ljava/util/ArrayList;-><init>()V
iput-object p1, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
return-void
.end method
.method public static synthetic j(Lokhttp3/internal/concurrent/TaskQueue;Lokhttp3/internal/concurrent/Task;JILjava/lang/Object;)V
.registers 6
and-int/lit8 p4, p4, 0x2
if-eqz p4, :cond_6
const-wide/16 p2, 0x0
:cond_6
invoke-virtual {p0, p1, p2, p3}, Lokhttp3/internal/concurrent/TaskQueue;->i(Lokhttp3/internal/concurrent/Task;J)V
return-void
.end method
# virtual methods
.method public final a()V
.registers 5
sget-boolean v0, Lokhttp3/internal/Util;->g:Z
if-eqz v0, :cond_37
invoke-static {p0}, Ljava/lang/Thread;->holdsLock(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_b
goto :goto_37
:cond_b
new-instance v0, Ljava/lang/AssertionError;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Thread "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
const-string v3, "Thread.currentThread()"
invoke-static {v2, v3}, Lkotlin/jvm/internal/Intrinsics;->b(Ljava/lang/Object;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " MUST NOT hold lock on "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw v0
:cond_37
:goto_37
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
monitor-enter v0
:try_start_3a
invoke-virtual {p0}, Lokhttp3/internal/concurrent/TaskQueue;->b()Z
move-result v1
if-eqz v1, :cond_45
iget-object v1, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
invoke-virtual {v1, p0}, Lokhttp3/internal/concurrent/TaskRunner;->h(Lokhttp3/internal/concurrent/TaskQueue;)V
:cond_45
sget-object v1, Lkotlin/Unit;->a:Lkotlin/Unit;
:try_end_47
.catchall {:try_start_3a .. :try_end_47} :catchall_49
monitor-exit v0
return-void
:catchall_49
move-exception v1
monitor-exit v0
throw v1
.end method
.method public final b()Z
.registers 6
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->b:Lokhttp3/internal/concurrent/Task;
const/4 v1, 0x1
if-eqz v0, :cond_15
if-eqz v0, :cond_10
invoke-virtual {v0}, Lokhttp3/internal/concurrent/Task;->a()Z
move-result v0
if-eqz v0, :cond_15
iput-boolean v1, p0, Lokhttp3/internal/concurrent/TaskQueue;->d:Z
goto :goto_15
:cond_10
invoke-static {}, Lkotlin/jvm/internal/Intrinsics;->h()V
const/4 v0, 0x0
throw v0
:cond_15
:goto_15
const/4 v0, 0x0
iget-object v2, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v2}, Ljava/util/List;->size()I
move-result v2
sub-int/2addr v2, v1
:goto_1d
if-ltz v2, :cond_51
iget-object v3, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v3, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Lokhttp3/internal/concurrent/Task;
invoke-virtual {v3}, Lokhttp3/internal/concurrent/Task;->a()Z
move-result v3
if-eqz v3, :cond_4e
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v0, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lokhttp3/internal/concurrent/Task;
sget-object v3, Lokhttp3/internal/concurrent/TaskRunner;->j:Lokhttp3/internal/concurrent/TaskRunner$Companion;
invoke-virtual {v3}, Lokhttp3/internal/concurrent/TaskRunner$Companion;->a()Ljava/util/logging/Logger;
move-result-object v3
sget-object v4, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {v3, v4}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result v3
if-eqz v3, :cond_48
const-string v3, "canceled"
invoke-static {v0, p0, v3}, Lokhttp3/internal/concurrent/TaskLoggerKt;->a(Lokhttp3/internal/concurrent/Task;Lokhttp3/internal/concurrent/TaskQueue;Ljava/lang/String;)V
:cond_48
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v0, v2}, Ljava/util/List;->remove(I)Ljava/lang/Object;
const/4 v0, 0x1
:cond_4e
add-int/lit8 v2, v2, -0x1
goto :goto_1d
:cond_51
return v0
.end method
.method public final c()Lokhttp3/internal/concurrent/Task;
.registers 2
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->b:Lokhttp3/internal/concurrent/Task;
return-object v0
.end method
.method public final d()Z
.registers 2
iget-boolean v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->d:Z
return v0
.end method
.method public final e()Ljava/util/List;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Lokhttp3/internal/concurrent/Task;",
">;"
}
.end annotation
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
return-object v0
.end method
.method public final f()Ljava/lang/String;
.registers 2
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->f:Ljava/lang/String;
return-object v0
.end method
.method public final g()Z
.registers 2
iget-boolean v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->a:Z
return v0
.end method
.method public final h()Lokhttp3/internal/concurrent/TaskRunner;
.registers 2
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
return-object v0
.end method
.method public final i(Lokhttp3/internal/concurrent/Task;J)V
.registers 6
const-string v0, "task"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->c(Ljava/lang/Object;Ljava/lang/String;)V
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
monitor-enter v0
:try_start_8
iget-boolean v1, p0, Lokhttp3/internal/concurrent/TaskQueue;->a:Z
if-eqz v1, :cond_40
invoke-virtual {p1}, Lokhttp3/internal/concurrent/Task;->a()Z
move-result p2
if-eqz p2, :cond_27
sget-object p2, Lokhttp3/internal/concurrent/TaskRunner;->j:Lokhttp3/internal/concurrent/TaskRunner$Companion;
invoke-virtual {p2}, Lokhttp3/internal/concurrent/TaskRunner$Companion;->a()Ljava/util/logging/Logger;
move-result-object p2
sget-object p3, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {p2, p3}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result p2
if-eqz p2, :cond_25
const-string p2, "schedule canceled (queue is shutdown)"
invoke-static {p1, p0, p2}, Lokhttp3/internal/concurrent/TaskLoggerKt;->a(Lokhttp3/internal/concurrent/Task;Lokhttp3/internal/concurrent/TaskQueue;Ljava/lang/String;)V
:try_end_25
.catchall {:try_start_8 .. :try_end_25} :catchall_50
:cond_25
monitor-exit v0
return-void
:cond_27
:try_start_27
sget-object p2, Lokhttp3/internal/concurrent/TaskRunner;->j:Lokhttp3/internal/concurrent/TaskRunner$Companion;
invoke-virtual {p2}, Lokhttp3/internal/concurrent/TaskRunner$Companion;->a()Ljava/util/logging/Logger;
move-result-object p2
sget-object p3, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {p2, p3}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result p2
if-eqz p2, :cond_3a
const-string p2, "schedule failed (queue is shutdown)"
invoke-static {p1, p0, p2}, Lokhttp3/internal/concurrent/TaskLoggerKt;->a(Lokhttp3/internal/concurrent/Task;Lokhttp3/internal/concurrent/TaskQueue;Ljava/lang/String;)V
:cond_3a
new-instance p1, Ljava/util/concurrent/RejectedExecutionException;
invoke-direct {p1}, Ljava/util/concurrent/RejectedExecutionException;-><init>()V
throw p1
:cond_40
const/4 v1, 0x0
invoke-virtual {p0, p1, p2, p3, v1}, Lokhttp3/internal/concurrent/TaskQueue;->k(Lokhttp3/internal/concurrent/Task;JZ)Z
move-result p1
if-eqz p1, :cond_4c
iget-object p1, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
invoke-virtual {p1, p0}, Lokhttp3/internal/concurrent/TaskRunner;->h(Lokhttp3/internal/concurrent/TaskQueue;)V
:cond_4c
sget-object p1, Lkotlin/Unit;->a:Lkotlin/Unit;
:try_end_4e
.catchall {:try_start_27 .. :try_end_4e} :catchall_50
monitor-exit v0
return-void
:catchall_50
move-exception p1
monitor-exit v0
throw p1
.end method
.method public final k(Lokhttp3/internal/concurrent/Task;JZ)Z
.registers 15
const-string v0, "task"
invoke-static {p1, v0}, Lkotlin/jvm/internal/Intrinsics;->c(Ljava/lang/Object;Ljava/lang/String;)V
invoke-virtual {p1, p0}, Lokhttp3/internal/concurrent/Task;->e(Lokhttp3/internal/concurrent/TaskQueue;)V
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
invoke-virtual {v0}, Lokhttp3/internal/concurrent/TaskRunner;->g()Lokhttp3/internal/concurrent/TaskRunner$Backend;
move-result-object v0
invoke-interface {v0}, Lokhttp3/internal/concurrent/TaskRunner$Backend;->a()J
move-result-wide v0
add-long v2, v0, p2
iget-object v4, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v4, p1}, Ljava/util/List;->indexOf(Ljava/lang/Object;)I
move-result v4
const/4 v5, -0x1
const/4 v6, 0x0
if-eq v4, v5, :cond_3f
invoke-virtual {p1}, Lokhttp3/internal/concurrent/Task;->c()J
move-result-wide v7
cmp-long v9, v7, v2
if-gtz v9, :cond_3a
sget-object p2, Lokhttp3/internal/concurrent/TaskRunner;->j:Lokhttp3/internal/concurrent/TaskRunner$Companion;
invoke-virtual {p2}, Lokhttp3/internal/concurrent/TaskRunner$Companion;->a()Ljava/util/logging/Logger;
move-result-object p2
sget-object p3, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {p2, p3}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result p2
if-eqz p2, :cond_39
const-string p2, "already scheduled"
invoke-static {p1, p0, p2}, Lokhttp3/internal/concurrent/TaskLoggerKt;->a(Lokhttp3/internal/concurrent/Task;Lokhttp3/internal/concurrent/TaskQueue;Ljava/lang/String;)V
:cond_39
return v6
:cond_3a
iget-object v7, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {v7, v4}, Ljava/util/List;->remove(I)Ljava/lang/Object;
:cond_3f
invoke-virtual {p1, v2, v3}, Lokhttp3/internal/concurrent/Task;->g(J)V
sget-object v4, Lokhttp3/internal/concurrent/TaskRunner;->j:Lokhttp3/internal/concurrent/TaskRunner$Companion;
invoke-virtual {v4}, Lokhttp3/internal/concurrent/TaskRunner$Companion;->a()Ljava/util/logging/Logger;
move-result-object v4
sget-object v7, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {v4, v7}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result v4
if-eqz v4, :cond_82
if-eqz p4, :cond_69
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "run again after "
invoke-virtual {p4, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sub-long/2addr v2, v0
invoke-static {v2, v3}, Lokhttp3/internal/concurrent/TaskLoggerKt;->b(J)Ljava/lang/String;
move-result-object v2
invoke-virtual {p4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
goto :goto_7f
:cond_69
new-instance p4, Ljava/lang/StringBuilder;
invoke-direct {p4}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "scheduled after "
invoke-virtual {p4, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sub-long/2addr v2, v0
invoke-static {v2, v3}, Lokhttp3/internal/concurrent/TaskLoggerKt;->b(J)Ljava/lang/String;
move-result-object v2
invoke-virtual {p4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p4
:goto_7f
invoke-static {p1, p0, p4}, Lokhttp3/internal/concurrent/TaskLoggerKt;->a(Lokhttp3/internal/concurrent/Task;Lokhttp3/internal/concurrent/TaskQueue;Ljava/lang/String;)V
:cond_82
iget-object p4, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {p4}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p4
const/4 v2, 0x0
:goto_89
invoke-interface {p4}, Ljava/util/Iterator;->hasNext()Z
move-result v3
const/4 v4, 0x1
if-eqz v3, :cond_a8
invoke-interface {p4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lokhttp3/internal/concurrent/Task;
invoke-virtual {v3}, Lokhttp3/internal/concurrent/Task;->c()J
move-result-wide v7
sub-long/2addr v7, v0
cmp-long v3, v7, p2
if-lez v3, :cond_a1
const/4 v3, 0x1
goto :goto_a2
:cond_a1
const/4 v3, 0x0
:goto_a2
if-eqz v3, :cond_a5
goto :goto_a9
:cond_a5
add-int/lit8 v2, v2, 0x1
goto :goto_89
:cond_a8
const/4 v2, -0x1
:goto_a9
if-ne v2, v5, :cond_b1
iget-object p2, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {p2}, Ljava/util/List;->size()I
move-result v2
:cond_b1
iget-object p2, p0, Lokhttp3/internal/concurrent/TaskQueue;->c:Ljava/util/List;
invoke-interface {p2, v2, p1}, Ljava/util/List;->add(ILjava/lang/Object;)V
if-nez v2, :cond_b9
const/4 v6, 0x1
:cond_b9
return v6
.end method
.method public final l(Lokhttp3/internal/concurrent/Task;)V
.registers 2
iput-object p1, p0, Lokhttp3/internal/concurrent/TaskQueue;->b:Lokhttp3/internal/concurrent/Task;
return-void
.end method
.method public final m(Z)V
.registers 2
iput-boolean p1, p0, Lokhttp3/internal/concurrent/TaskQueue;->d:Z
return-void
.end method
.method public final n()V
.registers 5
sget-boolean v0, Lokhttp3/internal/Util;->g:Z
if-eqz v0, :cond_37
invoke-static {p0}, Ljava/lang/Thread;->holdsLock(Ljava/lang/Object;)Z
move-result v0
if-nez v0, :cond_b
goto :goto_37
:cond_b
new-instance v0, Ljava/lang/AssertionError;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Thread "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v2
const-string v3, "Thread.currentThread()"
invoke-static {v2, v3}, Lkotlin/jvm/internal/Intrinsics;->b(Ljava/lang/Object;Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, " MUST NOT hold lock on "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw v0
:cond_37
:goto_37
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
monitor-enter v0
const/4 v1, 0x1
:try_start_3b
iput-boolean v1, p0, Lokhttp3/internal/concurrent/TaskQueue;->a:Z
invoke-virtual {p0}, Lokhttp3/internal/concurrent/TaskQueue;->b()Z
move-result v1
if-eqz v1, :cond_48
iget-object v1, p0, Lokhttp3/internal/concurrent/TaskQueue;->e:Lokhttp3/internal/concurrent/TaskRunner;
invoke-virtual {v1, p0}, Lokhttp3/internal/concurrent/TaskRunner;->h(Lokhttp3/internal/concurrent/TaskQueue;)V
:cond_48
sget-object v1, Lkotlin/Unit;->a:Lkotlin/Unit;
:try_end_4a
.catchall {:try_start_3b .. :try_end_4a} :catchall_4c
monitor-exit v0
return-void
:catchall_4c
move-exception v1
monitor-exit v0
throw v1
.end method
.method public toString()Ljava/lang/String;
.registers 2
iget-object v0, p0, Lokhttp3/internal/concurrent/TaskQueue;->f:Ljava/lang/String;
return-object v0
.end method