Http2Ping.smali
.class public Lio/grpc/internal/Http2Ping;
.super Ljava/lang/Object;
.source "Http2Ping.java"
# static fields
.field private static final log:Ljava/util/logging/Logger;
# instance fields
.field private callbacks:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Lio/grpc/internal/ClientTransport$PingCallback;",
"Ljava/util/concurrent/Executor;",
">;"
}
.end annotation
.end field
.field private completed:Z
.field private final data:J
.field private failureCause:Ljava/lang/Throwable;
.field private roundTripTimeNanos:J
.field private final stopwatch:Lcom/google/common/base/y;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 1
const-class v0, Lio/grpc/internal/Http2Ping;
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
move-result-object v0
sput-object v0, Lio/grpc/internal/Http2Ping;->log:Ljava/util/logging/Logger;
return-void
.end method
.method public constructor <init>(JLcom/google/common/base/y;)V
.registers 5
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
invoke-static {}, Lcom/google/common/collect/Maps;->d()Ljava/util/LinkedHashMap;
move-result-object v0
iput-object v0, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
.line 3
iput-wide p1, p0, Lio/grpc/internal/Http2Ping;->data:J
.line 4
iput-object p3, p0, Lio/grpc/internal/Http2Ping;->stopwatch:Lcom/google/common/base/y;
return-void
.end method
.method private static asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;J)Ljava/lang/Runnable;
.registers 4
.line 1
new-instance v0, Lio/grpc/internal/Http2Ping$1;
invoke-direct {v0, p0, p1, p2}, Lio/grpc/internal/Http2Ping$1;-><init>(Lio/grpc/internal/ClientTransport$PingCallback;J)V
return-object v0
.end method
.method private static asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/lang/Throwable;)Ljava/lang/Runnable;
.registers 3
.line 2
new-instance v0, Lio/grpc/internal/Http2Ping$2;
invoke-direct {v0, p0, p1}, Lio/grpc/internal/Http2Ping$2;-><init>(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/lang/Throwable;)V
return-object v0
.end method
.method private static doExecute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
.registers 4
.line 1
:try_start_0
invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:try_end_3
.catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_3} :catch_4
goto :goto_e
:catch_4
move-exception p0
.line 2
sget-object p1, Lio/grpc/internal/Http2Ping;->log:Ljava/util/logging/Logger;
sget-object v0, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
const-string v1, "Failed to execute PingCallback"
invoke-virtual {p1, v0, v1, p0}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_e
return-void
.end method
.method public static notifyFailed(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/util/concurrent/Executor;Ljava/lang/Throwable;)V
.registers 3
.line 1
invoke-static {p0, p2}, Lio/grpc/internal/Http2Ping;->asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/lang/Throwable;)Ljava/lang/Runnable;
move-result-object p0
invoke-static {p1, p0}, Lio/grpc/internal/Http2Ping;->doExecute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
return-void
.end method
# virtual methods
.method public addCallback(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/util/concurrent/Executor;)V
.registers 5
.line 1
monitor-enter p0
.line 2
:try_start_1
iget-boolean v0, p0, Lio/grpc/internal/Http2Ping;->completed:Z
if-nez v0, :cond_c
.line 3
iget-object v0, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
invoke-interface {v0, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 4
monitor-exit p0
return-void
.line 5
:cond_c
iget-object v0, p0, Lio/grpc/internal/Http2Ping;->failureCause:Ljava/lang/Throwable;
if-eqz v0, :cond_17
iget-object v0, p0, Lio/grpc/internal/Http2Ping;->failureCause:Ljava/lang/Throwable;
invoke-static {p1, v0}, Lio/grpc/internal/Http2Ping;->asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/lang/Throwable;)Ljava/lang/Runnable;
move-result-object p1
goto :goto_1d
:cond_17
iget-wide v0, p0, Lio/grpc/internal/Http2Ping;->roundTripTimeNanos:J
.line 6
invoke-static {p1, v0, v1}, Lio/grpc/internal/Http2Ping;->asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;J)Ljava/lang/Runnable;
move-result-object p1
.line 7
:goto_1d
monitor-exit p0
:try_end_1e
.catchall {:try_start_1 .. :try_end_1e} :catchall_22
.line 8
invoke-static {p2, p1}, Lio/grpc/internal/Http2Ping;->doExecute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
return-void
:catchall_22
move-exception p1
.line 9
:try_start_23
monitor-exit p0
:try_end_24
.catchall {:try_start_23 .. :try_end_24} :catchall_22
throw p1
.end method
.method public complete()Z
.registers 7
.line 1
monitor-enter p0
.line 2
:try_start_1
iget-boolean v0, p0, Lio/grpc/internal/Http2Ping;->completed:Z
if-eqz v0, :cond_8
const/4 v0, 0x0
.line 3
monitor-exit p0
return v0
:cond_8
const/4 v0, 0x1
.line 4
iput-boolean v0, p0, Lio/grpc/internal/Http2Ping;->completed:Z
.line 5
iget-object v1, p0, Lio/grpc/internal/Http2Ping;->stopwatch:Lcom/google/common/base/y;
sget-object v2, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v1, v2}, Lcom/google/common/base/y;->a(Ljava/util/concurrent/TimeUnit;)J
move-result-wide v1
iput-wide v1, p0, Lio/grpc/internal/Http2Ping;->roundTripTimeNanos:J
.line 6
iget-object v3, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
const/4 v4, 0x0
.line 7
iput-object v4, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
.line 8
monitor-exit p0
:try_end_1b
.catchall {:try_start_1 .. :try_end_1b} :catchall_44
.line 9
invoke-interface {v3}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v3
invoke-interface {v3}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v3
:goto_23
invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z
move-result v4
if-eqz v4, :cond_43
invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/util/Map$Entry;
.line 10
invoke-interface {v4}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v5
check-cast v5, Ljava/util/concurrent/Executor;
invoke-interface {v4}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lio/grpc/internal/ClientTransport$PingCallback;
invoke-static {v4, v1, v2}, Lio/grpc/internal/Http2Ping;->asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;J)Ljava/lang/Runnable;
move-result-object v4
invoke-static {v5, v4}, Lio/grpc/internal/Http2Ping;->doExecute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
goto :goto_23
:cond_43
return v0
:catchall_44
move-exception v0
.line 11
:try_start_45
monitor-exit p0
:try_end_46
.catchall {:try_start_45 .. :try_end_46} :catchall_44
goto :goto_48
:goto_47
throw v0
:goto_48
goto :goto_47
.end method
.method public failed(Ljava/lang/Throwable;)V
.registers 5
.line 1
monitor-enter p0
.line 2
:try_start_1
iget-boolean v0, p0, Lio/grpc/internal/Http2Ping;->completed:Z
if-eqz v0, :cond_7
.line 3
monitor-exit p0
return-void
:cond_7
const/4 v0, 0x1
.line 4
iput-boolean v0, p0, Lio/grpc/internal/Http2Ping;->completed:Z
.line 5
iput-object p1, p0, Lio/grpc/internal/Http2Ping;->failureCause:Ljava/lang/Throwable;
.line 6
iget-object v0, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
const/4 v1, 0x0
.line 7
iput-object v1, p0, Lio/grpc/internal/Http2Ping;->callbacks:Ljava/util/Map;
.line 8
monitor-exit p0
:try_end_12
.catchall {:try_start_1 .. :try_end_12} :catchall_3b
.line 9
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_1a
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_3a
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 10
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/util/concurrent/Executor;
invoke-interface {v1}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lio/grpc/internal/ClientTransport$PingCallback;
invoke-static {v1, p1}, Lio/grpc/internal/Http2Ping;->asRunnable(Lio/grpc/internal/ClientTransport$PingCallback;Ljava/lang/Throwable;)Ljava/lang/Runnable;
move-result-object v1
invoke-static {v2, v1}, Lio/grpc/internal/Http2Ping;->doExecute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
goto :goto_1a
:cond_3a
return-void
:catchall_3b
move-exception p1
.line 11
:try_start_3c
monitor-exit p0
:try_end_3d
.catchall {:try_start_3c .. :try_end_3d} :catchall_3b
goto :goto_3f
:goto_3e
throw p1
:goto_3f
goto :goto_3e
.end method
.method public payload()J
.registers 3
.line 1
iget-wide v0, p0, Lio/grpc/internal/Http2Ping;->data:J
return-wide v0
.end method