AsyncTimeout.smali 
.class public Ldc/squareup/okio/AsyncTimeout;
.super Ldc/squareup/okio/Timeout;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Ldc/squareup/okio/AsyncTimeout$Watchdog;
    }
.end annotation
# static fields
.field private static final IDLE_TIMEOUT_MILLIS:J
.field private static final IDLE_TIMEOUT_NANOS:J
.field private static final TIMEOUT_WRITE_SIZE:I = 0x10000
.field static head:Ldc/squareup/okio/AsyncTimeout;
# instance fields
.field private inQueue:Z
.field private next:Ldc/squareup/okio/AsyncTimeout;
.field private timeoutAt:J
# direct methods
.method static constructor <clinit>()V
    .registers 3
    .line 1
    sget-object v0, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
    const-wide/16 v1, 0x3c
    invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J
    move-result-wide v0
    sput-wide v0, Ldc/squareup/okio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J
    .line 2
    sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
    invoke-virtual {v2, v0, v1}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J
    move-result-wide v0
    sput-wide v0, Ldc/squareup/okio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J
    return-void
.end method
.method public constructor <init>()V
    .registers 1
    .line 1
    invoke-direct {p0}, Ldc/squareup/okio/Timeout;-><init>()V
    return-void
.end method
.method static awaitTimeout()Ldc/squareup/okio/AsyncTimeout;
    .registers 9
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/InterruptedException;
        }
    .end annotation
    .line 1
    const-class v0, Ldc/squareup/okio/AsyncTimeout;
    sget-object v1, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    iget-object v1, v1, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    const/4 v2, 0x0
    if-nez v1, :cond_26
    .line 5
    invoke-static {}, Ljava/lang/System;->nanoTime()J
    move-result-wide v3
    .line 6
    sget-wide v5, Ldc/squareup/okio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J
    invoke-virtual {v0, v5, v6}, Ljava/lang/Object;->wait(J)V
    .line 7
    sget-object v0, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    iget-object v0, v0, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    if-nez v0, :cond_25
    invoke-static {}, Ljava/lang/System;->nanoTime()J
    move-result-wide v0
    sub-long/2addr v0, v3
    sget-wide v3, Ldc/squareup/okio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J
    cmp-long v0, v0, v3
    if-ltz v0, :cond_25
    .line 8
    sget-object v2, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    :cond_25
    return-object v2
    .line 12
    :cond_26
    invoke-static {}, Ljava/lang/System;->nanoTime()J
    move-result-wide v3
    invoke-direct {v1, v3, v4}, Ldc/squareup/okio/AsyncTimeout;->remainingNanos(J)J
    move-result-wide v3
    const-wide/16 v5, 0x0
    cmp-long v5, v3, v5
    if-lez v5, :cond_40
    const-wide/32 v5, 0xf4240
    .line 18
    div-long v7, v3, v5
    mul-long/2addr v5, v7
    sub-long/2addr v3, v5
    long-to-int v1, v3
    .line 20
    invoke-virtual {v0, v7, v8, v1}, Ljava/lang/Object;->wait(JI)V
    return-object v2
    .line 25
    :cond_40
    sget-object v0, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    iget-object v3, v1, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    iput-object v3, v0, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    .line 26
    iput-object v2, v1, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    return-object v1
.end method
.method private static declared-synchronized cancelScheduledTimeout(Ldc/squareup/okio/AsyncTimeout;)Z
    .registers 4
    const-class v0, Ldc/squareup/okio/AsyncTimeout;
    monitor-enter v0
    .line 1
    :try_start_3
    sget-object v1, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    :goto_5
    if-eqz v1, :cond_17
    .line 2
    iget-object v2, v1, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    if-ne v2, p0, :cond_15
    .line 3
    iget-object v2, p0, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    iput-object v2, v1, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    const/4 v1, 0x0
    .line 4
    iput-object v1, p0, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    :try_end_12
    .catchall {:try_start_3 .. :try_end_12} :catchall_19
    const/4 p0, 0x0
    :goto_13
    monitor-exit v0
    return p0
    :cond_15
    move-object v1, v2
    goto :goto_5
    :cond_17
    const/4 p0, 0x1
    goto :goto_13
    :catchall_19
    move-exception p0
    monitor-exit v0
    throw p0
