StreamAllocation.smali
.class public final Lokhttp3/internal/connection/StreamAllocation;
.super Ljava/lang/Object;
.source "StreamAllocation.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lokhttp3/internal/connection/StreamAllocation$StreamAllocationReference;
}
.end annotation
# static fields
.field static final synthetic $assertionsDisabled:Z
# instance fields
.field public final address:Lokhttp3/Address;
.field public final call:Lokhttp3/Call;
.field private final callStackTrace:Ljava/lang/Object;
.field private canceled:Z
.field private codec:Lokhttp3/internal/http/HttpCodec;
.field private connection:Lokhttp3/internal/connection/RealConnection;
.field private final connectionPool:Lokhttp3/ConnectionPool;
.field public final eventListener:Lokhttp3/EventListener;
.field private refusedStreamCount:I
.field private released:Z
.field private reportedAcquired:Z
.field private route:Lokhttp3/Route;
.field private routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
.field private final routeSelector:Lokhttp3/internal/connection/RouteSelector;
# direct methods
.method static constructor <clinit>()V
.registers 0
.line 77
return-void
.end method
.method public constructor <init>(Lokhttp3/ConnectionPool;Lokhttp3/Address;Lokhttp3/Call;Lokhttp3/EventListener;Ljava/lang/Object;)V
.registers 8
.param p1, "connectionPool" # Lokhttp3/ConnectionPool;
.param p2, "address" # Lokhttp3/Address;
.param p3, "call" # Lokhttp3/Call;
.param p4, "eventListener" # Lokhttp3/EventListener;
.param p5, "callStackTrace" # Ljava/lang/Object;
.line 96
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 97
iput-object p1, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
.line 98
iput-object p2, p0, Lokhttp3/internal/connection/StreamAllocation;->address:Lokhttp3/Address;
.line 99
iput-object p3, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
.line 100
iput-object p4, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
.line 101
new-instance v0, Lokhttp3/internal/connection/RouteSelector;
invoke-direct {p0}, Lokhttp3/internal/connection/StreamAllocation;->routeDatabase()Lokhttp3/internal/connection/RouteDatabase;
move-result-object v1
invoke-direct {v0, p2, v1, p3, p4}, Lokhttp3/internal/connection/RouteSelector;-><init>(Lokhttp3/Address;Lokhttp3/internal/connection/RouteDatabase;Lokhttp3/Call;Lokhttp3/EventListener;)V
iput-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->routeSelector:Lokhttp3/internal/connection/RouteSelector;
.line 102
iput-object p5, p0, Lokhttp3/internal/connection/StreamAllocation;->callStackTrace:Ljava/lang/Object;
.line 103
return-void
.end method
.method private deallocate(ZZZ)Ljava/net/Socket;
.registers 9
.param p1, "noNewStreams" # Z
.param p2, "released" # Z
.param p3, "streamFinished" # Z
.line 382
nop
.line 384
const/4 v0, 0x0
if-eqz p3, :cond_6
.line 385
iput-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
.line 387
:cond_6
const/4 v1, 0x1
if-eqz p2, :cond_b
.line 388
iput-boolean v1, p0, Lokhttp3/internal/connection/StreamAllocation;->released:Z
.line 390
:cond_b
const/4 v2, 0x0
.line 391
.local v2, "socket":Ljava/net/Socket;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v3, :cond_4e
.line 392
if-eqz p1, :cond_14
.line 393
iput-boolean v1, v3, Lokhttp3/internal/connection/RealConnection;->noNewStreams:Z
.line 395
:cond_14
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
if-nez v1, :cond_4e
iget-boolean v1, p0, Lokhttp3/internal/connection/StreamAllocation;->released:Z
if-nez v1, :cond_22
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget-boolean v1, v1, Lokhttp3/internal/connection/RealConnection;->noNewStreams:Z
if-eqz v1, :cond_4e
.line 396
:cond_22
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
invoke-direct {p0, v1}, Lokhttp3/internal/connection/StreamAllocation;->release(Lokhttp3/internal/connection/RealConnection;)V
.line 397
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget-object v1, v1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->isEmpty()Z
move-result v1
if-eqz v1, :cond_4c
.line 398
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v3
iput-wide v3, v1, Lokhttp3/internal/connection/RealConnection;->idleAtNanos:J
.line 399
sget-object v1, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
invoke-virtual {v1, v3, v4}, Lokhttp3/internal/Internal;->connectionBecameIdle(Lokhttp3/ConnectionPool;Lokhttp3/internal/connection/RealConnection;)Z
move-result v1
if-eqz v1, :cond_4c
.line 400
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
invoke-virtual {v1}, Lokhttp3/internal/connection/RealConnection;->socket()Ljava/net/Socket;
move-result-object v1
move-object v2, v1
.line 403
:cond_4c
iput-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 406
:cond_4e
return-object v2
.end method
.method private findConnection(IIIIZ)Lokhttp3/internal/connection/RealConnection;
.registers 24
.param p1, "connectTimeout" # I
.param p2, "readTimeout" # I
.param p3, "writeTimeout" # I
.param p4, "pingIntervalMillis" # I
.param p5, "connectionRetryEnabled" # Z
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 162
move-object/from16 v1, p0
const/4 v2, 0x0
.line 163
.local v2, "foundPooledConnection":Z
const/4 v3, 0x0
.line 164
.local v3, "result":Lokhttp3/internal/connection/RealConnection;
const/4 v4, 0x0
.line 167
.local v4, "selectedRoute":Lokhttp3/Route;
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v5
.line 168
:try_start_8
iget-boolean v0, v1, Lokhttp3/internal/connection/StreamAllocation;->released:Z
if-nez v0, :cond_13a
.line 169
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
if-nez v0, :cond_132
.line 170
iget-boolean v0, v1, Lokhttp3/internal/connection/StreamAllocation;->canceled:Z
if-nez v0, :cond_12a
.line 174
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 175
.local v0, "releasedConnection":Lokhttp3/Connection;
invoke-direct/range {p0 .. p0}, Lokhttp3/internal/connection/StreamAllocation;->releaseIfNoNewStreams()Ljava/net/Socket;
move-result-object v6
.line 176
.local v6, "toClose":Ljava/net/Socket;
iget-object v7, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v7, :cond_22
.line 178
iget-object v7, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
move-object v3, v7
.line 179
const/4 v0, 0x0
.line 181
:cond_22
iget-boolean v7, v1, Lokhttp3/internal/connection/StreamAllocation;->reportedAcquired:Z
if-nez v7, :cond_29
.line 183
const/4 v0, 0x0
move-object v7, v0
goto :goto_2a
.line 181
:cond_29
move-object v7, v0
.line 186
.end local v0 # "releasedConnection":Lokhttp3/Connection;
.local v7, "releasedConnection":Lokhttp3/Connection;
:goto_2a
if-nez v3, :cond_42
.line 188
sget-object v0, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v8, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
iget-object v9, v1, Lokhttp3/internal/connection/StreamAllocation;->address:Lokhttp3/Address;
const/4 v10, 0x0
invoke-virtual {v0, v8, v9, v1, v10}, Lokhttp3/internal/Internal;->get(Lokhttp3/ConnectionPool;Lokhttp3/Address;Lokhttp3/internal/connection/StreamAllocation;Lokhttp3/Route;)Lokhttp3/internal/connection/RealConnection;
.line 189
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v0, :cond_3f
.line 190
const/4 v2, 0x1
.line 191
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
move-object v3, v0
.end local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.local v0, "result":Lokhttp3/internal/connection/RealConnection;
goto :goto_42
.line 193
.end local v0 # "result":Lokhttp3/internal/connection/RealConnection;
.restart local v3 # "result":Lokhttp3/internal/connection/RealConnection;
:cond_3f
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
move-object v4, v0
.line 196
:cond_42
:goto_42
monitor-exit v5
:try_end_43
.catchall {:try_start_8 .. :try_end_43} :catchall_142
.line 197
invoke-static {v6}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 199
if-eqz v7, :cond_4f
.line 200
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v5, v7}, Lokhttp3/EventListener;->connectionReleased(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 202
:cond_4f
if-eqz v2, :cond_58
.line 203
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v5, v3}, Lokhttp3/EventListener;->connectionAcquired(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 205
:cond_58
if-eqz v3, :cond_5b
.line 207
return-object v3
.line 211
:cond_5b
const/4 v0, 0x0
.line 212
.local v0, "newRouteSelection":Z
if-nez v4, :cond_73
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
if-eqz v5, :cond_68
invoke-virtual {v5}, Lokhttp3/internal/connection/RouteSelector$Selection;->hasNext()Z
move-result v5
if-nez v5, :cond_73
.line 213
:cond_68
const/4 v0, 0x1
.line 214
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->routeSelector:Lokhttp3/internal/connection/RouteSelector;
invoke-virtual {v5}, Lokhttp3/internal/connection/RouteSelector;->next()Lokhttp3/internal/connection/RouteSelector$Selection;
move-result-object v5
iput-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
move v8, v0
goto :goto_74
.line 217
:cond_73
move v8, v0
.end local v0 # "newRouteSelection":Z
.local v8, "newRouteSelection":Z
:goto_74
iget-object v9, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v9
.line 218
:try_start_77
iget-boolean v0, v1, Lokhttp3/internal/connection/StreamAllocation;->canceled:Z
if-nez v0, :cond_11f
.line 220
if-eqz v8, :cond_a7
.line 223
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
invoke-virtual {v0}, Lokhttp3/internal/connection/RouteSelector$Selection;->getAll()Ljava/util/List;
move-result-object v0
.line 224
.local v0, "routes":Ljava/util/List;, "Ljava/util/List<Lokhttp3/Route;>;"
const/4 v5, 0x0
.local v5, "i":I
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v10
.local v10, "size":I
:goto_88
if-ge v5, v10, :cond_a7
.line 225
invoke-interface {v0, v5}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v11
check-cast v11, Lokhttp3/Route;
.line 226
.local v11, "route":Lokhttp3/Route;
sget-object v12, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v13, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
iget-object v14, v1, Lokhttp3/internal/connection/StreamAllocation;->address:Lokhttp3/Address;
invoke-virtual {v12, v13, v14, v1, v11}, Lokhttp3/internal/Internal;->get(Lokhttp3/ConnectionPool;Lokhttp3/Address;Lokhttp3/internal/connection/StreamAllocation;Lokhttp3/Route;)Lokhttp3/internal/connection/RealConnection;
.line 227
iget-object v12, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v12, :cond_a4
.line 228
const/4 v2, 0x1
.line 229
iget-object v12, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
move-object v3, v12
.line 230
iput-object v11, v1, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
.line 231
goto :goto_a7
.line 224
.end local v11 # "route":Lokhttp3/Route;
:cond_a4
add-int/lit8 v5, v5, 0x1
goto :goto_88
.line 236
.end local v0 # "routes":Ljava/util/List;, "Ljava/util/List<Lokhttp3/Route;>;"
.end local v5 # "i":I
.end local v10 # "size":I
:cond_a7
:goto_a7
if-nez v2, :cond_c2
.line 237
if-nez v4, :cond_b2
.line 238
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
invoke-virtual {v0}, Lokhttp3/internal/connection/RouteSelector$Selection;->next()Lokhttp3/Route;
move-result-object v0
move-object v4, v0
.line 243
:cond_b2
iput-object v4, v1, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
.line 244
const/4 v0, 0x0
iput v0, v1, Lokhttp3/internal/connection/StreamAllocation;->refusedStreamCount:I
.line 245
new-instance v5, Lokhttp3/internal/connection/RealConnection;
iget-object v10, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
invoke-direct {v5, v10, v4}, Lokhttp3/internal/connection/RealConnection;-><init>(Lokhttp3/ConnectionPool;Lokhttp3/Route;)V
move-object v3, v5
.line 246
invoke-virtual {v1, v3, v0}, Lokhttp3/internal/connection/StreamAllocation;->acquire(Lokhttp3/internal/connection/RealConnection;Z)V
.line 248
:cond_c2
monitor-exit v9
:try_end_c3
.catchall {:try_start_77 .. :try_end_c3} :catchall_127
.line 251
if-eqz v2, :cond_cd
.line 252
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v5, v3}, Lokhttp3/EventListener;->connectionAcquired(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 253
return-object v3
.line 257
:cond_cd
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
iget-object v5, v1, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
move-object v10, v3
move/from16 v11, p1
move/from16 v12, p2
move/from16 v13, p3
move/from16 v14, p4
move/from16 v15, p5
move-object/from16 v16, v0
move-object/from16 v17, v5
invoke-virtual/range {v10 .. v17}, Lokhttp3/internal/connection/RealConnection;->connect(IIIIZLokhttp3/Call;Lokhttp3/EventListener;)V
.line 259
invoke-direct/range {p0 .. p0}, Lokhttp3/internal/connection/StreamAllocation;->routeDatabase()Lokhttp3/internal/connection/RouteDatabase;
move-result-object v0
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->route()Lokhttp3/Route;
move-result-object v5
invoke-virtual {v0, v5}, Lokhttp3/internal/connection/RouteDatabase;->connected(Lokhttp3/Route;)V
.line 261
const/4 v5, 0x0
.line 262
.local v5, "socket":Ljava/net/Socket;
iget-object v10, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v10
.line 263
const/4 v0, 0x1
:try_start_f3
iput-boolean v0, v1, Lokhttp3/internal/connection/StreamAllocation;->reportedAcquired:Z
.line 266
sget-object v0, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v9, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
invoke-virtual {v0, v9, v3}, Lokhttp3/internal/Internal;->put(Lokhttp3/ConnectionPool;Lokhttp3/internal/connection/RealConnection;)V
.line 270
invoke-virtual {v3}, Lokhttp3/internal/connection/RealConnection;->isMultiplexed()Z
move-result v0
if-eqz v0, :cond_110
.line 271
sget-object v0, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v9, v1, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
iget-object v11, v1, Lokhttp3/internal/connection/StreamAllocation;->address:Lokhttp3/Address;
invoke-virtual {v0, v9, v11, v1}, Lokhttp3/internal/Internal;->deduplicate(Lokhttp3/ConnectionPool;Lokhttp3/Address;Lokhttp3/internal/connection/StreamAllocation;)Ljava/net/Socket;
move-result-object v0
move-object v5, v0
.line 272
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
move-object v3, v0
.line 274
:cond_110
monitor-exit v10
:try_end_111
.catchall {:try_start_f3 .. :try_end_111} :catchall_11c
.line 275
invoke-static {v5}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 277
iget-object v0, v1, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v9, v1, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v9, v3}, Lokhttp3/EventListener;->connectionAcquired(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 278
return-object v3
.line 274
:catchall_11c
move-exception v0
:try_start_11d
monitor-exit v10
:try_end_11e
.catchall {:try_start_11d .. :try_end_11e} :catchall_11c
throw v0
.line 218
.end local v5 # "socket":Ljava/net/Socket;
:cond_11f
:try_start_11f
new-instance v0, Ljava/io/IOException;
const-string v5, "Canceled"
invoke-direct {v0, v5}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
.end local v2 # "foundPooledConnection":Z
.end local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.end local v4 # "selectedRoute":Lokhttp3/Route;
.end local v6 # "toClose":Ljava/net/Socket;
.end local v7 # "releasedConnection":Lokhttp3/Connection;
.end local v8 # "newRouteSelection":Z
.end local p1 # "connectTimeout":I
.end local p2 # "readTimeout":I
.end local p3 # "writeTimeout":I
.end local p4 # "pingIntervalMillis":I
.end local p5 # "connectionRetryEnabled":Z
throw v0
.line 248
.restart local v2 # "foundPooledConnection":Z
.restart local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.restart local v4 # "selectedRoute":Lokhttp3/Route;
.restart local v6 # "toClose":Ljava/net/Socket;
.restart local v7 # "releasedConnection":Lokhttp3/Connection;
.restart local v8 # "newRouteSelection":Z
.restart local p1 # "connectTimeout":I
.restart local p2 # "readTimeout":I
.restart local p3 # "writeTimeout":I
.restart local p4 # "pingIntervalMillis":I
.restart local p5 # "connectionRetryEnabled":Z
:catchall_127
move-exception v0
monitor-exit v9
:try_end_129
.catchall {:try_start_11f .. :try_end_129} :catchall_127
throw v0
.line 170
.end local v6 # "toClose":Ljava/net/Socket;
.end local v7 # "releasedConnection":Lokhttp3/Connection;
.end local v8 # "newRouteSelection":Z
:cond_12a
:try_start_12a
new-instance v0, Ljava/io/IOException;
const-string v6, "Canceled"
invoke-direct {v0, v6}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
.end local v2 # "foundPooledConnection":Z
.end local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.end local v4 # "selectedRoute":Lokhttp3/Route;
.end local p1 # "connectTimeout":I
.end local p2 # "readTimeout":I
.end local p3 # "writeTimeout":I
.end local p4 # "pingIntervalMillis":I
.end local p5 # "connectionRetryEnabled":Z
throw v0
.line 169
.restart local v2 # "foundPooledConnection":Z
.restart local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.restart local v4 # "selectedRoute":Lokhttp3/Route;
.restart local p1 # "connectTimeout":I
.restart local p2 # "readTimeout":I
.restart local p3 # "writeTimeout":I
.restart local p4 # "pingIntervalMillis":I
.restart local p5 # "connectionRetryEnabled":Z
:cond_132
new-instance v0, Ljava/lang/IllegalStateException;
const-string v6, "codec != null"
invoke-direct {v0, v6}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
.end local v2 # "foundPooledConnection":Z
.end local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.end local v4 # "selectedRoute":Lokhttp3/Route;
.end local p1 # "connectTimeout":I
.end local p2 # "readTimeout":I
.end local p3 # "writeTimeout":I
.end local p4 # "pingIntervalMillis":I
.end local p5 # "connectionRetryEnabled":Z
throw v0
.line 168
.restart local v2 # "foundPooledConnection":Z
.restart local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.restart local v4 # "selectedRoute":Lokhttp3/Route;
.restart local p1 # "connectTimeout":I
.restart local p2 # "readTimeout":I
.restart local p3 # "writeTimeout":I
.restart local p4 # "pingIntervalMillis":I
.restart local p5 # "connectionRetryEnabled":Z
:cond_13a
new-instance v0, Ljava/lang/IllegalStateException;
const-string v6, "released"
invoke-direct {v0, v6}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
.end local v2 # "foundPooledConnection":Z
.end local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.end local v4 # "selectedRoute":Lokhttp3/Route;
.end local p1 # "connectTimeout":I
.end local p2 # "readTimeout":I
.end local p3 # "writeTimeout":I
.end local p4 # "pingIntervalMillis":I
.end local p5 # "connectionRetryEnabled":Z
throw v0
.line 196
.restart local v2 # "foundPooledConnection":Z
.restart local v3 # "result":Lokhttp3/internal/connection/RealConnection;
.restart local v4 # "selectedRoute":Lokhttp3/Route;
.restart local p1 # "connectTimeout":I
.restart local p2 # "readTimeout":I
.restart local p3 # "writeTimeout":I
.restart local p4 # "pingIntervalMillis":I
.restart local p5 # "connectionRetryEnabled":Z
:catchall_142
move-exception v0
monitor-exit v5
:try_end_144
.catchall {:try_start_12a .. :try_end_144} :catchall_142
goto :goto_146
:goto_145
throw v0
:goto_146
goto :goto_145
.end method
.method private findHealthyConnection(IIIIZZ)Lokhttp3/internal/connection/RealConnection;
.registers 10
.param p1, "connectTimeout" # I
.param p2, "readTimeout" # I
.param p3, "writeTimeout" # I
.param p4, "pingIntervalMillis" # I
.param p5, "connectionRetryEnabled" # Z
.param p6, "doExtensiveHealthChecks" # Z
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 135
:goto_0
invoke-direct/range {p0 .. p5}, Lokhttp3/internal/connection/StreamAllocation;->findConnection(IIIIZ)Lokhttp3/internal/connection/RealConnection;
move-result-object v0
.line 139
.local v0, "candidate":Lokhttp3/internal/connection/RealConnection;
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v1
.line 140
:try_start_7
iget v2, v0, Lokhttp3/internal/connection/RealConnection;->successCount:I
if-nez v2, :cond_d
.line 141
monitor-exit v1
return-object v0
.line 143
:cond_d
monitor-exit v1
:try_end_e
.catchall {:try_start_7 .. :try_end_e} :catchall_19
.line 147
invoke-virtual {v0, p6}, Lokhttp3/internal/connection/RealConnection;->isHealthy(Z)Z
move-result v1
if-nez v1, :cond_18
.line 148
invoke-virtual {p0}, Lokhttp3/internal/connection/StreamAllocation;->noNewStreams()V
.line 149
goto :goto_0
.line 152
:cond_18
return-object v0
.line 143
:catchall_19
move-exception v2
:try_start_1a
monitor-exit v1
:try_end_1b
.catchall {:try_start_1a .. :try_end_1b} :catchall_19
goto :goto_1d
:goto_1c
throw v2
:goto_1d
goto :goto_1c
.end method
.method private release(Lokhttp3/internal/connection/RealConnection;)V
.registers 6
.param p1, "connection" # Lokhttp3/internal/connection/RealConnection;
.line 482
const/4 v0, 0x0
.local v0, "i":I
iget-object v1, p1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
.local v1, "size":I
:goto_7
if-ge v0, v1, :cond_20
.line 483
iget-object v2, p1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v2, v0}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/lang/ref/Reference;
.line 484
.local v2, "reference":Ljava/lang/ref/Reference;, "Ljava/lang/ref/Reference<Lokhttp3/internal/connection/StreamAllocation;>;"
invoke-virtual {v2}, Ljava/lang/ref/Reference;->get()Ljava/lang/Object;
move-result-object v3
if-ne v3, p0, :cond_1d
.line 485
iget-object v3, p1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v3, v0}, Ljava/util/List;->remove(I)Ljava/lang/Object;
.line 486
return-void
.line 482
.end local v2 # "reference":Ljava/lang/ref/Reference;, "Ljava/lang/ref/Reference<Lokhttp3/internal/connection/StreamAllocation;>;"
:cond_1d
add-int/lit8 v0, v0, 0x1
goto :goto_7
.line 489
.end local v0 # "i":I
.end local v1 # "size":I
:cond_20
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
goto :goto_27
:goto_26
throw v0
:goto_27
goto :goto_26
.end method
.method private releaseIfNoNewStreams()Ljava/net/Socket;
.registers 4
.line 288
nop
.line 289
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 290
.local v0, "allocatedConnection":Lokhttp3/internal/connection/RealConnection;
if-eqz v0, :cond_10
iget-boolean v1, v0, Lokhttp3/internal/connection/RealConnection;->noNewStreams:Z
if-eqz v1, :cond_10
.line 291
const/4 v1, 0x1
const/4 v2, 0x0
invoke-direct {p0, v2, v2, v1}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v1
return-object v1
.line 293
:cond_10
const/4 v1, 0x0
return-object v1
.end method
.method private routeDatabase()Lokhttp3/internal/connection/RouteDatabase;
.registers 3
.line 333
sget-object v0, Lokhttp3/internal/Internal;->instance:Lokhttp3/internal/Internal;
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
invoke-virtual {v0, v1}, Lokhttp3/internal/Internal;->routeDatabase(Lokhttp3/ConnectionPool;)Lokhttp3/internal/connection/RouteDatabase;
move-result-object v0
return-object v0
.end method
# virtual methods
.method public acquire(Lokhttp3/internal/connection/RealConnection;Z)V
.registers 6
.param p1, "connection" # Lokhttp3/internal/connection/RealConnection;
.param p2, "reportedAcquired" # Z
.line 472
nop
.line 473
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-nez v0, :cond_16
.line 475
iput-object p1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 476
iput-boolean p2, p0, Lokhttp3/internal/connection/StreamAllocation;->reportedAcquired:Z
.line 477
iget-object v0, p1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
new-instance v1, Lokhttp3/internal/connection/StreamAllocation$StreamAllocationReference;
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->callStackTrace:Ljava/lang/Object;
invoke-direct {v1, p0, v2}, Lokhttp3/internal/connection/StreamAllocation$StreamAllocationReference;-><init>(Lokhttp3/internal/connection/StreamAllocation;Ljava/lang/Object;)V
invoke-interface {v0, v1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 478
return-void
.line 473
:cond_16
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
throw v0
.end method
.method public cancel()V
.registers 4
.line 412
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 413
const/4 v1, 0x1
:try_start_4
iput-boolean v1, p0, Lokhttp3/internal/connection/StreamAllocation;->canceled:Z
.line 414
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
.line 415
.local v1, "codecToCancel":Lokhttp3/internal/http/HttpCodec;
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 416
.local v2, "connectionToCancel":Lokhttp3/internal/connection/RealConnection;
monitor-exit v0
:try_end_b
.catchall {:try_start_4 .. :try_end_b} :catchall_17
.line 417
if-eqz v1, :cond_11
.line 418
invoke-interface {v1}, Lokhttp3/internal/http/HttpCodec;->cancel()V
goto :goto_16
.line 419
:cond_11
if-eqz v2, :cond_16
.line 420
invoke-virtual {v2}, Lokhttp3/internal/connection/RealConnection;->cancel()V
.line 422
:cond_16
:goto_16
return-void
.line 416
.end local v1 # "codecToCancel":Lokhttp3/internal/http/HttpCodec;
.end local v2 # "connectionToCancel":Lokhttp3/internal/connection/RealConnection;
:catchall_17
move-exception v1
:try_start_18
monitor-exit v0
:try_end_19
.catchall {:try_start_18 .. :try_end_19} :catchall_17
throw v1
.end method
.method public codec()Lokhttp3/internal/http/HttpCodec;
.registers 3
.line 327
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 328
:try_start_3
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
monitor-exit v0
return-object v1
.line 329
:catchall_7
move-exception v1
monitor-exit v0
:try_end_9
.catchall {:try_start_3 .. :try_end_9} :catchall_7
throw v1
.end method
.method public declared-synchronized connection()Lokhttp3/internal/connection/RealConnection;
.registers 2
monitor-enter p0
.line 341
:try_start_1
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return-object v0
.end local p0 # "this":Lokhttp3/internal/connection/StreamAllocation;
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public hasMoreRoutes()Z
.registers 2
.line 516
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
if-nez v0, :cond_19
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->routeSelection:Lokhttp3/internal/connection/RouteSelector$Selection;
if-eqz v0, :cond_e
.line 517
invoke-virtual {v0}, Lokhttp3/internal/connection/RouteSelector$Selection;->hasNext()Z
move-result v0
if-nez v0, :cond_19
:cond_e
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->routeSelector:Lokhttp3/internal/connection/RouteSelector;
.line 518
invoke-virtual {v0}, Lokhttp3/internal/connection/RouteSelector;->hasNext()Z
move-result v0
if-eqz v0, :cond_17
goto :goto_19
:cond_17
const/4 v0, 0x0
goto :goto_1a
:cond_19
:goto_19
const/4 v0, 0x1
.line 516
:goto_1a
return v0
.end method
.method public newStream(Lokhttp3/OkHttpClient;Lokhttp3/Interceptor$Chain;Z)Lokhttp3/internal/http/HttpCodec;
.registers 16
.param p1, "client" # Lokhttp3/OkHttpClient;
.param p2, "chain" # Lokhttp3/Interceptor$Chain;
.param p3, "doExtensiveHealthChecks" # Z
.line 107
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->connectTimeoutMillis()I
move-result v7
.line 108
.local v7, "connectTimeout":I
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->readTimeoutMillis()I
move-result v8
.line 109
.local v8, "readTimeout":I
invoke-interface {p2}, Lokhttp3/Interceptor$Chain;->writeTimeoutMillis()I
move-result v9
.line 110
.local v9, "writeTimeout":I
invoke-virtual {p1}, Lokhttp3/OkHttpClient;->pingIntervalMillis()I
move-result v10
.line 111
.local v10, "pingIntervalMillis":I
invoke-virtual {p1}, Lokhttp3/OkHttpClient;->retryOnConnectionFailure()Z
move-result v11
.line 114
.local v11, "connectionRetryEnabled":Z
move-object v0, p0
move v1, v7
move v2, v8
move v3, v9
move v4, v10
move v5, v11
move v6, p3
:try_start_1b
invoke-direct/range {v0 .. v6}, Lokhttp3/internal/connection/StreamAllocation;->findHealthyConnection(IIIIZZ)Lokhttp3/internal/connection/RealConnection;
move-result-object v0
.line 116
.local v0, "resultConnection":Lokhttp3/internal/connection/RealConnection;
invoke-virtual {v0, p1, p2, p0}, Lokhttp3/internal/connection/RealConnection;->newCodec(Lokhttp3/OkHttpClient;Lokhttp3/Interceptor$Chain;Lokhttp3/internal/connection/StreamAllocation;)Lokhttp3/internal/http/HttpCodec;
move-result-object v1
.line 118
.local v1, "resultCodec":Lokhttp3/internal/http/HttpCodec;
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v2
:try_end_26
.catch Ljava/io/IOException; {:try_start_1b .. :try_end_26} :catch_2d
.line 119
:try_start_26
iput-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
.line 120
monitor-exit v2
return-object v1
.line 121
:catchall_2a
move-exception v3
monitor-exit v2
:try_end_2c
.catchall {:try_start_26 .. :try_end_2c} :catchall_2a
.end local v7 # "connectTimeout":I
.end local v8 # "readTimeout":I
.end local v9 # "writeTimeout":I
.end local v10 # "pingIntervalMillis":I
.end local v11 # "connectionRetryEnabled":Z
.end local p1 # "client":Lokhttp3/OkHttpClient;
.end local p2 # "chain":Lokhttp3/Interceptor$Chain;
.end local p3 # "doExtensiveHealthChecks":Z
:try_start_2c
throw v3
:try_end_2d
.catch Ljava/io/IOException; {:try_start_2c .. :try_end_2d} :catch_2d
.line 122
.end local v0 # "resultConnection":Lokhttp3/internal/connection/RealConnection;
.end local v1 # "resultCodec":Lokhttp3/internal/http/HttpCodec;
.restart local v7 # "connectTimeout":I
.restart local v8 # "readTimeout":I
.restart local v9 # "writeTimeout":I
.restart local v10 # "pingIntervalMillis":I
.restart local v11 # "connectionRetryEnabled":Z
.restart local p1 # "client":Lokhttp3/OkHttpClient;
.restart local p2 # "chain":Lokhttp3/Interceptor$Chain;
.restart local p3 # "doExtensiveHealthChecks":Z
:catch_2d
move-exception v0
.line 123
.local v0, "e":Ljava/io/IOException;
new-instance v1, Lokhttp3/internal/connection/RouteException;
invoke-direct {v1, v0}, Lokhttp3/internal/connection/RouteException;-><init>(Ljava/io/IOException;)V
throw v1
.end method
.method public noNewStreams()V
.registers 5
.line 363
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 364
:try_start_3
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 365
.local v1, "releasedConnection":Lokhttp3/Connection;
const/4 v2, 0x1
const/4 v3, 0x0
invoke-direct {p0, v2, v3, v3}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v2
.line 366
.local v2, "socket":Ljava/net/Socket;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v3, :cond_10
const/4 v1, 0x0
.line 367
:cond_10
monitor-exit v0
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_1e
.line 368
invoke-static {v2}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 369
if-eqz v1, :cond_1d
.line 370
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v3, v1}, Lokhttp3/EventListener;->connectionReleased(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 372
:cond_1d
return-void
.line 367
.end local v1 # "releasedConnection":Lokhttp3/Connection;
.end local v2 # "socket":Ljava/net/Socket;
:catchall_1e
move-exception v1
:try_start_1f
monitor-exit v0
:try_end_20
.catchall {:try_start_1f .. :try_end_20} :catchall_1e
throw v1
.end method
.method public release()V
.registers 5
.line 347
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 348
:try_start_3
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 349
.local v1, "releasedConnection":Lokhttp3/Connection;
const/4 v2, 0x1
const/4 v3, 0x0
invoke-direct {p0, v3, v2, v3}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v2
.line 350
.local v2, "socket":Ljava/net/Socket;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v3, :cond_10
const/4 v1, 0x0
.line 351
:cond_10
monitor-exit v0
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_25
.line 352
invoke-static {v2}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 353
if-eqz v1, :cond_24
.line 354
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v3, v1}, Lokhttp3/EventListener;->connectionReleased(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 355
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v3}, Lokhttp3/EventListener;->callEnd(Lokhttp3/Call;)V
.line 357
:cond_24
return-void
.line 351
.end local v1 # "releasedConnection":Lokhttp3/Connection;
.end local v2 # "socket":Ljava/net/Socket;
:catchall_25
move-exception v1
:try_start_26
monitor-exit v0
:try_end_27
.catchall {:try_start_26 .. :try_end_27} :catchall_25
throw v1
.end method
.method public releaseAndAcquire(Lokhttp3/internal/connection/RealConnection;)Ljava/net/Socket;
.registers 5
.param p1, "newConnection" # Lokhttp3/internal/connection/RealConnection;
.line 501
nop
.line 502
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
if-nez v0, :cond_27
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget-object v0, v0, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v0}, Ljava/util/List;->size()I
move-result v0
const/4 v1, 0x1
if-ne v0, v1, :cond_27
.line 505
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget-object v0, v0, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
const/4 v2, 0x0
invoke-interface {v0, v2}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/ref/Reference;
.line 506
.local v0, "onlyAllocation":Ljava/lang/ref/Reference;, "Ljava/lang/ref/Reference<Lokhttp3/internal/connection/StreamAllocation;>;"
invoke-direct {p0, v1, v2, v2}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v1
.line 509
.local v1, "socket":Ljava/net/Socket;
iput-object p1, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 510
iget-object v2, p1, Lokhttp3/internal/connection/RealConnection;->allocations:Ljava/util/List;
invoke-interface {v2, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 512
return-object v1
.line 502
.end local v0 # "onlyAllocation":Ljava/lang/ref/Reference;, "Ljava/lang/ref/Reference<Lokhttp3/internal/connection/StreamAllocation;>;"
.end local v1 # "socket":Ljava/net/Socket;
:cond_27
new-instance v0, Ljava/lang/IllegalStateException;
invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
throw v0
.end method
.method public route()Lokhttp3/Route;
.registers 2
.line 337
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
return-object v0
.end method
.method public streamFailed(Ljava/io/IOException;)V
.registers 8
.param p1, "e" # Ljava/io/IOException;
.line 427
const/4 v0, 0x0
.line 429
.local v0, "noNewStreams":Z
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v1
.line 430
:try_start_4
instance-of v2, p1, Lokhttp3/internal/http2/StreamResetException;
const/4 v3, 0x0
const/4 v4, 0x1
if-eqz v2, :cond_26
.line 431
move-object v2, p1
check-cast v2, Lokhttp3/internal/http2/StreamResetException;
iget-object v2, v2, Lokhttp3/internal/http2/StreamResetException;->errorCode:Lokhttp3/internal/http2/ErrorCode;
.line 432
.local v2, "errorCode":Lokhttp3/internal/http2/ErrorCode;
sget-object v5, Lokhttp3/internal/http2/ErrorCode;->REFUSED_STREAM:Lokhttp3/internal/http2/ErrorCode;
if-ne v2, v5, :cond_1e
.line 434
iget v5, p0, Lokhttp3/internal/connection/StreamAllocation;->refusedStreamCount:I
add-int/2addr v5, v4
iput v5, p0, Lokhttp3/internal/connection/StreamAllocation;->refusedStreamCount:I
.line 435
if-le v5, v4, :cond_25
.line 436
const/4 v0, 0x1
.line 437
iput-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
goto :goto_25
.line 439
:cond_1e
sget-object v5, Lokhttp3/internal/http2/ErrorCode;->CANCEL:Lokhttp3/internal/http2/ErrorCode;
if-eq v2, v5, :cond_25
.line 441
const/4 v0, 0x1
.line 442
iput-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
.line 444
.end local v2 # "errorCode":Lokhttp3/internal/http2/ErrorCode;
:cond_25
:goto_25
goto :goto_4c
:cond_26
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v2, :cond_25
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 445
invoke-virtual {v2}, Lokhttp3/internal/connection/RealConnection;->isMultiplexed()Z
move-result v2
if-eqz v2, :cond_36
instance-of v2, p1, Lokhttp3/internal/http2/ConnectionShutdownException;
if-eqz v2, :cond_4c
.line 446
:cond_36
const/4 v0, 0x1
.line 449
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget v2, v2, Lokhttp3/internal/connection/RealConnection;->successCount:I
if-nez v2, :cond_4c
.line 450
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
if-eqz v2, :cond_4a
if-eqz p1, :cond_4a
.line 451
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->routeSelector:Lokhttp3/internal/connection/RouteSelector;
iget-object v5, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
invoke-virtual {v2, v5, p1}, Lokhttp3/internal/connection/RouteSelector;->connectFailed(Lokhttp3/Route;Ljava/io/IOException;)V
.line 453
:cond_4a
iput-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->route:Lokhttp3/Route;
.line 456
:cond_4c
:goto_4c
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 457
.local v2, "releasedConnection":Lokhttp3/Connection;
const/4 v3, 0x0
invoke-direct {p0, v0, v3, v4}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v3
.line 458
.local v3, "socket":Ljava/net/Socket;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-nez v4, :cond_5b
iget-boolean v4, p0, Lokhttp3/internal/connection/StreamAllocation;->reportedAcquired:Z
if-nez v4, :cond_5c
:cond_5b
const/4 v2, 0x0
.line 459
:cond_5c
monitor-exit v1
:try_end_5d
.catchall {:try_start_4 .. :try_end_5d} :catchall_6a
.line 461
invoke-static {v3}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 462
if-eqz v2, :cond_69
.line 463
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v1, v4, v2}, Lokhttp3/EventListener;->connectionReleased(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 465
:cond_69
return-void
.line 459
.end local v2 # "releasedConnection":Lokhttp3/Connection;
.end local v3 # "socket":Ljava/net/Socket;
:catchall_6a
move-exception v2
:try_start_6b
monitor-exit v1
:try_end_6c
.catchall {:try_start_6b .. :try_end_6c} :catchall_6a
goto :goto_6e
:goto_6d
throw v2
:goto_6e
goto :goto_6d
.end method
.method public streamFinished(ZLokhttp3/internal/http/HttpCodec;JLjava/io/IOException;)V
.registers 11
.param p1, "noNewStreams" # Z
.param p2, "codec" # Lokhttp3/internal/http/HttpCodec;
.param p3, "bytesRead" # J
.param p5, "e" # Ljava/io/IOException;
.line 297
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v1, p3, p4}, Lokhttp3/EventListener;->responseBodyEnd(Lokhttp3/Call;J)V
.line 302
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->connectionPool:Lokhttp3/ConnectionPool;
monitor-enter v0
.line 303
if-eqz p2, :cond_49
:try_start_c
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
if-ne p2, v1, :cond_49
.line 306
const/4 v1, 0x1
if-nez p1, :cond_1a
.line 307
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
iget v3, v2, Lokhttp3/internal/connection/RealConnection;->successCount:I
add-int/2addr v3, v1
iput v3, v2, Lokhttp3/internal/connection/RealConnection;->successCount:I
.line 309
:cond_1a
iget-object v2, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
.line 310
.local v2, "releasedConnection":Lokhttp3/Connection;
const/4 v3, 0x0
invoke-direct {p0, p1, v3, v1}, Lokhttp3/internal/connection/StreamAllocation;->deallocate(ZZZ)Ljava/net/Socket;
move-result-object v1
.line 311
.local v1, "socket":Ljava/net/Socket;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->connection:Lokhttp3/internal/connection/RealConnection;
if-eqz v3, :cond_26
const/4 v2, 0x0
.line 312
:cond_26
iget-boolean v3, p0, Lokhttp3/internal/connection/StreamAllocation;->released:Z
.line 313
.local v3, "callEnd":Z
monitor-exit v0
:try_end_29
.catchall {:try_start_c .. :try_end_29} :catchall_6a
.line 314
invoke-static {v1}, Lokhttp3/internal/Util;->closeQuietly(Ljava/net/Socket;)V
.line 315
if-eqz v2, :cond_35
.line 316
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v4, v2}, Lokhttp3/EventListener;->connectionReleased(Lokhttp3/Call;Lokhttp3/Connection;)V
.line 319
:cond_35
if-eqz p5, :cond_3f
.line 320
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v4, p5}, Lokhttp3/EventListener;->callFailed(Lokhttp3/Call;Ljava/io/IOException;)V
goto :goto_48
.line 321
:cond_3f
if-eqz v3, :cond_48
.line 322
iget-object v0, p0, Lokhttp3/internal/connection/StreamAllocation;->eventListener:Lokhttp3/EventListener;
iget-object v4, p0, Lokhttp3/internal/connection/StreamAllocation;->call:Lokhttp3/Call;
invoke-virtual {v0, v4}, Lokhttp3/EventListener;->callEnd(Lokhttp3/Call;)V
.line 324
:cond_48
:goto_48
return-void
.line 304
.end local v1 # "socket":Ljava/net/Socket;
.end local v2 # "releasedConnection":Lokhttp3/Connection;
.end local v3 # "callEnd":Z
:cond_49
:try_start_49
new-instance v1, Ljava/lang/IllegalStateException;
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "expected "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v3, p0, Lokhttp3/internal/connection/StreamAllocation;->codec:Lokhttp3/internal/http/HttpCodec;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v3, " but was "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-direct {v1, v2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
.end local p1 # "noNewStreams":Z
.end local p2 # "codec":Lokhttp3/internal/http/HttpCodec;
.end local p3 # "bytesRead":J
.end local p5 # "e":Ljava/io/IOException;
throw v1
.line 313
.restart local p1 # "noNewStreams":Z
.restart local p2 # "codec":Lokhttp3/internal/http/HttpCodec;
.restart local p3 # "bytesRead":J
.restart local p5 # "e":Ljava/io/IOException;
:catchall_6a
move-exception v1
monitor-exit v0
:try_end_6c
.catchall {:try_start_49 .. :try_end_6c} :catchall_6a
throw v1
.end method
.method public toString()Ljava/lang/String;
.registers 3
.line 522
invoke-virtual {p0}, Lokhttp3/internal/connection/StreamAllocation;->connection()Lokhttp3/internal/connection/RealConnection;
move-result-object v0
.line 523
.local v0, "connection":Lokhttp3/internal/connection/RealConnection;
if-eqz v0, :cond_b
invoke-virtual {v0}, Lokhttp3/internal/connection/RealConnection;->toString()Ljava/lang/String;
move-result-object v1
goto :goto_11
:cond_b
iget-object v1, p0, Lokhttp3/internal/connection/StreamAllocation;->address:Lokhttp3/Address;
invoke-virtual {v1}, Lokhttp3/Address;->toString()Ljava/lang/String;
move-result-object v1
:goto_11
return-object v1
.end method