TransportSet.smali
.class final Lio/grpc/internal/TransportSet;
.super Ljava/lang/Object;
.source "TransportSet.java"
# interfaces
.implements Lio/grpc/internal/WithLogId;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lio/grpc/internal/TransportSet$Callback;,
Lio/grpc/internal/TransportSet$TransportListener;,
Lio/grpc/internal/TransportSet$BaseTransportListener;
}
.end annotation
# static fields
.field private static final SHUTDOWN_TRANSPORT:Lio/grpc/internal/ClientTransport;
.field private static final log:Ljava/util/logging/Logger;
# instance fields
.field private volatile activeTransport:Lio/grpc/internal/ManagedClientTransport;
.field private final addressGroup:Lio/grpc/EquivalentAddressGroup;
.field private final appExecutor:Ljava/util/concurrent/Executor;
.field private final authority:Ljava/lang/String;
.field private final backoffPolicyProvider:Lio/grpc/internal/BackoffPolicy$Provider;
.field private final callback:Lio/grpc/internal/TransportSet$Callback;
.field private final connectingTimer:Lcom/google/common/base/y;
.field private final inUseStateAggregator:Lio/grpc/internal/InUseStateAggregator;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lio/grpc/internal/InUseStateAggregator<",
"Lio/grpc/internal/ManagedClientTransport;",
">;"
}
.end annotation
.end field
.field private final loadBalancer:Lio/grpc/LoadBalancer;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lio/grpc/LoadBalancer<",
"Lio/grpc/internal/ClientTransport;",
">;"
}
.end annotation
.end field
.field private final lock:Ljava/lang/Object;
.field private nextAddressIndex:I
.field private pendingTransport:Lio/grpc/internal/ConnectionClientTransport;
.field private reconnectPolicy:Lio/grpc/internal/BackoffPolicy;
.field private reconnectTask:Ljava/util/concurrent/ScheduledFuture;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ScheduledFuture<",
"*>;"
}
.end annotation
.end field
.field private final scheduledExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.field private shutdown:Z
.field private final transportFactory:Lio/grpc/internal/ClientTransportFactory;
.field private final transports:Ljava/util/Collection;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Collection<",
"Lio/grpc/internal/ManagedClientTransport;",
">;"
}
.end annotation
.end field
.field private final userAgent:Ljava/lang/String;
# direct methods
.method static constructor <clinit>()V
.registers 3
.line 1
const-class v0, Lio/grpc/internal/TransportSet;
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/TransportSet;->log:Ljava/util/logging/Logger;
.line 2
new-instance v0, Lio/grpc/internal/FailingClientTransport;
sget-object v1, Lio/grpc/Status;->UNAVAILABLE:Lio/grpc/Status;
const-string v2, "TransportSet is shutdown"
.line 3
invoke-virtual {v1, v2}, Lio/grpc/Status;->withDescription(Ljava/lang/String;)Lio/grpc/Status;
move-result-object v1
invoke-direct {v0, v1}, Lio/grpc/internal/FailingClientTransport;-><init>(Lio/grpc/Status;)V
sput-object v0, Lio/grpc/internal/TransportSet;->SHUTDOWN_TRANSPORT:Lio/grpc/internal/ClientTransport;
return-void
.end method
.method constructor <init>(Lio/grpc/EquivalentAddressGroup;Ljava/lang/String;Ljava/lang/String;Lio/grpc/LoadBalancer;Lio/grpc/internal/BackoffPolicy$Provider;Lio/grpc/internal/ClientTransportFactory;Ljava/util/concurrent/ScheduledExecutorService;Lcom/google/common/base/A;Ljava/util/concurrent/Executor;Lio/grpc/internal/TransportSet$Callback;)V
.registers 12
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/grpc/EquivalentAddressGroup;",
"Ljava/lang/String;",
"Ljava/lang/String;",
"Lio/grpc/LoadBalancer<",
"Lio/grpc/internal/ClientTransport;",
">;",
"Lio/grpc/internal/BackoffPolicy$Provider;",
"Lio/grpc/internal/ClientTransportFactory;",
"Ljava/util/concurrent/ScheduledExecutorService;",
"Lcom/google/common/base/A<",
"Lcom/google/common/base/y;",
">;",
"Ljava/util/concurrent/Executor;",
"Lio/grpc/internal/TransportSet$Callback;",
")V"
}
.end annotation
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lio/grpc/internal/TransportSet;->lock:Ljava/lang/Object;
.line 3
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
.line 4
new-instance v0, Lio/grpc/internal/TransportSet$1;
invoke-direct {v0, p0}, Lio/grpc/internal/TransportSet$1;-><init>(Lio/grpc/internal/TransportSet;)V
iput-object v0, p0, Lio/grpc/internal/TransportSet;->inUseStateAggregator:Lio/grpc/internal/InUseStateAggregator;
const-string v0, "addressGroup"
.line 5
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
check-cast p1, Lio/grpc/EquivalentAddressGroup;
iput-object p1, p0, Lio/grpc/internal/TransportSet;->addressGroup:Lio/grpc/EquivalentAddressGroup;
.line 6
iput-object p2, p0, Lio/grpc/internal/TransportSet;->authority:Ljava/lang/String;
.line 7
iput-object p3, p0, Lio/grpc/internal/TransportSet;->userAgent:Ljava/lang/String;
.line 8
iput-object p4, p0, Lio/grpc/internal/TransportSet;->loadBalancer:Lio/grpc/LoadBalancer;
.line 9
iput-object p5, p0, Lio/grpc/internal/TransportSet;->backoffPolicyProvider:Lio/grpc/internal/BackoffPolicy$Provider;
.line 10
iput-object p6, p0, Lio/grpc/internal/TransportSet;->transportFactory:Lio/grpc/internal/ClientTransportFactory;
.line 11
iput-object p7, p0, Lio/grpc/internal/TransportSet;->scheduledExecutor:Ljava/util/concurrent/ScheduledExecutorService;
.line 12
invoke-interface {p8}, Lcom/google/common/base/A;->get()Ljava/lang/Object;
move-result-object p1
check-cast p1, Lcom/google/common/base/y;
iput-object p1, p0, Lio/grpc/internal/TransportSet;->connectingTimer:Lcom/google/common/base/y;
.line 13
iput-object p9, p0, Lio/grpc/internal/TransportSet;->appExecutor:Ljava/util/concurrent/Executor;
.line 14
iput-object p10, p0, Lio/grpc/internal/TransportSet;->callback:Lio/grpc/internal/TransportSet$Callback;
return-void
.end method
.method static synthetic access$000(Lio/grpc/internal/TransportSet;)Ljava/lang/Object;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->lock:Ljava/lang/Object;
return-object p0
.end method
.method static synthetic access$100(Lio/grpc/internal/TransportSet;)Lio/grpc/internal/TransportSet$Callback;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->callback:Lio/grpc/internal/TransportSet$Callback;
return-object p0
.end method
.method static synthetic access$1002(Lio/grpc/internal/TransportSet;Lio/grpc/internal/BackoffPolicy;)Lio/grpc/internal/BackoffPolicy;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/TransportSet;->reconnectPolicy:Lio/grpc/internal/BackoffPolicy;
return-object p1
.end method
.method static synthetic access$1100(Lio/grpc/internal/TransportSet;)I
.registers 1
.line 1
iget p0, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
return p0
.end method
.method static synthetic access$1102(Lio/grpc/internal/TransportSet;I)I
.registers 2
.line 1
iput p1, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
return p1
.end method
.method static synthetic access$1200(Lio/grpc/internal/TransportSet;)Lio/grpc/internal/ConnectionClientTransport;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->pendingTransport:Lio/grpc/internal/ConnectionClientTransport;
return-object p0
.end method
.method static synthetic access$1202(Lio/grpc/internal/TransportSet;Lio/grpc/internal/ConnectionClientTransport;)Lio/grpc/internal/ConnectionClientTransport;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/TransportSet;->pendingTransport:Lio/grpc/internal/ConnectionClientTransport;
return-object p1
.end method
.method static synthetic access$1300(Lio/grpc/internal/TransportSet;)Lio/grpc/EquivalentAddressGroup;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->addressGroup:Lio/grpc/EquivalentAddressGroup;
return-object p0
.end method
.method static synthetic access$1400(Lio/grpc/internal/TransportSet;)Lio/grpc/LoadBalancer;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->loadBalancer:Lio/grpc/LoadBalancer;
return-object p0
.end method
.method static synthetic access$1500(Lio/grpc/internal/TransportSet;Lio/grpc/internal/DelayedClientTransport;Lio/grpc/Status;)Ljava/lang/Runnable;
.registers 3
.line 1
invoke-direct {p0, p1, p2}, Lio/grpc/internal/TransportSet;->scheduleBackoff(Lio/grpc/internal/DelayedClientTransport;Lio/grpc/Status;)Ljava/lang/Runnable;
move-result-object p0
return-object p0
.end method
.method static synthetic access$202(Lio/grpc/internal/TransportSet;Ljava/util/concurrent/ScheduledFuture;)Ljava/util/concurrent/ScheduledFuture;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
return-object p1
.end method
.method static synthetic access$300(Lio/grpc/internal/TransportSet;Lio/grpc/internal/DelayedClientTransport;)V
.registers 2
.line 1
invoke-direct {p0, p1}, Lio/grpc/internal/TransportSet;->startNewTransport(Lio/grpc/internal/DelayedClientTransport;)V
return-void
.end method
.method static synthetic access$400(Lio/grpc/internal/TransportSet;)Lio/grpc/internal/ManagedClientTransport;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
return-object p0
.end method
.method static synthetic access$402(Lio/grpc/internal/TransportSet;Lio/grpc/internal/ManagedClientTransport;)Lio/grpc/internal/ManagedClientTransport;
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
return-object p1
.end method
.method static synthetic access$500()Ljava/util/logging/Logger;
.registers 1
.line 1
sget-object v0, Lio/grpc/internal/TransportSet;->log:Ljava/util/logging/Logger;
return-object v0
.end method
.method static synthetic access$600(Lio/grpc/internal/TransportSet;)Lio/grpc/internal/InUseStateAggregator;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->inUseStateAggregator:Lio/grpc/internal/InUseStateAggregator;
return-object p0
.end method
.method static synthetic access$700(Lio/grpc/internal/TransportSet;)Ljava/util/Collection;
.registers 1
.line 1
iget-object p0, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
return-object p0
.end method
.method static synthetic access$800(Lio/grpc/internal/TransportSet;)Z
.registers 1
.line 1
iget-boolean p0, p0, Lio/grpc/internal/TransportSet;->shutdown:Z
return p0
.end method
.method static synthetic access$900(Lio/grpc/internal/TransportSet;)V
.registers 1
.line 1
invoke-direct {p0}, Lio/grpc/internal/TransportSet;->cancelReconnectTask()V
return-void
.end method
.method private cancelReconnectTask()V
.registers 3
.line 1
iget-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
if-eqz v0, :cond_b
const/4 v1, 0x0
.line 2
invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
const/4 v0, 0x0
.line 3
iput-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
:cond_b
return-void
.end method
.method private scheduleBackoff(Lio/grpc/internal/DelayedClientTransport;Lio/grpc/Status;)Ljava/lang/Runnable;
.registers 11
.line 1
iget-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
const/4 v1, 0x1
const/4 v2, 0x0
if-nez v0, :cond_8
const/4 v0, 0x1
goto :goto_9
:cond_8
const/4 v0, 0x0
:goto_9
const-string v3, "previous reconnectTask is not done"
invoke-static {v0, v3}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
.line 2
iget-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectPolicy:Lio/grpc/internal/BackoffPolicy;
if-nez v0, :cond_1a
.line 3
iget-object v0, p0, Lio/grpc/internal/TransportSet;->backoffPolicyProvider:Lio/grpc/internal/BackoffPolicy$Provider;
invoke-interface {v0}, Lio/grpc/internal/BackoffPolicy$Provider;->get()Lio/grpc/internal/BackoffPolicy;
move-result-object v0
iput-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectPolicy:Lio/grpc/internal/BackoffPolicy;
.line 4
:cond_1a
iget-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectPolicy:Lio/grpc/internal/BackoffPolicy;
.line 5
invoke-interface {v0}, Lio/grpc/internal/BackoffPolicy;->nextBackoffMillis()J
move-result-wide v3
iget-object v0, p0, Lio/grpc/internal/TransportSet;->connectingTimer:Lcom/google/common/base/y;
sget-object v5, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-virtual {v0, v5}, Lcom/google/common/base/y;->a(Ljava/util/concurrent/TimeUnit;)J
move-result-wide v5
sub-long/2addr v3, v5
.line 6
sget-object v0, Lio/grpc/internal/TransportSet;->log:Ljava/util/logging/Logger;
sget-object v5, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {v0, v5}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result v0
if-eqz v0, :cond_4b
.line 7
sget-object v0, Lio/grpc/internal/TransportSet;->log:Ljava/util/logging/Logger;
sget-object v5, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
const/4 v6, 0x2
new-array v6, v6, [Ljava/lang/Object;
.line 8
invoke-virtual {p0}, Lio/grpc/internal/TransportSet;->getLogId()Ljava/lang/String;
move-result-object v7
aput-object v7, v6, v2
invoke-static {v3, v4}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
aput-object v2, v6, v1
const-string v1, "[{0}] Scheduling backoff for {1} ms"
.line 9
invoke-virtual {v0, v5, v1, v6}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
.line 10
:cond_4b
iget-object v0, p0, Lio/grpc/internal/TransportSet;->scheduledExecutor:Ljava/util/concurrent/ScheduledExecutorService;
new-instance v1, Lio/grpc/internal/LogExceptionRunnable;
new-instance v2, Lio/grpc/internal/TransportSet$1EndOfCurrentBackoff;
invoke-direct {v2, p0, p1}, Lio/grpc/internal/TransportSet$1EndOfCurrentBackoff;-><init>(Lio/grpc/internal/TransportSet;Lio/grpc/internal/DelayedClientTransport;)V
invoke-direct {v1, v2}, Lio/grpc/internal/LogExceptionRunnable;-><init>(Ljava/lang/Runnable;)V
sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v0, v1, v3, v4, v2}, 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/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
.line 11
new-instance v0, Lio/grpc/internal/TransportSet$2;
invoke-direct {v0, p0, p1, p2}, Lio/grpc/internal/TransportSet$2;-><init>(Lio/grpc/internal/TransportSet;Lio/grpc/internal/DelayedClientTransport;Lio/grpc/Status;)V
return-object v0
.end method
.method private startNewTransport(Lio/grpc/internal/DelayedClientTransport;)V
.registers 10
.line 1
iget-object v0, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
const/4 v1, 0x1
const/4 v2, 0x0
if-nez v0, :cond_8
const/4 v0, 0x1
goto :goto_9
:cond_8
const/4 v0, 0x0
:goto_9
const-string v3, "Should have no reconnectTask scheduled"
invoke-static {v0, v3}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
.line 2
iget v0, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
if-nez v0, :cond_1a
.line 3
iget-object v0, p0, Lio/grpc/internal/TransportSet;->connectingTimer:Lcom/google/common/base/y;
invoke-virtual {v0}, Lcom/google/common/base/y;->b()Lcom/google/common/base/y;
invoke-virtual {v0}, Lcom/google/common/base/y;->c()Lcom/google/common/base/y;
.line 4
:cond_1a
iget-object v0, p0, Lio/grpc/internal/TransportSet;->addressGroup:Lio/grpc/EquivalentAddressGroup;
invoke-virtual {v0}, Lio/grpc/EquivalentAddressGroup;->getAddresses()Ljava/util/List;
move-result-object v0
.line 5
iget v3, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
add-int/lit8 v4, v3, 0x1
iput v4, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
invoke-interface {v0, v3}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/net/SocketAddress;
.line 6
iget v4, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
if-lt v4, v0, :cond_36
.line 7
iput v2, p0, Lio/grpc/internal/TransportSet;->nextAddressIndex:I
.line 8
:cond_36
iget-object v0, p0, Lio/grpc/internal/TransportSet;->transportFactory:Lio/grpc/internal/ClientTransportFactory;
iget-object v4, p0, Lio/grpc/internal/TransportSet;->authority:Ljava/lang/String;
iget-object v5, p0, Lio/grpc/internal/TransportSet;->userAgent:Ljava/lang/String;
.line 9
invoke-interface {v0, v3, v4, v5}, Lio/grpc/internal/ClientTransportFactory;->newClientTransport(Ljava/net/SocketAddress;Ljava/lang/String;Ljava/lang/String;)Lio/grpc/internal/ConnectionClientTransport;
move-result-object v0
.line 10
sget-object v4, Lio/grpc/internal/TransportSet;->log:Ljava/util/logging/Logger;
sget-object v5, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {v4, v5}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result v4
if-eqz v4, :cond_65
.line 11
sget-object v4, Lio/grpc/internal/TransportSet;->log:Ljava/util/logging/Logger;
sget-object v5, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
const/4 v6, 0x3
new-array v6, v6, [Ljava/lang/Object;
.line 12
invoke-virtual {p0}, Lio/grpc/internal/TransportSet;->getLogId()Ljava/lang/String;
move-result-object v7
aput-object v7, v6, v2
invoke-interface {v0}, Lio/grpc/internal/WithLogId;->getLogId()Ljava/lang/String;
move-result-object v2
aput-object v2, v6, v1
const/4 v1, 0x2
aput-object v3, v6, v1
const-string v1, "[{0}] Created {1} for {2}"
.line 13
invoke-virtual {v4, v5, v1, v6}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
.line 14
:cond_65
iput-object v0, p0, Lio/grpc/internal/TransportSet;->pendingTransport:Lio/grpc/internal/ConnectionClientTransport;
.line 15
iget-object v1, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
invoke-interface {v1, v0}, Ljava/util/Collection;->add(Ljava/lang/Object;)Z
.line 16
new-instance v1, Lio/grpc/internal/TransportSet$TransportListener;
invoke-direct {v1, p0, v0, p1, v3}, Lio/grpc/internal/TransportSet$TransportListener;-><init>(Lio/grpc/internal/TransportSet;Lio/grpc/internal/ManagedClientTransport;Lio/grpc/internal/DelayedClientTransport;Ljava/net/SocketAddress;)V
invoke-interface {v0, v1}, Lio/grpc/internal/ManagedClientTransport;->start(Lio/grpc/internal/ManagedClientTransport$Listener;)V
return-void
.end method
# virtual methods
.method public getLogId()Ljava/lang/String;
.registers 2
.line 1
invoke-static {p0}, Lio/grpc/internal/GrpcUtil;->getLogId(Lio/grpc/internal/WithLogId;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method final obtainActiveTransport()Lio/grpc/internal/ClientTransport;
.registers 4
.line 1
iget-object v0, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
if-eqz v0, :cond_5
return-object v0
.line 2
:cond_5
iget-object v0, p0, Lio/grpc/internal/TransportSet;->lock:Ljava/lang/Object;
monitor-enter v0
.line 3
:try_start_8
iget-object v1, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
if-nez v1, :cond_2d
.line 4
iget-boolean v1, p0, Lio/grpc/internal/TransportSet;->shutdown:Z
if-eqz v1, :cond_14
.line 5
sget-object v1, Lio/grpc/internal/TransportSet;->SHUTDOWN_TRANSPORT:Lio/grpc/internal/ClientTransport;
monitor-exit v0
return-object v1
.line 6
:cond_14
new-instance v1, Lio/grpc/internal/DelayedClientTransport;
iget-object v2, p0, Lio/grpc/internal/TransportSet;->appExecutor:Ljava/util/concurrent/Executor;
invoke-direct {v1, v2}, Lio/grpc/internal/DelayedClientTransport;-><init>(Ljava/util/concurrent/Executor;)V
.line 7
iget-object v2, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
invoke-interface {v2, v1}, Ljava/util/Collection;->add(Ljava/lang/Object;)Z
.line 8
new-instance v2, Lio/grpc/internal/TransportSet$BaseTransportListener;
invoke-direct {v2, p0, v1}, Lio/grpc/internal/TransportSet$BaseTransportListener;-><init>(Lio/grpc/internal/TransportSet;Lio/grpc/internal/ManagedClientTransport;)V
invoke-virtual {v1, v2}, Lio/grpc/internal/DelayedClientTransport;->start(Lio/grpc/internal/ManagedClientTransport$Listener;)V
.line 9
iput-object v1, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
.line 10
invoke-direct {p0, v1}, Lio/grpc/internal/TransportSet;->startNewTransport(Lio/grpc/internal/DelayedClientTransport;)V
.line 11
:cond_2d
iget-object v1, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
monitor-exit v0
return-object v1
:catchall_31
move-exception v1
.line 12
monitor-exit v0
:try_end_33
.catchall {:try_start_8 .. :try_end_33} :catchall_31
throw v1
.end method
.method final shutdown()V
.registers 7
.line 1
iget-object v0, p0, Lio/grpc/internal/TransportSet;->lock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-boolean v1, p0, Lio/grpc/internal/TransportSet;->shutdown:Z
if-eqz v1, :cond_9
.line 3
monitor-exit v0
return-void
:cond_9
const/4 v1, 0x1
.line 4
iput-boolean v1, p0, Lio/grpc/internal/TransportSet;->shutdown:Z
.line 5
iget-object v2, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
.line 6
iget-object v3, p0, Lio/grpc/internal/TransportSet;->pendingTransport:Lio/grpc/internal/ConnectionClientTransport;
const/4 v4, 0x0
.line 7
iput-object v4, p0, Lio/grpc/internal/TransportSet;->activeTransport:Lio/grpc/internal/ManagedClientTransport;
.line 8
iget-object v4, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
invoke-interface {v4}, Ljava/util/Collection;->isEmpty()Z
move-result v4
const/4 v5, 0x0
if-eqz v4, :cond_27
.line 9
iget-object v4, p0, Lio/grpc/internal/TransportSet;->reconnectTask:Ljava/util/concurrent/ScheduledFuture;
if-nez v4, :cond_21
const/4 v5, 0x1
:cond_21
const-string v4, "Should have no reconnectTask scheduled"
invoke-static {v5, v4}, Lcom/google/common/base/r;->b(ZLjava/lang/Object;)V
goto :goto_28
:cond_27
const/4 v1, 0x0
.line 10
:goto_28
monitor-exit v0
:try_end_29
.catchall {:try_start_3 .. :try_end_29} :catchall_3b
if-eqz v2, :cond_2e
.line 11
invoke-interface {v2}, Lio/grpc/internal/ManagedClientTransport;->shutdown()V
:cond_2e
if-eqz v3, :cond_33
.line 12
invoke-interface {v3}, Lio/grpc/internal/ManagedClientTransport;->shutdown()V
:cond_33
if-eqz v1, :cond_3a
.line 13
iget-object v0, p0, Lio/grpc/internal/TransportSet;->callback:Lio/grpc/internal/TransportSet$Callback;
invoke-virtual {v0, p0}, Lio/grpc/internal/TransportSet$Callback;->onTerminated(Lio/grpc/internal/TransportSet;)V
:cond_3a
return-void
:catchall_3b
move-exception v1
.line 14
:try_start_3c
monitor-exit v0
:try_end_3d
.catchall {:try_start_3c .. :try_end_3d} :catchall_3b
throw v1
.end method
.method shutdownNow(Lio/grpc/Status;)V
.registers 5
.line 1
invoke-virtual {p0}, Lio/grpc/internal/TransportSet;->shutdown()V
.line 2
iget-object v0, p0, Lio/grpc/internal/TransportSet;->lock:Ljava/lang/Object;
monitor-enter v0
.line 3
:try_start_6
new-instance v1, Ljava/util/ArrayList;
iget-object v2, p0, Lio/grpc/internal/TransportSet;->transports:Ljava/util/Collection;
invoke-direct {v1, v2}, Ljava/util/ArrayList;-><init>(Ljava/util/Collection;)V
.line 4
monitor-exit v0
:try_end_e
.catchall {:try_start_6 .. :try_end_e} :catchall_23
.line 5
invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_12
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_22
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lio/grpc/internal/ManagedClientTransport;
.line 6
invoke-interface {v1, p1}, Lio/grpc/internal/ManagedClientTransport;->shutdownNow(Lio/grpc/Status;)V
goto :goto_12
:cond_22
return-void
:catchall_23
move-exception p1
.line 7
:try_start_24
monitor-exit v0
:try_end_25
.catchall {:try_start_24 .. :try_end_25} :catchall_23
goto :goto_27
:goto_26
throw p1
:goto_27
goto :goto_26
.end method