.end method
.method private remainingNanos(J)J
    .registers 5
    .line 1
    iget-wide v0, p0, Ldc/squareup/okio/AsyncTimeout;->timeoutAt:J
    sub-long/2addr v0, p1
    return-wide v0
.end method
.method private static declared-synchronized scheduleTimeout(Ldc/squareup/okio/AsyncTimeout;JZ)V
    .registers 9
    const-class v0, Ldc/squareup/okio/AsyncTimeout;
    monitor-enter v0
    .line 1
    :try_start_3
    sget-object v1, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    if-nez v1, :cond_16
    .line 2
    new-instance v1, Ldc/squareup/okio/AsyncTimeout;
    invoke-direct {v1}, Ldc/squareup/okio/AsyncTimeout;-><init>()V
    sput-object v1, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    .line 3
    new-instance v1, Ldc/squareup/okio/AsyncTimeout$Watchdog;
    invoke-direct {v1}, Ldc/squareup/okio/AsyncTimeout$Watchdog;-><init>()V
    invoke-virtual {v1}, Ljava/lang/Thread;->start()V
    .line 6
    :cond_16
    invoke-static {}, Ljava/lang/System;->nanoTime()J
    move-result-wide v1
    const-wide/16 v3, 0x0
    cmp-long v3, p1, v3
    if-eqz v3, :cond_2f
    if-eqz p3, :cond_2f
    .line 10
    invoke-virtual {p0}, Ldc/squareup/okio/Timeout;->deadlineNanoTime()J
    move-result-wide v3
    sub-long/2addr v3, v1
    invoke-static {p1, p2, v3, v4}, Ljava/lang/Math;->min(JJ)J
    move-result-wide p1
    add-long/2addr p1, v1
    iput-wide p1, p0, Ldc/squareup/okio/AsyncTimeout;->timeoutAt:J
    goto :goto_3d
    :cond_2f
    if-eqz v3, :cond_35
    add-long/2addr p1, v1
    .line 12
    iput-wide p1, p0, Ldc/squareup/okio/AsyncTimeout;->timeoutAt:J
    goto :goto_3d
    :cond_35
    if-eqz p3, :cond_62
    .line 14
    invoke-virtual {p0}, Ldc/squareup/okio/Timeout;->deadlineNanoTime()J
    move-result-wide p1
    iput-wide p1, p0, Ldc/squareup/okio/AsyncTimeout;->timeoutAt:J
    .line 20
    :goto_3d
    invoke-direct {p0, v1, v2}, Ldc/squareup/okio/AsyncTimeout;->remainingNanos(J)J
    move-result-wide p1
    .line 21
    sget-object p3, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    .line 22
    :goto_43
    iget-object v3, p3, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    if-eqz v3, :cond_53
    invoke-direct {v3, v1, v2}, Ldc/squareup/okio/AsyncTimeout;->remainingNanos(J)J
    move-result-wide v3
    cmp-long v3, p1, v3
    if-gez v3, :cond_50
    goto :goto_53
    .line 23
    :cond_50
    iget-object p3, p3, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    goto :goto_43
    .line 25
    :cond_53
    :goto_53
    iget-object p1, p3, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    iput-object p1, p0, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    .line 26
    iput-object p0, p3, Ldc/squareup/okio/AsyncTimeout;->next:Ldc/squareup/okio/AsyncTimeout;
    .line 27
    sget-object p0, Ldc/squareup/okio/AsyncTimeout;->head:Ldc/squareup/okio/AsyncTimeout;
    if-ne p3, p0, :cond_60
    .line 28
    invoke-virtual {v0}, Ljava/lang/Object;->notify()V
    :try_end_60
    .catchall {:try_start_3 .. :try_end_60} :catchall_68
    :cond_60
    monitor-exit v0
    return-void
    .line 29
    :cond_62
    :try_start_62
    new-instance p0, Ljava/lang/AssertionError;
    invoke-direct {p0}, Ljava/lang/AssertionError;-><init>()V
    throw p0
    :try_end_68
    .catchall {:try_start_62 .. :try_end_68} :catchall_68
    :catchall_68
    move-exception p0
    monitor-exit v0
    throw p0
