ManagedChannelImpl$3.smali
.class Lio/grpc/internal/ManagedChannelImpl$3;
.super Lio/grpc/TransportManager;
.source "ManagedChannelImpl.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lio/grpc/internal/ManagedChannelImpl;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x0
name = null
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"Lio/grpc/TransportManager<",
"Lio/grpc/internal/ClientTransport;",
">;"
}
.end annotation
# instance fields
.field final synthetic this$0:Lio/grpc/internal/ManagedChannelImpl;
# direct methods
.method constructor <init>(Lio/grpc/internal/ManagedChannelImpl;)V
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
invoke-direct {p0}, Lio/grpc/TransportManager;-><init>()V
return-void
.end method
# virtual methods
.method public createFailingTransport(Lio/grpc/Status;)Lio/grpc/internal/ClientTransport;
.registers 3
.line 2
new-instance v0, Lio/grpc/internal/FailingClientTransport;
invoke-direct {v0, p1}, Lio/grpc/internal/FailingClientTransport;-><init>(Lio/grpc/Status;)V
return-object v0
.end method
.method public bridge synthetic createFailingTransport(Lio/grpc/Status;)Ljava/lang/Object;
.registers 2
.line 1
invoke-virtual {p0, p1}, Lio/grpc/internal/ManagedChannelImpl$3;->createFailingTransport(Lio/grpc/Status;)Lio/grpc/internal/ClientTransport;
move-result-object p1
return-object p1
.end method
.method public createInterimTransport()Lio/grpc/TransportManager$InterimTransport;
.registers 3
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Lio/grpc/TransportManager$InterimTransport<",
"Lio/grpc/internal/ClientTransport;",
">;"
}
.end annotation
.line 1
new-instance v0, Lio/grpc/internal/ManagedChannelImpl$InterimTransportImpl;
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
invoke-direct {v0, v1}, Lio/grpc/internal/ManagedChannelImpl$InterimTransportImpl;-><init>(Lio/grpc/internal/ManagedChannelImpl;)V
return-object v0
.end method
.method public createOobTransportProvider(Lio/grpc/EquivalentAddressGroup;Ljava/lang/String;)Lio/grpc/TransportManager$OobTransportProvider;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lio/grpc/EquivalentAddressGroup;",
"Ljava/lang/String;",
")",
"Lio/grpc/TransportManager$OobTransportProvider<",
"Lio/grpc/internal/ClientTransport;",
">;"
}
.end annotation
.line 1
new-instance v0, Lio/grpc/internal/ManagedChannelImpl$OobTransportProviderImpl;
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
invoke-direct {v0, v1, p1, p2}, Lio/grpc/internal/ManagedChannelImpl$OobTransportProviderImpl;-><init>(Lio/grpc/internal/ManagedChannelImpl;Lio/grpc/EquivalentAddressGroup;Ljava/lang/String;)V
return-object v0
.end method
.method public getTransport(Lio/grpc/EquivalentAddressGroup;)Lio/grpc/internal/ClientTransport;
.registers 15
const-string v0, "addressGroup"
.line 2
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 3
iget-object v0, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->lock:Ljava/lang/Object;
invoke-static {v0}, Lio/grpc/internal/ManagedChannelImpl;->access$000(Lio/grpc/internal/ManagedChannelImpl;)Ljava/lang/Object;
move-result-object v0
monitor-enter v0
.line 4
:try_start_c
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->shutdown:Z
invoke-static {v1}, Lio/grpc/internal/ManagedChannelImpl;->access$100(Lio/grpc/internal/ManagedChannelImpl;)Z
move-result v1
if-eqz v1, :cond_1a
.line 5
# getter for: Lio/grpc/internal/ManagedChannelImpl;->SHUTDOWN_TRANSPORT:Lio/grpc/internal/ClientTransport;
invoke-static {}, Lio/grpc/internal/ManagedChannelImpl;->access$1100()Lio/grpc/internal/ClientTransport;
move-result-object p1
monitor-exit v0
return-object p1
.line 6
:cond_1a
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->loadBalancer:Lio/grpc/LoadBalancer;
invoke-static {v1}, Lio/grpc/internal/ManagedChannelImpl;->access$300(Lio/grpc/internal/ManagedChannelImpl;)Lio/grpc/LoadBalancer;
move-result-object v1
if-nez v1, :cond_26
.line 7
sget-object p1, Lio/grpc/internal/ManagedChannelImpl;->IDLE_MODE_TRANSPORT:Lio/grpc/internal/ClientTransport;
monitor-exit v0
return-object p1
.line 8
:cond_26
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->transports:Ljava/util/Map;
invoke-static {v1}, Lio/grpc/internal/ManagedChannelImpl;->access$800(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/Map;
move-result-object v1
invoke-interface {v1, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lio/grpc/internal/TransportSet;
if-nez v1, :cond_a6
.line 9
new-instance v1, Lio/grpc/internal/TransportSet;
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
invoke-virtual {v2}, Lio/grpc/internal/ManagedChannelImpl;->authority()Ljava/lang/String;
move-result-object v4
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->userAgent:Ljava/lang/String;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$1800(Lio/grpc/internal/ManagedChannelImpl;)Ljava/lang/String;
move-result-object v5
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->loadBalancer:Lio/grpc/LoadBalancer;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$300(Lio/grpc/internal/ManagedChannelImpl;)Lio/grpc/LoadBalancer;
move-result-object v6
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
.line 10
# getter for: Lio/grpc/internal/ManagedChannelImpl;->backoffPolicyProvider:Lio/grpc/internal/BackoffPolicy$Provider;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$1900(Lio/grpc/internal/ManagedChannelImpl;)Lio/grpc/internal/BackoffPolicy$Provider;
move-result-object v7
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->transportFactory:Lio/grpc/internal/ClientTransportFactory;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$2000(Lio/grpc/internal/ManagedChannelImpl;)Lio/grpc/internal/ClientTransportFactory;
move-result-object v8
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->scheduledExecutor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$1700(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v9
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->stopwatchSupplier:Lcom/google/common/base/A;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$2100(Lio/grpc/internal/ManagedChannelImpl;)Lcom/google/common/base/A;
move-result-object v10
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
.line 11
# getter for: Lio/grpc/internal/ManagedChannelImpl;->executor:Ljava/util/concurrent/Executor;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$1300(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/concurrent/Executor;
move-result-object v11
new-instance v12, Lio/grpc/internal/ManagedChannelImpl$3$1;
invoke-direct {v12, p0, p1}, Lio/grpc/internal/ManagedChannelImpl$3$1;-><init>(Lio/grpc/internal/ManagedChannelImpl$3;Lio/grpc/EquivalentAddressGroup;)V
move-object v2, v1
move-object v3, p1
invoke-direct/range {v2 .. v12}, Lio/grpc/internal/TransportSet;-><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
.line 12
# getter for: Lio/grpc/internal/ManagedChannelImpl;->log:Ljava/util/logging/Logger;
invoke-static {}, Lio/grpc/internal/ManagedChannelImpl;->access$2300()Ljava/util/logging/Logger;
move-result-object v2
sget-object v3, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
invoke-virtual {v2, v3}, Ljava/util/logging/Logger;->isLoggable(Ljava/util/logging/Level;)Z
move-result v2
if-eqz v2, :cond_9d
.line 13
# getter for: Lio/grpc/internal/ManagedChannelImpl;->log:Ljava/util/logging/Logger;
invoke-static {}, Lio/grpc/internal/ManagedChannelImpl;->access$2300()Ljava/util/logging/Logger;
move-result-object v2
sget-object v3, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;
const-string v4, "[{0}] {1} created for {2}"
const/4 v5, 0x3
new-array v5, v5, [Ljava/lang/Object;
const/4 v6, 0x0
iget-object v7, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
.line 14
invoke-virtual {v7}, Lio/grpc/internal/ManagedChannelImpl;->getLogId()Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x1
invoke-virtual {v1}, Lio/grpc/internal/TransportSet;->getLogId()Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v6
const/4 v6, 0x2
aput-object p1, v5, v6
.line 15
invoke-virtual {v2, v3, v4, v5}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
.line 16
:cond_9d
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->transports:Ljava/util/Map;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$800(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/Map;
move-result-object v2
invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 17
:cond_a6
monitor-exit v0
:try_end_a7
.catchall {:try_start_c .. :try_end_a7} :catchall_ac
.line 18
invoke-virtual {v1}, Lio/grpc/internal/TransportSet;->obtainActiveTransport()Lio/grpc/internal/ClientTransport;
move-result-object p1
return-object p1
:catchall_ac
move-exception p1
.line 19
:try_start_ad
monitor-exit v0
:try_end_ae
.catchall {:try_start_ad .. :try_end_ae} :catchall_ac
throw p1
.end method
.method public bridge synthetic getTransport(Lio/grpc/EquivalentAddressGroup;)Ljava/lang/Object;
.registers 2
.line 1
invoke-virtual {p0, p1}, Lio/grpc/internal/ManagedChannelImpl$3;->getTransport(Lio/grpc/EquivalentAddressGroup;)Lio/grpc/internal/ClientTransport;
move-result-object p1
return-object p1
.end method
.method public makeChannel(Lio/grpc/internal/ClientTransport;)Lio/grpc/Channel;
.registers 6
.line 2
new-instance v0, Lio/grpc/internal/SingleTransportChannel;
iget-object v1, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
.line 3
# getter for: Lio/grpc/internal/ManagedChannelImpl;->executor:Ljava/util/concurrent/Executor;
invoke-static {v1}, Lio/grpc/internal/ManagedChannelImpl;->access$1300(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/concurrent/Executor;
move-result-object v1
iget-object v2, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
# getter for: Lio/grpc/internal/ManagedChannelImpl;->scheduledExecutor:Ljava/util/concurrent/ScheduledExecutorService;
invoke-static {v2}, Lio/grpc/internal/ManagedChannelImpl;->access$1700(Lio/grpc/internal/ManagedChannelImpl;)Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v2
iget-object v3, p0, Lio/grpc/internal/ManagedChannelImpl$3;->this$0:Lio/grpc/internal/ManagedChannelImpl;
invoke-virtual {v3}, Lio/grpc/internal/ManagedChannelImpl;->authority()Ljava/lang/String;
move-result-object v3
invoke-direct {v0, p1, v1, v2, v3}, Lio/grpc/internal/SingleTransportChannel;-><init>(Lio/grpc/internal/ClientTransport;Ljava/util/concurrent/Executor;Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/String;)V
return-object v0
.end method
.method public bridge synthetic makeChannel(Ljava/lang/Object;)Lio/grpc/Channel;
.registers 2
.line 1
check-cast p1, Lio/grpc/internal/ClientTransport;
invoke-virtual {p0, p1}, Lio/grpc/internal/ManagedChannelImpl$3;->makeChannel(Lio/grpc/internal/ClientTransport;)Lio/grpc/Channel;
move-result-object p1
return-object p1
.end method
.method public updateRetainedTransports(Ljava/util/Collection;)V
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/Collection<",
"Lio/grpc/EquivalentAddressGroup;",
">;)V"
}
.end annotation
return-void
.end method