.class public Lokio/AsyncTimeout; .super Lokio/Timeout; .source "SourceFile" # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lokio/AsyncTimeout$Watchdog; } .end annotation # static fields .field public static final IDLE_TIMEOUT_MILLIS:J .field public static final IDLE_TIMEOUT_NANOS:J .field public static head:Lokio/AsyncTimeout; # instance fields .field public inQueue:Z .field public next:Lokio/AsyncTimeout; .field public timeoutAt:J # direct methods .method static constructor ()V .locals 3 .line 50 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, Lokio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J .line 51 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, Lokio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J return-void .end method .method public constructor ()V .locals 0 .line 41 invoke-direct {p0}, Lokio/Timeout;->()V return-void .end method .method public static awaitTimeout()Lokio/AsyncTimeout; .locals 9 sget-object v0, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; .line 343 iget-object v0, v0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; const-class v1, Lokio/AsyncTimeout; const/4 v2, 0x0 if-nez v0, :cond_1 .line 347 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v3 sget-wide v5, Lokio/AsyncTimeout;->IDLE_TIMEOUT_MILLIS:J .line 348 invoke-virtual {v1, v5, v6}, Ljava/lang/Object;->wait(J)V sget-object v0, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; .line 349 iget-object v0, v0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; if-nez v0, :cond_0 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v0 sub-long/2addr v0, v3 sget-wide v3, Lokio/AsyncTimeout;->IDLE_TIMEOUT_NANOS:J cmp-long v0, v0, v3 if-ltz v0, :cond_0 sget-object v2, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; :cond_0 return-object v2 .line 354 :cond_1 invoke-static {}, Ljava/lang/System;->nanoTime()J move-result-wide v3 invoke-virtual {v0, v3, v4}, Lokio/AsyncTimeout;->remainingNanos(J)J move-result-wide v3 const-wide/16 v5, 0x0 cmp-long v5, v3, v5 if-lez v5, :cond_2 const-wide/32 v5, 0xf4240 .line 360 div-long v7, v3, v5 mul-long/2addr v5, v7 sub-long/2addr v3, v5 long-to-int v0, v3 .line 362 invoke-virtual {v1, v7, v8, v0}, Ljava/lang/Object;->wait(JI)V return-object v2 :cond_2 sget-object v1, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; .line 367 iget-object v3, v0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; iput-object v3, v1, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; .line 368 iput-object v2, v0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; return-object v0 .end method .method public static declared-synchronized cancelScheduledTimeout(Lokio/AsyncTimeout;)Z .locals 3 const-class v0, Lokio/AsyncTimeout; monitor-enter v0 :try_start_0 sget-object v1, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; :goto_0 if-eqz v1, :cond_1 .line 129 iget-object v2, v1, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; if-ne v2, p0, :cond_0 .line 130 iget-object v2, p0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; iput-object v2, v1, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; const/4 v1, 0x0 .line 131 iput-object v1, p0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 132 monitor-exit v0 const/4 p0, 0x0 return p0 :catchall_0 move-exception p0 goto :goto_1 :cond_0 move-object v1, v2 goto :goto_0 .line 137 :cond_1 monitor-exit v0 const/4 p0, 0x1 return p0 :goto_1 monitor-exit v0 throw p0 .end method .method public static declared-synchronized scheduleTimeout(Lokio/AsyncTimeout;JZ)V .locals 5 const-class v0, Lokio/AsyncTimeout; monitor-enter v0 :try_start_0 sget-object v1, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; if-nez v1, :cond_0 .line 87 new-instance v1, Lokio/AsyncTimeout; invoke-direct {v1}, Lokio/AsyncTimeout;->()V sput-object v1, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; .line 88 new-instance v1, Lokio/AsyncTimeout$Watchdog; invoke-direct {v1}, Lokio/AsyncTimeout$Watchdog;->()V invoke-virtual {v1}, Ljava/lang/Thread;->start()V goto :goto_0 :catchall_0 move-exception p0 goto :goto_4 .line 91 :cond_0 :goto_0 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_1 if-eqz p3, :cond_1 .line 95 invoke-virtual {p0}, Lokio/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, Lokio/AsyncTimeout;->timeoutAt:J goto :goto_1 :cond_1 if-eqz v3, :cond_2 add-long/2addr p1, v1 .line 97 iput-wide p1, p0, Lokio/AsyncTimeout;->timeoutAt:J goto :goto_1 :cond_2 if-eqz p3, :cond_6 .line 99 invoke-virtual {p0}, Lokio/Timeout;->deadlineNanoTime()J move-result-wide p1 iput-wide p1, p0, Lokio/AsyncTimeout;->timeoutAt:J .line 105 :goto_1 invoke-virtual {p0, v1, v2}, Lokio/AsyncTimeout;->remainingNanos(J)J move-result-wide p1 sget-object p3, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; .line 107 :goto_2 iget-object v3, p3, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; if-eqz v3, :cond_4 invoke-virtual {v3, v1, v2}, Lokio/AsyncTimeout;->remainingNanos(J)J move-result-wide v3 cmp-long v3, p1, v3 if-gez v3, :cond_3 goto :goto_3 .line 106 :cond_3 iget-object p3, p3, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; goto :goto_2 .line 108 :cond_4 :goto_3 iget-object p1, p3, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; iput-object p1, p0, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; .line 109 iput-object p0, p3, Lokio/AsyncTimeout;->next:Lokio/AsyncTimeout; sget-object p0, Lokio/AsyncTimeout;->head:Lokio/AsyncTimeout; if-ne p3, p0, :cond_5 const-class p0, Lokio/AsyncTimeout; .line 111 invoke-virtual {p0}, Ljava/lang/Object;->notify()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 116 :cond_5 monitor-exit v0 return-void .line 101 :cond_6 :try_start_1 new-instance p0, Ljava/lang/AssertionError; invoke-direct {p0}, Ljava/lang/AssertionError;->()V throw p0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :goto_4 monitor-exit v0 throw p0 .end method # virtual methods .method public final enter()V .locals 5 iget-boolean v0, p0, Lokio/AsyncTimeout;->inQueue:Z if-nez v0, :cond_1 .line 74 invoke-virtual {p0}, Lokio/Timeout;->timeoutNanos()J move-result-wide v0 .line 75 invoke-virtual {p0}, Lokio/Timeout;->hasDeadline()Z move-result v2 const-wide/16 v3, 0x0 cmp-long v3, v0, v3 if-nez v3, :cond_0 if-nez v2, :cond_0 return-void :cond_0 const/4 v3, 0x1 iput-boolean v3, p0, Lokio/AsyncTimeout;->inQueue:Z .line 80 invoke-static {p0, v0, v1, v2}, Lokio/AsyncTimeout;->scheduleTimeout(Lokio/AsyncTimeout;JZ)V return-void .line 73 :cond_1 new-instance v0, Ljava/lang/IllegalStateException; const-string v1, "Unbalanced enter/exit" invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 .end method .method public final exit(Ljava/io/IOException;)Ljava/io/IOException; .locals 1 .line 285 invoke-virtual {p0}, Lokio/AsyncTimeout;->exit()Z move-result v0 if-nez v0, :cond_0 return-object p1 .line 286 :cond_0 invoke-virtual {p0, p1}, Lokio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; move-result-object p1 return-object p1 .end method .method public final exit(Z)V .locals 1 .line 275 invoke-virtual {p0}, Lokio/AsyncTimeout;->exit()Z move-result v0 if-eqz v0, :cond_1 if-nez p1, :cond_0 goto :goto_0 :cond_0 const/4 p1, 0x0 .line 276 invoke-virtual {p0, p1}, Lokio/AsyncTimeout;->newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; move-result-object p1 throw p1 :cond_1 :goto_0 return-void .end method .method public final exit()Z .locals 2 iget-boolean v0, p0, Lokio/AsyncTimeout;->inQueue:Z const/4 v1, 0x0 if-nez v0, :cond_0 return v1 :cond_0 iput-boolean v1, p0, Lokio/AsyncTimeout;->inQueue:Z .line 122 invoke-static {p0}, Lokio/AsyncTimeout;->cancelScheduledTimeout(Lokio/AsyncTimeout;)Z move-result v0 return v0 .end method .method public newTimeoutException(Ljava/io/IOException;)Ljava/io/IOException; .locals 2 .line 295 new-instance v0, Ljava/io/InterruptedIOException; const-string v1, "timeout" invoke-direct {v0, v1}, Ljava/io/InterruptedIOException;->(Ljava/lang/String;)V if-eqz p1, :cond_0 .line 297 invoke-virtual {v0, p1}, Ljava/lang/Throwable;->initCause(Ljava/lang/Throwable;)Ljava/lang/Throwable; :cond_0 return-object v0 .end method .method public final remainingNanos(J)J .locals 2 iget-wide v0, p0, Lokio/AsyncTimeout;->timeoutAt:J sub-long/2addr v0, p1 return-wide v0 .end method .method public final sink(Lokio/Sink;)Lokio/Sink; .locals 1 .line 160 new-instance v0, Lokio/AsyncTimeout$1; invoke-direct {v0, p0, p1}, Lokio/AsyncTimeout$1;->(Lokio/AsyncTimeout;Lokio/Sink;)V return-object v0 .end method .method public final source(Lokio/Source;)Lokio/Source; .locals 1 .line 232 new-instance v0, Lokio/AsyncTimeout$2; invoke-direct {v0, p0, p1}, Lokio/AsyncTimeout$2;->(Lokio/AsyncTimeout;Lokio/Source;)V return-object v0 .end method .method public timedOut()V .locals 0 return-void .end method