.end method
# virtual methods
.method public final enter()V
    .registers 6
    .line 1
    iget-boolean v0, p0, Ldc/squareup/okio/AsyncTimeout;->inQueue:Z
    if-nez v0, :cond_1c
    .line 2
    invoke-virtual {p0}, Ldc/squareup/okio/Timeout;->timeoutNanos()J
    move-result-wide v0
    .line 3
    invoke-virtual {p0}, Ldc/squareup/okio/Timeout;->hasDeadline()Z
    move-result v2
    const-wide/16 v3, 0x0
    cmp-long v3, v0, v3
    if-nez v3, :cond_15
    if-nez v2, :cond_15
    return-void
    :cond_15
    const/4 v3, 0x1
    .line 7
    iput-boolean v3, p0, Ldc/squareup/okio/AsyncTimeout;->inQueue:Z
    .line 8
    invoke-static {p0, v0, v1, v2}, Ldc/squareup/okio/AsyncTimeout;->scheduleTimeout(Ldc/squareup/okio/AsyncTimeout;JZ)V
    return-void
    .line 9
    :cond_1c
    new-instance v0, Ljava/lang/IllegalStateException;
    const-string v1, "Unbalanced enter/exit"
    invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
    throw v0
.end method
.method final exit(Ljava/io/IOException;)Ljava/io/IOException;
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/io/IOException;
        }
    .end annotation
    .line 6
    invoke-virtual {p0}, Ldc/squareup/okio/AsyncTimeout;->exit()Z
    move-result v0
    if-nez v0, :cond_7
    return-object p1
    .line 7
    :cond_7
    invoke-virtual {p0, p1}, Ldc/squareup/okio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException;
    move-result-object p1
    return-object p1
.end method
.method final exit(Z)V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/io/IOException;
        }
    .end annotation
    .line 4
    invoke-virtual {p0}, Ldc/squareup/okio/AsyncTimeout;->exit()Z
    move-result v0
    if-eqz v0, :cond_f
    if-nez p1, :cond_9
    goto :goto_f
    :cond_9
    const/4 p1, 0x0
    .line 5
    invoke-virtual {p0, p1}, Ldc/squareup/okio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException;
    move-result-object p1
    throw p1
    :cond_f
    :goto_f
    return-void
.end method
.method public final exit()Z
    .registers 3
    .line 1
    iget-boolean v0, p0, Ldc/squareup/okio/AsyncTimeout;->inQueue:Z
    const/4 v1, 0x0
    if-nez v0, :cond_6
    return v1
    .line 2
    :cond_6
    iput-boolean v1, p0, Ldc/squareup/okio/AsyncTimeout;->inQueue:Z
    .line 3
    invoke-static {p0}, Ldc/squareup/okio/AsyncTimeout;->cancelScheduledTimeout(Ldc/squareup/okio/AsyncTimeout;)Z
    move-result v0
    return v0
.end method
.method protected newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException;
    .registers 4
    .line 1
    new-instance v0, Ljava/io/InterruptedIOException;
    const-string v1, "timeout"
    invoke-direct {v0, v1}, Ljava/io/InterruptedIOException;-><init>(Ljava/lang/String;)V
    if-eqz p1, :cond_c
    .line 3
    invoke-virtual {v0, p1}, Ljava/io/InterruptedIOException;->initCause(Ljava/lang/Throwable;)Ljava/lang/Throwable;
    :cond_c
    return-object v0
.end method
.method public final sink(Ldc/squareup/okio/Sink;)Ldc/squareup/okio/Sink;
    .registers 3
    .line 1
    new-instance v0, Ldc/squareup/okio/AsyncTimeout$1;
    invoke-direct {v0, p0, p1}, Ldc/squareup/okio/AsyncTimeout$1;-><init>(Ldc/squareup/okio/AsyncTimeout;Ldc/squareup/okio/Sink;)V
    return-object v0
.end method
.method public final source(Ldc/squareup/okio/Source;)Ldc/squareup/okio/Source;
    .registers 3
    .line 1
    new-instance v0, Ldc/squareup/okio/AsyncTimeout$2;
    invoke-direct {v0, p0, p1}, Ldc/squareup/okio/AsyncTimeout$2;-><init>(Ldc/squareup/okio/AsyncTimeout;Ldc/squareup/okio/Source;)V
    return-object v0
.end method
.method protected timedOut()V
    .registers 1
    return-void
.end method