KeepAliveManager.smali
.class public Lio/grpc/internal/KeepAliveManager;
.super Ljava/lang/Object;
.source "KeepAliveManager.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/grpc/internal/KeepAliveManager$SystemTicker;,
Lio/grpc/internal/KeepAliveManager$Ticker;,
Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;,
Lio/grpc/internal/KeepAliveManager$State;
}
.end annotation
# static fields
.field private static final MIN_KEEPALIVE_DELAY_NANOS:J
.field private static final SYSTEM_TICKER:Lio/grpc/internal/KeepAliveManager$SystemTicker;
# instance fields
.field private keepAliveDelayInNanos:J
.field private keepAliveTimeoutInNanos:J
.field private nextKeepaliveTime:J
.field private final pingCallback:Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
.field private pingFuture:Ljava/util/concurrent/ScheduledFuture;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.end field
.field private final scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.field private final sendPing:Ljava/lang/Runnable;
.field private final shutdown:Ljava/lang/Runnable;
.field private shutdownFuture:Ljava/util/concurrent/ScheduledFuture;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.end field
.field private state:Lio/grpc/internal/KeepAliveManager$State;
.field private final ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
.field private final transport:Lio/grpc/internal/ManagedClientTransport;
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 1
new-instance v0, Lio/grpc/internal/KeepAliveManager$SystemTicker;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lio/grpc/internal/KeepAliveManager$SystemTicker;-><init>(Lio/grpc/internal/KeepAliveManager$1;)V
sput-object v0, Lio/grpc/internal/KeepAliveManager;->SYSTEM_TICKER:Lio/grpc/internal/KeepAliveManager$SystemTicker;
.line 2
sget-object v0, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;
const-wide/16 v1, 0x1
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toNanos(J)J
move-result-wide v0
sput-wide v0, Lio/grpc/internal/KeepAliveManager;->MIN_KEEPALIVE_DELAY_NANOS:J
return-void
.end method
.method public constructor <init>(Lio/grpc/internal/ManagedClientTransport;Ljava/util/concurrent/ScheduledExecutorService;JJ)V
.registers 9
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->IDLE:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
.line 3
new-instance v0, Lio/grpc/internal/KeepAliveManager$1;
invoke-direct {v0, p0}, Lio/grpc/internal/KeepAliveManager$1;-><init>(Lio/grpc/internal/KeepAliveManager;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->shutdown:Ljava/lang/Runnable;
.line 4
new-instance v0, Lio/grpc/internal/KeepAliveManager$2;
invoke-direct {v0, p0}, Lio/grpc/internal/KeepAliveManager$2;-><init>(Lio/grpc/internal/KeepAliveManager;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->sendPing:Ljava/lang/Runnable;
.line 5
new-instance v0, Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;-><init>(Lio/grpc/internal/KeepAliveManager;Lio/grpc/internal/KeepAliveManager$1;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->pingCallback:Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
const-string v0, "transport"
.line 6
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p1, Lio/grpc/internal/ManagedClientTransport;
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->transport:Lio/grpc/internal/ManagedClientTransport;
const-string p1, "scheduler"
.line 7
invoke-static {p2, p1}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p2, Ljava/util/concurrent/ScheduledExecutorService;
iput-object p2, p0, Lio/grpc/internal/KeepAliveManager;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.line 8
sget-object p1, Lio/grpc/internal/KeepAliveManager;->SYSTEM_TICKER:Lio/grpc/internal/KeepAliveManager$SystemTicker;
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
.line 9
sget-wide p1, Lio/grpc/internal/KeepAliveManager;->MIN_KEEPALIVE_DELAY_NANOS:J
invoke-static {p1, p2, p3, p4}, Ljava/lang/Math;->max(JJ)J
move-result-wide p1
iput-wide p1, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveDelayInNanos:J
.line 10
iput-wide p5, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveTimeoutInNanos:J
.line 11
iget-object p1, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
invoke-virtual {p1}, Lio/grpc/internal/KeepAliveManager$Ticker;->read()J
move-result-wide p1
add-long/2addr p1, p3
iput-wide p1, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
return-void
.end method
.method constructor <init>(Lio/grpc/internal/ManagedClientTransport;Ljava/util/concurrent/ScheduledExecutorService;Lio/grpc/internal/KeepAliveManager$Ticker;JJ)V
.registers 10
.line 12
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 13
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->IDLE:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
.line 14
new-instance v0, Lio/grpc/internal/KeepAliveManager$1;
invoke-direct {v0, p0}, Lio/grpc/internal/KeepAliveManager$1;-><init>(Lio/grpc/internal/KeepAliveManager;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->shutdown:Ljava/lang/Runnable;
.line 15
new-instance v0, Lio/grpc/internal/KeepAliveManager$2;
invoke-direct {v0, p0}, Lio/grpc/internal/KeepAliveManager$2;-><init>(Lio/grpc/internal/KeepAliveManager;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->sendPing:Ljava/lang/Runnable;
.line 16
new-instance v0, Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
const/4 v1, 0x0
invoke-direct {v0, p0, v1}, Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;-><init>(Lio/grpc/internal/KeepAliveManager;Lio/grpc/internal/KeepAliveManager$1;)V
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->pingCallback:Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
const-string v0, "transport"
.line 17
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p1, Lio/grpc/internal/ManagedClientTransport;
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->transport:Lio/grpc/internal/ManagedClientTransport;
const-string p1, "scheduler"
.line 18
invoke-static {p2, p1}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p2, Ljava/util/concurrent/ScheduledExecutorService;
iput-object p2, p0, Lio/grpc/internal/KeepAliveManager;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
const-string p1, "ticker"
.line 19
invoke-static {p3, p1}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
move-object p1, p3
check-cast p1, Lio/grpc/internal/KeepAliveManager$Ticker;
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
.line 20
iput-wide p4, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveDelayInNanos:J
.line 21
iput-wide p6, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveTimeoutInNanos:J
.line 22
invoke-virtual {p3}, Lio/grpc/internal/KeepAliveManager$Ticker;->read()J
move-result-wide p1
add-long/2addr p1, p4
iput-wide p1, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
return-void
.end method
.method static synthetic access$100(Lio/grpc/internal/KeepAliveManager;)Lio/grpc/internal/KeepAliveManager$State;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
return-object p0
.end method
.method static synthetic access$1000(Lio/grpc/internal/KeepAliveManager;)Lio/grpc/internal/KeepAliveManager$Ticker;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
return-object p0
.end method
.method static synthetic access$102(Lio/grpc/internal/KeepAliveManager;Lio/grpc/internal/KeepAliveManager$State;)Lio/grpc/internal/KeepAliveManager$State;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
return-object p1
.end method
.method static synthetic access$1100(Lio/grpc/internal/KeepAliveManager;)Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->pingCallback:Lio/grpc/internal/KeepAliveManager$KeepAlivePingCallback;
return-object p0
.end method
.method static synthetic access$1300(Lio/grpc/internal/KeepAliveManager;)J
.registers 3
.line 1
iget-wide v0, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveDelayInNanos:J
return-wide v0
.end method
.method static synthetic access$200(Lio/grpc/internal/KeepAliveManager;)Lio/grpc/internal/ManagedClientTransport;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->transport:Lio/grpc/internal/ManagedClientTransport;
return-object p0
.end method
.method static synthetic access$300(Lio/grpc/internal/KeepAliveManager;)Ljava/util/concurrent/ScheduledFuture;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->shutdownFuture:Ljava/util/concurrent/ScheduledFuture;
return-object p0
.end method
.method static synthetic access$302(Lio/grpc/internal/KeepAliveManager;Ljava/util/concurrent/ScheduledFuture;)Ljava/util/concurrent/ScheduledFuture;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->shutdownFuture:Ljava/util/concurrent/ScheduledFuture;
return-object p1
.end method
.method static synthetic access$400(Lio/grpc/internal/KeepAliveManager;)Ljava/lang/Runnable;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->shutdown:Ljava/lang/Runnable;
return-object p0
.end method
.method static synthetic access$500(Lio/grpc/internal/KeepAliveManager;)J
.registers 3
.line 1
iget-wide v0, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveTimeoutInNanos:J
return-wide v0
.end method
.method static synthetic access$600(Lio/grpc/internal/KeepAliveManager;)Ljava/util/concurrent/ScheduledExecutorService;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
return-object p0
.end method
.method static synthetic access$702(Lio/grpc/internal/KeepAliveManager;Ljava/util/concurrent/ScheduledFuture;)Ljava/util/concurrent/ScheduledFuture;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/KeepAliveManager;->pingFuture:Ljava/util/concurrent/ScheduledFuture;
return-object p1
.end method
.method static synthetic access$800(Lio/grpc/internal/KeepAliveManager;)Ljava/lang/Runnable;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/KeepAliveManager;->sendPing:Ljava/lang/Runnable;
return-object p0
.end method
.method static synthetic access$900(Lio/grpc/internal/KeepAliveManager;)J
.registers 3
.line 1
iget-wide v0, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
return-wide v0
.end method
.method static synthetic access$902(Lio/grpc/internal/KeepAliveManager;J)J
.registers 3
.line 1
iput-wide p1, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
return-wide p1
.end method
# virtual methods
.method public declared-synchronized onDataReceived()V
.registers 5
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
invoke-virtual {v0}, Lio/grpc/internal/KeepAliveManager$Ticker;->read()J
move-result-wide v0
iget-wide v2, p0, Lio/grpc/internal/KeepAliveManager;->keepAliveDelayInNanos:J
add-long/2addr v0, v2
iput-wide v0, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
.line 2
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->PING_SCHEDULED:Lio/grpc/internal/KeepAliveManager$State;
if-ne v0, v1, :cond_16
.line 3
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->PING_DELAYED:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
:try_end_16
.catchall {:try_start_1 .. :try_end_16} :catchall_18
.line 4
:cond_16
monitor-exit p0
return-void
:catchall_18
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onTransportActive()V
.registers 7
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->IDLE:Lio/grpc/internal/KeepAliveManager$State;
if-ne v0, v1, :cond_20
.line 2
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->PING_SCHEDULED:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
.line 3
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
iget-object v1, p0, Lio/grpc/internal/KeepAliveManager;->sendPing:Ljava/lang/Runnable;
iget-wide v2, p0, Lio/grpc/internal/KeepAliveManager;->nextKeepaliveTime:J
iget-object v4, p0, Lio/grpc/internal/KeepAliveManager;->ticker:Lio/grpc/internal/KeepAliveManager$Ticker;
invoke-virtual {v4}, Lio/grpc/internal/KeepAliveManager$Ticker;->read()J
move-result-wide v4
sub-long/2addr v2, v4
sget-object v4, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v0, v1, v2, v3, v4}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object v0
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->pingFuture:Ljava/util/concurrent/ScheduledFuture;
:try_end_20
.catchall {:try_start_1 .. :try_end_20} :catchall_22
.line 4
:cond_20
monitor-exit p0
return-void
:catchall_22
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onTransportIdle()V
.registers 3
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->PING_SCHEDULED:Lio/grpc/internal/KeepAliveManager$State;
if-eq v0, v1, :cond_d
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->PING_DELAYED:Lio/grpc/internal/KeepAliveManager$State;
if-ne v0, v1, :cond_11
.line 2
:cond_d
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->IDLE:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
.line 3
:cond_11
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->PING_SENT:Lio/grpc/internal/KeepAliveManager$State;
if-ne v0, v1, :cond_1b
.line 4
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->IDLE_AND_PING_SENT:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
:try_end_1b
.catchall {:try_start_1 .. :try_end_1b} :catchall_1d
.line 5
:cond_1b
monitor-exit p0
return-void
:catchall_1d
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onTransportShutdown()V
.registers 3
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
sget-object v1, Lio/grpc/internal/KeepAliveManager$State;->DISCONNECTED:Lio/grpc/internal/KeepAliveManager$State;
if-eq v0, v1, :cond_1e
.line 2
sget-object v0, Lio/grpc/internal/KeepAliveManager$State;->DISCONNECTED:Lio/grpc/internal/KeepAliveManager$State;
iput-object v0, p0, Lio/grpc/internal/KeepAliveManager;->state:Lio/grpc/internal/KeepAliveManager$State;
.line 3
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->shutdownFuture:Ljava/util/concurrent/ScheduledFuture;
const/4 v1, 0x0
if-eqz v0, :cond_15
.line 4
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->shutdownFuture:Ljava/util/concurrent/ScheduledFuture;
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
.line 5
:cond_15
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->pingFuture:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_1e
.line 6
iget-object v0, p0, Lio/grpc/internal/KeepAliveManager;->pingFuture:Ljava/util/concurrent/ScheduledFuture;
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
:try_end_1e
.catchall {:try_start_1 .. :try_end_1e} :catchall_20
.line 7
:cond_1e
monitor-exit p0
return-void
:catchall_20
move-exception v0
monitor-exit p0
throw v0
.end method