.class final Lcom/google/common/util/concurrent/TimeoutFuture$Fire; .super Ljava/lang/Object; .source "TimeoutFuture.java" # interfaces .implements Ljava/lang/Runnable; # annotations .annotation system Ldalvik/annotation/EnclosingClass; value = Lcom/google/common/util/concurrent/TimeoutFuture; .end annotation .annotation system Ldalvik/annotation/InnerClass; accessFlags = 0x19 name = "Fire" .end annotation .annotation system Ldalvik/annotation/Signature; value = { "", "Ljava/lang/Object;", "Ljava/lang/Runnable;" } .end annotation # instance fields .field public timeoutFutureRef:Lcom/google/common/util/concurrent/TimeoutFuture; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/util/concurrent/TimeoutFuture<", "TV;>;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end field # direct methods .method public constructor (Lcom/google/common/util/concurrent/TimeoutFuture;)V .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/util/concurrent/TimeoutFuture<", "TV;>;)V" } .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Object;->()V .line 2 iput-object p1, p0, Lcom/google/common/util/concurrent/TimeoutFuture$Fire;->timeoutFutureRef:Lcom/google/common/util/concurrent/TimeoutFuture; return-void .end method # virtual methods .method public run()V .locals 10 .line 1 iget-object v0, p0, Lcom/google/common/util/concurrent/TimeoutFuture$Fire;->timeoutFutureRef:Lcom/google/common/util/concurrent/TimeoutFuture; if-nez v0, :cond_0 return-void .line 2 :cond_0 invoke-static {v0}, Lcom/google/common/util/concurrent/TimeoutFuture;->access$000(Lcom/google/common/util/concurrent/TimeoutFuture;)Lcom/google/common/util/concurrent/ListenableFuture; move-result-object v1 if-nez v1, :cond_1 return-void :cond_1 const/4 v2, 0x0 .line 3 iput-object v2, p0, Lcom/google/common/util/concurrent/TimeoutFuture$Fire;->timeoutFutureRef:Lcom/google/common/util/concurrent/TimeoutFuture; .line 4 invoke-interface {v1}, Ljava/util/concurrent/Future;->isDone()Z move-result v3 if-eqz v3, :cond_2 .line 5 invoke-virtual {v0, v1}, Lcom/google/common/util/concurrent/AbstractFuture;->setFuture(Lcom/google/common/util/concurrent/ListenableFuture;)Z goto :goto_0 :cond_2 const/4 v3, 0x1 .line 6 :try_start_0 invoke-static {v0}, Lcom/google/common/util/concurrent/TimeoutFuture;->access$100(Lcom/google/common/util/concurrent/TimeoutFuture;)Ljava/util/concurrent/ScheduledFuture; move-result-object v4 .line 7 invoke-static {v0, v2}, Lcom/google/common/util/concurrent/TimeoutFuture;->access$102(Lcom/google/common/util/concurrent/TimeoutFuture;Ljava/util/concurrent/ScheduledFuture;)Ljava/util/concurrent/ScheduledFuture; const-string v5, "Timed out" :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 if-eqz v4, :cond_3 .line 8 :try_start_1 sget-object v6, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit; invoke-interface {v4, v6}, Ljava/util/concurrent/ScheduledFuture;->getDelay(Ljava/util/concurrent/TimeUnit;)J move-result-wide v6 invoke-static {v6, v7}, Ljava/lang/Math;->abs(J)J move-result-wide v6 const-wide/16 v8, 0xa cmp-long v4, v6, v8 if-lez v4, :cond_3 .line 9 invoke-virtual {v5}, Ljava/lang/String;->length()I move-result v4 add-int/lit8 v4, v4, 0x42 new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8, v4}, Ljava/lang/StringBuilder;->(I)V invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v4, " (timeout delayed by " invoke-virtual {v8, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; const-string v4, " ms after scheduled time)" invoke-virtual {v8, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 move-object v5, v4 .line 10 :cond_3 invoke-static {v5}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v4 invoke-static {v1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String; move-result-object v6 invoke-virtual {v4}, Ljava/lang/String;->length()I move-result v7 add-int/lit8 v7, v7, 0x2 invoke-virtual {v6}, Ljava/lang/String;->length()I move-result v8 add-int/2addr v7, v8 new-instance v8, Ljava/lang/StringBuilder; invoke-direct {v8, v7}, Ljava/lang/StringBuilder;->(I)V invoke-virtual {v8, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v4, ": " invoke-virtual {v8, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v4 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 11 :try_start_2 new-instance v5, Lcom/google/common/util/concurrent/TimeoutFuture$TimeoutFutureException; invoke-direct {v5, v4, v2}, Lcom/google/common/util/concurrent/TimeoutFuture$TimeoutFutureException;->(Ljava/lang/String;Lcom/google/common/util/concurrent/TimeoutFuture$1;)V invoke-virtual {v0, v5}, Lcom/google/common/util/concurrent/AbstractFuture;->setException(Ljava/lang/Throwable;)Z :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_1 .line 12 invoke-interface {v1, v3}, Ljava/util/concurrent/Future;->cancel(Z)Z :goto_0 return-void :catchall_0 move-exception v4 .line 13 :try_start_3 new-instance v6, Lcom/google/common/util/concurrent/TimeoutFuture$TimeoutFutureException; invoke-direct {v6, v5, v2}, Lcom/google/common/util/concurrent/TimeoutFuture$TimeoutFutureException;->(Ljava/lang/String;Lcom/google/common/util/concurrent/TimeoutFuture$1;)V invoke-virtual {v0, v6}, Lcom/google/common/util/concurrent/AbstractFuture;->setException(Ljava/lang/Throwable;)Z .line 14 throw v4 :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_1 :catchall_1 move-exception v0 .line 15 invoke-interface {v1, v3}, Ljava/util/concurrent/Future;->cancel(Z)Z .line 16 throw v0 .end method